sketchup-api-stubs 0.7.9 → 0.7.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (160) hide show
  1. checksums.yaml +4 -4
  2. data/lib/sketchup-api-stubs/sketchup.rb +157 -151
  3. data/lib/sketchup-api-stubs/stubs/Array.rb +741 -741
  4. data/lib/sketchup-api-stubs/stubs/Geom/BoundingBox.rb +322 -322
  5. data/lib/sketchup-api-stubs/stubs/Geom/Bounds2d.rb +182 -172
  6. data/lib/sketchup-api-stubs/stubs/Geom/LatLong.rb +111 -126
  7. data/lib/sketchup-api-stubs/stubs/Geom/OrientedBounds2d.rb +102 -102
  8. data/lib/sketchup-api-stubs/stubs/Geom/Point2d.rb +423 -400
  9. data/lib/sketchup-api-stubs/stubs/Geom/Point3d.rb +693 -661
  10. data/lib/sketchup-api-stubs/stubs/Geom/PolygonMesh.rb +535 -509
  11. data/lib/sketchup-api-stubs/stubs/Geom/Transformation.rb +500 -476
  12. data/lib/sketchup-api-stubs/stubs/Geom/Transformation2d.rb +267 -263
  13. data/lib/sketchup-api-stubs/stubs/Geom/UTM.rb +133 -141
  14. data/lib/sketchup-api-stubs/stubs/Geom/Vector2d.rb +547 -522
  15. data/lib/sketchup-api-stubs/stubs/Geom/Vector3d.rb +678 -693
  16. data/lib/sketchup-api-stubs/stubs/Geom.rb +351 -351
  17. data/lib/sketchup-api-stubs/stubs/LanguageHandler.rb +93 -93
  18. data/lib/sketchup-api-stubs/stubs/Layout/AngularDimension.rb +595 -595
  19. data/lib/sketchup-api-stubs/stubs/Layout/AutoTextDefinition.rb +751 -747
  20. data/lib/sketchup-api-stubs/stubs/Layout/AutoTextDefinitions.rb +183 -183
  21. data/lib/sketchup-api-stubs/stubs/Layout/ConnectionPoint.rb +70 -70
  22. data/lib/sketchup-api-stubs/stubs/Layout/Dictionary.rb +234 -0
  23. data/lib/sketchup-api-stubs/stubs/Layout/Document.rb +683 -517
  24. data/lib/sketchup-api-stubs/stubs/Layout/Ellipse.rb +29 -29
  25. data/lib/sketchup-api-stubs/stubs/Layout/Entities.rb +148 -148
  26. data/lib/sketchup-api-stubs/stubs/Layout/Entity.rb +464 -353
  27. data/lib/sketchup-api-stubs/stubs/Layout/FormattedText.rb +354 -354
  28. data/lib/sketchup-api-stubs/stubs/Layout/Grid.rb +311 -311
  29. data/lib/sketchup-api-stubs/stubs/Layout/Group.rb +261 -261
  30. data/lib/sketchup-api-stubs/stubs/Layout/Image.rb +91 -91
  31. data/lib/sketchup-api-stubs/stubs/Layout/Label.rb +370 -370
  32. data/lib/sketchup-api-stubs/stubs/Layout/Layer.rb +218 -218
  33. data/lib/sketchup-api-stubs/stubs/Layout/LayerInstance.rb +128 -128
  34. data/lib/sketchup-api-stubs/stubs/Layout/Layers.rb +225 -225
  35. data/lib/sketchup-api-stubs/stubs/Layout/LinearDimension.rb +614 -567
  36. data/lib/sketchup-api-stubs/stubs/Layout/LockedEntityError.rb +10 -10
  37. data/lib/sketchup-api-stubs/stubs/Layout/LockedLayerError.rb +11 -11
  38. data/lib/sketchup-api-stubs/stubs/Layout/Page.rb +282 -183
  39. data/lib/sketchup-api-stubs/stubs/Layout/PageInfo.rb +458 -387
  40. data/lib/sketchup-api-stubs/stubs/Layout/Pages.rb +209 -209
  41. data/lib/sketchup-api-stubs/stubs/Layout/Path.rb +346 -344
  42. data/lib/sketchup-api-stubs/stubs/Layout/Rectangle.rb +174 -174
  43. data/lib/sketchup-api-stubs/stubs/Layout/ReferenceEntity.rb +82 -82
  44. data/lib/sketchup-api-stubs/stubs/Layout/SketchUpModel.rb +714 -692
  45. data/lib/sketchup-api-stubs/stubs/Layout/Style.rb +1565 -1519
  46. data/lib/sketchup-api-stubs/stubs/Layout/Table.rb +290 -290
  47. data/lib/sketchup-api-stubs/stubs/Layout/TableCell.rb +149 -149
  48. data/lib/sketchup-api-stubs/stubs/Layout/TableColumn.rb +139 -139
  49. data/lib/sketchup-api-stubs/stubs/Layout/TableRow.rb +135 -135
  50. data/lib/sketchup-api-stubs/stubs/Layout.rb +25 -25
  51. data/lib/sketchup-api-stubs/stubs/Length.rb +286 -278
  52. data/lib/sketchup-api-stubs/stubs/Numeric.rb +249 -249
  53. data/lib/sketchup-api-stubs/stubs/Sketchup/Animation.rb +196 -144
  54. data/lib/sketchup-api-stubs/stubs/Sketchup/AppObserver.rb +169 -169
  55. data/lib/sketchup-api-stubs/stubs/Sketchup/ArcCurve.rb +226 -209
  56. data/lib/sketchup-api-stubs/stubs/Sketchup/AttributeDictionaries.rb +145 -150
  57. data/lib/sketchup-api-stubs/stubs/Sketchup/AttributeDictionary.rb +294 -281
  58. data/lib/sketchup-api-stubs/stubs/Sketchup/Axes.rb +149 -149
  59. data/lib/sketchup-api-stubs/stubs/Sketchup/Behavior.rb +296 -302
  60. data/lib/sketchup-api-stubs/stubs/Sketchup/Camera.rb +473 -478
  61. data/lib/sketchup-api-stubs/stubs/Sketchup/ClassificationSchema.rb +63 -63
  62. data/lib/sketchup-api-stubs/stubs/Sketchup/Classifications.rb +121 -121
  63. data/lib/sketchup-api-stubs/stubs/Sketchup/Color.rb +294 -294
  64. data/lib/sketchup-api-stubs/stubs/Sketchup/ComponentDefinition.rb +673 -659
  65. data/lib/sketchup-api-stubs/stubs/Sketchup/ComponentInstance.rb +600 -593
  66. data/lib/sketchup-api-stubs/stubs/Sketchup/Console.rb +76 -76
  67. data/lib/sketchup-api-stubs/stubs/Sketchup/ConstructionLine.rb +252 -257
  68. data/lib/sketchup-api-stubs/stubs/Sketchup/ConstructionPoint.rb +32 -32
  69. data/lib/sketchup-api-stubs/stubs/Sketchup/Curve.rb +201 -201
  70. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionList.rb +443 -449
  71. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionObserver.rb +74 -74
  72. data/lib/sketchup-api-stubs/stubs/Sketchup/DefinitionsObserver.rb +104 -104
  73. data/lib/sketchup-api-stubs/stubs/Sketchup/Dimension.rb +167 -165
  74. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionLinear.rb +306 -306
  75. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionObserver.rb +42 -42
  76. data/lib/sketchup-api-stubs/stubs/Sketchup/DimensionRadial.rb +87 -87
  77. data/lib/sketchup-api-stubs/stubs/Sketchup/Drawingelement.rb +403 -406
  78. data/lib/sketchup-api-stubs/stubs/Sketchup/Edge.rb +397 -397
  79. data/lib/sketchup-api-stubs/stubs/Sketchup/EdgeUse.rb +211 -211
  80. data/lib/sketchup-api-stubs/stubs/Sketchup/Entities.rb +1282 -1239
  81. data/lib/sketchup-api-stubs/stubs/Sketchup/EntitiesBuilder.rb +261 -261
  82. data/lib/sketchup-api-stubs/stubs/Sketchup/EntitiesObserver.rb +127 -127
  83. data/lib/sketchup-api-stubs/stubs/Sketchup/Entity.rb +519 -545
  84. data/lib/sketchup-api-stubs/stubs/Sketchup/EntityObserver.rb +60 -60
  85. data/lib/sketchup-api-stubs/stubs/Sketchup/Environment.rb +406 -0
  86. data/lib/sketchup-api-stubs/stubs/Sketchup/Environments.rb +185 -0
  87. data/lib/sketchup-api-stubs/stubs/Sketchup/EnvironmentsObserver.rb +113 -0
  88. data/lib/sketchup-api-stubs/stubs/Sketchup/ExtensionsManager.rb +122 -125
  89. data/lib/sketchup-api-stubs/stubs/Sketchup/Face.rb +1006 -937
  90. data/lib/sketchup-api-stubs/stubs/Sketchup/FrameChangeObserver.rb +102 -102
  91. data/lib/sketchup-api-stubs/stubs/Sketchup/Group.rb +740 -750
  92. data/lib/sketchup-api-stubs/stubs/Sketchup/Http/Request.rb +289 -282
  93. data/lib/sketchup-api-stubs/stubs/Sketchup/Http/Response.rb +64 -62
  94. data/lib/sketchup-api-stubs/stubs/Sketchup/Http.rb +27 -27
  95. data/lib/sketchup-api-stubs/stubs/Sketchup/Image.rb +405 -468
  96. data/lib/sketchup-api-stubs/stubs/Sketchup/ImageRep.rb +266 -266
  97. data/lib/sketchup-api-stubs/stubs/Sketchup/Importer.rb +189 -189
  98. data/lib/sketchup-api-stubs/stubs/Sketchup/InputPoint.rb +432 -406
  99. data/lib/sketchup-api-stubs/stubs/Sketchup/InstanceObserver.rb +84 -84
  100. data/lib/sketchup-api-stubs/stubs/Sketchup/InstancePath.rb +307 -306
  101. data/lib/sketchup-api-stubs/stubs/Sketchup/Layer.rb +332 -326
  102. data/lib/sketchup-api-stubs/stubs/Sketchup/LayerFolder.rb +380 -422
  103. data/lib/sketchup-api-stubs/stubs/Sketchup/Layers.rb +409 -427
  104. data/lib/sketchup-api-stubs/stubs/Sketchup/LayersObserver.rb +241 -249
  105. data/lib/sketchup-api-stubs/stubs/Sketchup/Licensing/ExtensionLicense.rb +86 -86
  106. data/lib/sketchup-api-stubs/stubs/Sketchup/Licensing.rb +55 -48
  107. data/lib/sketchup-api-stubs/stubs/Sketchup/LineStyle.rb +24 -24
  108. data/lib/sketchup-api-stubs/stubs/Sketchup/LineStyles.rb +114 -114
  109. data/lib/sketchup-api-stubs/stubs/Sketchup/LoadHandler.rb +70 -0
  110. data/lib/sketchup-api-stubs/stubs/Sketchup/Loop.rb +137 -137
  111. data/lib/sketchup-api-stubs/stubs/Sketchup/Material.rb +1115 -414
  112. data/lib/sketchup-api-stubs/stubs/Sketchup/Materials.rb +330 -317
  113. data/lib/sketchup-api-stubs/stubs/Sketchup/MaterialsObserver.rb +142 -142
  114. data/lib/sketchup-api-stubs/stubs/Sketchup/Menu.rb +93 -93
  115. data/lib/sketchup-api-stubs/stubs/Sketchup/Model.rb +1714 -1652
  116. data/lib/sketchup-api-stubs/stubs/Sketchup/ModelObserver.rb +372 -357
  117. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsManager.rb +133 -130
  118. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsProvider.rb +271 -271
  119. data/lib/sketchup-api-stubs/stubs/Sketchup/OptionsProviderObserver.rb +58 -58
  120. data/lib/sketchup-api-stubs/stubs/Sketchup/Overlay.rb +463 -490
  121. data/lib/sketchup-api-stubs/stubs/Sketchup/OverlaysManager.rb +104 -116
  122. data/lib/sketchup-api-stubs/stubs/Sketchup/Page.rb +939 -797
  123. data/lib/sketchup-api-stubs/stubs/Sketchup/Pages.rb +388 -361
  124. data/lib/sketchup-api-stubs/stubs/Sketchup/PagesObserver.rb +77 -77
  125. data/lib/sketchup-api-stubs/stubs/Sketchup/PickHelper.rb +501 -478
  126. data/lib/sketchup-api-stubs/stubs/Sketchup/RegionalSettings.rb +43 -43
  127. data/lib/sketchup-api-stubs/stubs/Sketchup/RenderingOptions.rb +385 -361
  128. data/lib/sketchup-api-stubs/stubs/Sketchup/RenderingOptionsObserver.rb +45 -45
  129. data/lib/sketchup-api-stubs/stubs/Sketchup/SectionPlane.rb +150 -150
  130. data/lib/sketchup-api-stubs/stubs/Sketchup/Selection.rb +451 -458
  131. data/lib/sketchup-api-stubs/stubs/Sketchup/SelectionObserver.rb +115 -115
  132. data/lib/sketchup-api-stubs/stubs/Sketchup/Set.rb +211 -212
  133. data/lib/sketchup-api-stubs/stubs/Sketchup/ShadowInfo.rb +259 -255
  134. data/lib/sketchup-api-stubs/stubs/Sketchup/ShadowInfoObserver.rb +59 -59
  135. data/lib/sketchup-api-stubs/stubs/Sketchup/Skp.rb +40 -40
  136. data/lib/sketchup-api-stubs/stubs/Sketchup/Snap.rb +125 -0
  137. data/lib/sketchup-api-stubs/stubs/Sketchup/Style.rb +88 -69
  138. data/lib/sketchup-api-stubs/stubs/Sketchup/Styles.rb +263 -217
  139. data/lib/sketchup-api-stubs/stubs/Sketchup/Text.rb +283 -262
  140. data/lib/sketchup-api-stubs/stubs/Sketchup/Texture.rb +199 -217
  141. data/lib/sketchup-api-stubs/stubs/Sketchup/TextureWriter.rb +237 -237
  142. data/lib/sketchup-api-stubs/stubs/Sketchup/Tool.rb +924 -834
  143. data/lib/sketchup-api-stubs/stubs/Sketchup/Tools.rb +132 -132
  144. data/lib/sketchup-api-stubs/stubs/Sketchup/ToolsObserver.rb +156 -156
  145. data/lib/sketchup-api-stubs/stubs/Sketchup/UVHelper.rb +75 -75
  146. data/lib/sketchup-api-stubs/stubs/Sketchup/Vertex.rb +143 -142
  147. data/lib/sketchup-api-stubs/stubs/Sketchup/View.rb +1566 -1311
  148. data/lib/sketchup-api-stubs/stubs/Sketchup/ViewObserver.rb +71 -45
  149. data/lib/sketchup-api-stubs/stubs/Sketchup.rb +1429 -1377
  150. data/lib/sketchup-api-stubs/stubs/SketchupExtension.rb +353 -353
  151. data/lib/sketchup-api-stubs/stubs/String.rb +24 -24
  152. data/lib/sketchup-api-stubs/stubs/UI/Command.rb +399 -389
  153. data/lib/sketchup-api-stubs/stubs/UI/HtmlDialog.rb +580 -494
  154. data/lib/sketchup-api-stubs/stubs/UI/Notification.rb +280 -269
  155. data/lib/sketchup-api-stubs/stubs/UI/Toolbar.rb +258 -241
  156. data/lib/sketchup-api-stubs/stubs/UI/WebDialog.rb +636 -635
  157. data/lib/sketchup-api-stubs/stubs/UI.rb +791 -683
  158. data/lib/sketchup-api-stubs/stubs/_top_level.rb +303 -303
  159. data/lib/sketchup-api-stubs.rb +1 -1
  160. metadata +10 -24
@@ -1,237 +1,237 @@
1
- # Copyright:: Copyright 2023 Trimble Inc.
2
- # License:: The MIT License (MIT)
3
-
4
- # The TextureWriter class is used primarily for writing the textures used in a
5
- # SketchUp model out to files as part of an export for use in another
6
- # application. These methods are usually invoked in this order:
7
- #
8
- # - 1. load - load one or more textures from a model into the TextureWriter.
9
- # - 2. write_all or write - write the texture(s) to file.
10
- #
11
- # @example
12
- # # This code snippet sets up a texture writer and some variables that are
13
- # # used in the following texture writer examples.
14
- # # Assumptions:
15
- # # 1) The active model contains at least one entity at the root level of the
16
- # # following types: component instance, group, or image.
17
- # # 2) The active model contains at least one face at the root level.
18
- # model = Sketchup.active_model
19
- # entities = model.entities
20
- # faces = entities.grep(Sketchup::Face)
21
- # texturable_entities = entities.select{ |ent|
22
- # (ent.is_a?(Sketchup::ComponentInstance) ||
23
- # ent.is_a?(Sketchup::Group) || ent.is_a?(Sketchup::Image)) }
24
- # tw = Sketchup.create_texture_writer
25
- #
26
- # @version SketchUp 6.0
27
- class Sketchup::TextureWriter
28
-
29
- # Instance Methods
30
-
31
- # The {#length} method is used to determine the number of textures loaded into
32
- # the texture writer.
33
- #
34
- # The {#count} method is an alias for {#length}.
35
- #
36
- # @example
37
- # length = tw.length
38
- # tw.load(texturable_entities[0])
39
- # if length < tw.length
40
- # puts("A new entity was successfully loaded into the writer.")
41
- # end
42
- #
43
- # @return [Integer] length - the number of textures loaded in the texture
44
- # writer
45
- #
46
- # @version SketchUp 6.0
47
- def count
48
- end
49
-
50
- # The filename method is used to retrieve the original filename for a
51
- # particular texture.
52
- #
53
- # @example
54
- # index = tw.load(texturable_entities[0])
55
- # filename = tw.filename(index)
56
- # puts("filename = #{filename}")
57
- #
58
- # @param [Integer] handle
59
- # The index or handle of the texture in the texture
60
- # writer.
61
- #
62
- # @return [String] filename - the filename of the texture on the file system.
63
- # Textures can be generated without filenames, so if the
64
- # texture doesn't have a name write_all will save the
65
- # texture to an image file named "i.png". Where i is the
66
- # first integer greater than zero which was not already used
67
- # for a png file name.
68
- #
69
- # @version SketchUp 6.0
70
- def filename(handle)
71
- end
72
-
73
- # The handle method is used to retrieve a handle or index for a specific
74
- # texture in the texture writer.
75
- #
76
- # @example
77
- # tw.load(texturable_entities[0])
78
- # handle = tw.handle(texturable_entities[0])
79
- #
80
- # @example
81
- # load_front_face = true
82
- # tw.load(faces[0], load_front_face)
83
- # handle = tw.handle(faces[0], load_front_face)
84
- #
85
- # @overload handle(entity)
86
- #
87
- # @param [Sketchup::Entity] entity A image, component instance, group, or
88
- # layer.
89
- # @return [Integer] the index for the entity in the texture writer.
90
- #
91
- # @overload handle(face, side)
92
- #
93
- # @param [Sketchup::Face] face
94
- # @param [Boolean] side Specifies one of the sides of the face
95
- # (true if front, false if back.)
96
- # @return [Integer] the index for the entity in the texture writer.
97
- #
98
- # @version SketchUp 6.0
99
- def handle(*args)
100
- end
101
-
102
- # The {#length} method is used to determine the number of textures loaded into
103
- # the texture writer.
104
- #
105
- # The {#count} method is an alias for {#length}.
106
- #
107
- # @example
108
- # length = tw.length
109
- # tw.load(texturable_entities[0])
110
- # if length < tw.length
111
- # puts("A new entity was successfully loaded into the writer.")
112
- # end
113
- #
114
- # @return [Integer] length - the number of textures loaded in the texture
115
- # writer
116
- #
117
- # @version SketchUp 6.0
118
- def length
119
- end
120
-
121
- # The load method is used to load one or more textures into the texture writer
122
- # for writing out to a file.
123
- #
124
- # @example
125
- # index = tw.load(texturable_entities[0])
126
- #
127
- # @example
128
- # index = tw.load(faces[0], true)
129
- #
130
- # @note If you are passing a face in as the entity argument when loading a
131
- # texture you will have to specify the second boolean argument, side.
132
- # The argument side specifies which side of the face the texture will be
133
- # loaded from.
134
- #
135
- # @overload load(entity)
136
- #
137
- # @param [Sketchup::Entity] entity Image, component instance, group, or layer
138
- # to load.
139
- # @return [Integer] handle - the index or handle of the entity that was
140
- # loaded
141
- #
142
- # @overload load(face, side)
143
- #
144
- # @param [Sketchup::Face] face A face to load.
145
- # @param [Boolean] side A boolean used to indicate the side of the
146
- # face being loaded (true if front, false if
147
- # back).
148
- # @return [Integer] handle - the index or handle of the entity that was
149
- # loaded
150
- #
151
- # @version SketchUp 6.0
152
- def load(*args)
153
- end
154
-
155
- # The write method is used to write an individual textures, within the texture
156
- # writer, to a file. An entity's texture must have been loaded into the texture
157
- # writer before this method can be used to write it's texture.
158
- #
159
- # This method will return one of the following status messages. (These are
160
- # constants that are defined by the API.)
161
- #
162
- # - 0 = FILE_WRITE_OK
163
- # - 1 = FILE_WRITE_FAILED_INVALID_TIFF
164
- # - 2 = FILE_WRITE_FAILED_UNKNOWN
165
- #
166
- # @example
167
- # tw.load(texturable_entities[0])
168
- # if tw.write(texturable_entities[0], "C:\\textures\\A.jpg") == FILE_WRITE_OK
169
- # puts("JPEG file successfully written.")
170
- # end
171
- #
172
- # @example
173
- # tw.load(faces[0], true)
174
- # if tw.write(faces[0], true, "C:\\textures\\Face.png") == FILE_WRITE_OK
175
- # puts("PNG file successfully written.")
176
- # end
177
- # if tw.write(faces[0], true, "C:\\textures\\Face.bmp") == FILE_WRITE_OK
178
- # puts("BMP file successfully written.")
179
- # end
180
- # if tw.write(faces[0], true, "C:\\textures\\Face.tif") == FILE_WRITE_OK
181
- # puts("TIFF file successfully written.")
182
- # end
183
- #
184
- # @note If you are passing a face in as the entity argument when writing a
185
- # texture you will have to specify the boolean argument, side. The argument
186
- # side controls the side of the face from which the texture will be sampled
187
- # before writing it.
188
- #
189
- # @overload write(entity, filename)
190
- #
191
- # @param [Sketchup::Entity] entity An image, component instance, group, or
192
- # layer to write.
193
- # @param [String] filename The name of the file to contain the
194
- # texture.
195
- # @return [Integer] status - one of three status messages (see comments.)
196
- #
197
- # @overload write(entity, side, filename)
198
- #
199
- # @param [Sketchup::Entity] entity A face to write.
200
- # @param [Boolean] side A boolean used to indicate the side of the
201
- # face being written (true if front, false
202
- # if back).
203
- # @param [String] filename The name of the file to contain the
204
- # texture.
205
- # @return [Integer] status - one of three status messages (see comments.)
206
- #
207
- # @version SketchUp 6.0
208
- def write(*args)
209
- end
210
-
211
- # The write_all method is used to write all of the textures within the texture
212
- # writer to files. It will return one of three status numbers:
213
- #
214
- # - 0 = FILE_WRITE_OK
215
- # - 1 = FILE_WRITE_FAILED_INVALID_TIFF
216
- # - 2 = FILE_WRITE_FAILED_UNKNOWN
217
- #
218
- # @example
219
- # tw.load(texturable_entities[0]
220
- # tw.load(faces[0], false)
221
- # if tw.write_all("C:\\textures\\", true) == FILE_WRITE_OK
222
- # puts("Texture files were successfully written.")
223
- # end
224
- #
225
- # @param [String] dirname
226
- # The directory to write to.
227
- #
228
- # @param [Boolean] filename_format
229
- # true to use 8.3 DOS name format.
230
- #
231
- # @return [Integer] status - one of three status messages (see comments.)
232
- #
233
- # @version SketchUp 6.0
234
- def write_all(dirname, filename_format)
235
- end
236
-
237
- end
1
+ # Copyright:: Copyright 2026 Trimble Inc.
2
+ # License:: The MIT License (MIT)
3
+
4
+ # The TextureWriter class is used primarily for writing the textures used in a
5
+ # SketchUp model out to files as part of an export for use in another
6
+ # application. These methods are usually invoked in this order:
7
+ #
8
+ # 1. {#load} - load one or more textures from a model into the TextureWriter.
9
+ # 2. {#write_all} or {#write} - write the texture(s) to file.
10
+ #
11
+ # @example
12
+ # # This code snippet sets up a texture writer and some variables that are
13
+ # # used in the following texture writer examples.
14
+ # # Assumptions:
15
+ # # 1) The active model contains at least one entity at the root level of the
16
+ # # following types: component instance, group, or image.
17
+ # # 2) The active model contains at least one face at the root level.
18
+ # model = Sketchup.active_model
19
+ # entities = model.entities
20
+ # faces = entities.grep(Sketchup::Face)
21
+ # texturable_entities = entities.select{ |ent|
22
+ # (ent.is_a?(Sketchup::ComponentInstance) ||
23
+ # ent.is_a?(Sketchup::Group) || ent.is_a?(Sketchup::Image)) }
24
+ # tw = Sketchup.create_texture_writer
25
+ #
26
+ # @version SketchUp 6.0
27
+ class Sketchup::TextureWriter
28
+
29
+ # Instance Methods
30
+
31
+ # The {#length} method is used to determine the number of textures loaded into
32
+ # the texture writer.
33
+ #
34
+ # The {#count} method is an alias for {#length}.
35
+ #
36
+ # @example
37
+ # length = tw.length
38
+ # tw.load(texturable_entities[0])
39
+ # if length < tw.length
40
+ # puts("A new entity was successfully loaded into the writer.")
41
+ # end
42
+ #
43
+ # @return [Integer] length - the number of textures loaded in the texture
44
+ # writer
45
+ #
46
+ # @version SketchUp 6.0
47
+ def count
48
+ end
49
+
50
+ # The filename method is used to retrieve the original filename for a
51
+ # particular texture.
52
+ #
53
+ # @example
54
+ # index = tw.load(texturable_entities[0])
55
+ # filename = tw.filename(index)
56
+ # puts("filename = #{filename}")
57
+ #
58
+ # @param [Integer] handle
59
+ # The index or handle of the texture in the texture
60
+ # writer.
61
+ #
62
+ # @return [String] filename - the filename of the texture on the file system.
63
+ # Textures can be generated without filenames, so if the
64
+ # texture doesn't have a name write_all will save the
65
+ # texture to an image file named "i.png". Where i is the
66
+ # first integer greater than zero which was not already used
67
+ # for a png file name.
68
+ #
69
+ # @version SketchUp 6.0
70
+ def filename(handle)
71
+ end
72
+
73
+ # The handle method is used to retrieve a handle or index for a specific
74
+ # texture in the texture writer.
75
+ #
76
+ # @example
77
+ # tw.load(texturable_entities[0])
78
+ # handle = tw.handle(texturable_entities[0])
79
+ #
80
+ # @example
81
+ # load_front_face = true
82
+ # tw.load(faces[0], load_front_face)
83
+ # handle = tw.handle(faces[0], load_front_face)
84
+ #
85
+ # @overload handle(entity)
86
+ #
87
+ # @param [Sketchup::Entity] entity A image, component instance, group, or
88
+ # layer.
89
+ # @return [Integer] the index for the entity in the texture writer.
90
+ #
91
+ # @overload handle(face, side)
92
+ #
93
+ # @param [Sketchup::Face] face
94
+ # @param [Boolean] side Specifies one of the sides of the face
95
+ # (true if front, false if back.)
96
+ # @return [Integer] the index for the entity in the texture writer.
97
+ #
98
+ # @version SketchUp 6.0
99
+ def handle(*args)
100
+ end
101
+
102
+ # The {#length} method is used to determine the number of textures loaded into
103
+ # the texture writer.
104
+ #
105
+ # The {#count} method is an alias for {#length}.
106
+ #
107
+ # @example
108
+ # length = tw.length
109
+ # tw.load(texturable_entities[0])
110
+ # if length < tw.length
111
+ # puts("A new entity was successfully loaded into the writer.")
112
+ # end
113
+ #
114
+ # @return [Integer] length - the number of textures loaded in the texture
115
+ # writer
116
+ #
117
+ # @version SketchUp 6.0
118
+ def length
119
+ end
120
+
121
+ # The load method is used to load one or more textures into the texture writer
122
+ # for writing out to a file.
123
+ #
124
+ # @example
125
+ # index = tw.load(texturable_entities[0])
126
+ #
127
+ # @example
128
+ # index = tw.load(faces[0], true)
129
+ #
130
+ # @note If you are passing a face in as the entity argument when loading a
131
+ # texture you will have to specify the second boolean argument, side.
132
+ # The argument side specifies which side of the face the texture will be
133
+ # loaded from.
134
+ #
135
+ # @overload load(entity)
136
+ #
137
+ # @param [Sketchup::Entity] entity Image, component instance, group, or layer
138
+ # to load.
139
+ # @return [Integer] handle - the index or handle of the entity that was
140
+ # loaded
141
+ #
142
+ # @overload load(face, side)
143
+ #
144
+ # @param [Sketchup::Face] face A face to load.
145
+ # @param [Boolean] side A boolean used to indicate the side of the
146
+ # face being loaded (true if front, false if
147
+ # back).
148
+ # @return [Integer] handle - the index or handle of the entity that was
149
+ # loaded
150
+ #
151
+ # @version SketchUp 6.0
152
+ def load(*args)
153
+ end
154
+
155
+ # The write method is used to write an individual textures, within the texture
156
+ # writer, to a file. An entity's texture must have been loaded into the texture
157
+ # writer before this method can be used to write it's texture.
158
+ #
159
+ # This method will return one of the following status messages. (These are
160
+ # constants that are defined by the API.)
161
+ #
162
+ # - 0 = {FILE_WRITE_OK}
163
+ # - 1 = {FILE_WRITE_FAILED_INVALID_TYPE}
164
+ # - 2 = {FILE_WRITE_FAILED_UNKNOWN}
165
+ #
166
+ # @example
167
+ # tw.load(texturable_entities[0])
168
+ # if tw.write(texturable_entities[0], "C:\\textures\\A.jpg") == FILE_WRITE_OK
169
+ # puts("JPEG file successfully written.")
170
+ # end
171
+ #
172
+ # @example
173
+ # tw.load(faces[0], true)
174
+ # if tw.write(faces[0], true, "C:\\textures\\Face.png") == FILE_WRITE_OK
175
+ # puts("PNG file successfully written.")
176
+ # end
177
+ # if tw.write(faces[0], true, "C:\\textures\\Face.bmp") == FILE_WRITE_OK
178
+ # puts("BMP file successfully written.")
179
+ # end
180
+ # if tw.write(faces[0], true, "C:\\textures\\Face.tif") == FILE_WRITE_OK
181
+ # puts("TIFF file successfully written.")
182
+ # end
183
+ #
184
+ # @note If you are passing a face in as the entity argument when writing a
185
+ # texture you will have to specify the boolean argument, side. The argument
186
+ # side controls the side of the face from which the texture will be sampled
187
+ # before writing it.
188
+ #
189
+ # @overload write(entity, filename)
190
+ #
191
+ # @param [Sketchup::Entity] entity An image, component instance, group, or
192
+ # layer to write.
193
+ # @param [String] filename The name of the file to contain the
194
+ # texture.
195
+ # @return [Integer] status - one of three status messages (see comments.)
196
+ #
197
+ # @overload write(entity, side, filename)
198
+ #
199
+ # @param [Sketchup::Entity] entity A face to write.
200
+ # @param [Boolean] side A boolean used to indicate the side of the
201
+ # face being written (true if front, false
202
+ # if back).
203
+ # @param [String] filename The name of the file to contain the
204
+ # texture.
205
+ # @return [Integer] status - one of three status messages (see comments.)
206
+ #
207
+ # @version SketchUp 6.0
208
+ def write(*args)
209
+ end
210
+
211
+ # The write_all method is used to write all of the textures within the texture
212
+ # writer to files. It will return one of three status numbers:
213
+ #
214
+ # - 0 = {FILE_WRITE_OK}
215
+ # - 1 = {FILE_WRITE_FAILED_INVALID_TYPE}
216
+ # - 2 = {FILE_WRITE_FAILED_UNKNOWN}
217
+ #
218
+ # @example
219
+ # tw.load(texturable_entities[0]
220
+ # tw.load(faces[0], false)
221
+ # if tw.write_all("C:\\textures\\", true) == FILE_WRITE_OK
222
+ # puts("Texture files were successfully written.")
223
+ # end
224
+ #
225
+ # @param [String] dirname
226
+ # The directory to write to.
227
+ #
228
+ # @param [Boolean] filename_format
229
+ # true to use 8.3 DOS name format.
230
+ #
231
+ # @return [Integer] status - one of three status messages (see comments.)
232
+ #
233
+ # @version SketchUp 6.0
234
+ def write_all(dirname, filename_format)
235
+ end
236
+
237
+ end