Best way to get all Face's in model?
-
I'm having trouble getting an
Array
of all Face's in the model, sinceSketchup.active_model.entities
returnsGroup
objects, without theFace
's contained within them. -
model = Sketchup.active_model faces = [] faces.concat( model.entities.select{|e| e.is_a?( Sketchup;;Face ) } model.definitions.each { |d| next if d.image? faces.concat( d.entities.select{|e| e.is_a?( Sketchup;;Face ) } }
-
Thanks thomthom!
-
thomthom, I run your code on Sketchup 7.1:
(eval);508; compile error (eval);505; syntax error, unexpected tIDENTIFIER, expecting ')' model.definitions.each { |d| ^ (eval);508; syntax error, unexpected '}', expecting ')'<<< Process finished.
-
Ther was a typo [a missing ')'...]
model = Sketchup.active_model faces = [] faces.concat( model.entities.select{|e| e.is_a?( Sketchup;;Face ) } model.definitions.each { |d| next if d.image? faces.concat( d.entities.select{|e| e.is_a?( Sketchup;;Face ) } ) }
-
This code work:
model = Sketchup.active_model faces = [] faces.concat( model.entities.select{|e| e.is_a?( Sketchup;;Face ) } ) model.definitions.each { |d| next if d.image? faces.concat( d.entities.select{|e| e.is_a?( Sketchup;;Face ) } ) }
-
@exvion said:
This code work:
model = Sketchup.active_model > faces = [] > faces.concat( model.entities.select{|e| e.is_a?( Sketchup;;Face ) } ) > model.definitions.each { |d| > next if d.image? > faces.concat( d.entities.select{|e| e.is_a?( Sketchup;;Face ) } ) > }
It doesn't seem to be working for me. I put it as a method called get_face_array() inside a class called Tester:
This is a 68.2MB model.
-
faces = [] faces.concat( model.entities.select{|e| e.is_a?( Sketchup::Face ) } )
Could be simplified to:
faces = model.entities.select{|e| e.is_a?( Sketchup::Face ) }
-
@draftomatic said:
It doesn't seem to be working for me. I put it as a method called get_face_array() inside a class called Tester:
It doesn't return the correct number because the code doesn't take into account instances.
<span class="syntaxdefault">def number_of_faces<br /> model </span><span class="syntaxkeyword">=</span><span class="syntaxdefault"> Sketchup</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">active_model<br /> faces </span><span class="syntaxkeyword">=</span><span class="syntaxdefault"> model</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">entities</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">select</span><span class="syntaxkeyword">{|</span><span class="syntaxdefault">e</span><span class="syntaxkeyword">|</span><span class="syntaxdefault"> e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">is_a</span><span class="syntaxkeyword">?(</span><span class="syntaxdefault"> Sketchup</span><span class="syntaxkeyword">;;</span><span class="syntaxdefault">Face </span><span class="syntaxkeyword">)</span><span class="syntaxdefault"> </span><span class="syntaxkeyword">}.</span><span class="syntaxdefault">length<br /> model</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">definitions</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">each </span><span class="syntaxkeyword">{</span><span class="syntaxdefault"> </span><span class="syntaxkeyword">|</span><span class="syntaxdefault">d</span><span class="syntaxkeyword">|<br /></span><span class="syntaxdefault"> next if d</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">image</span><span class="syntaxkeyword">?<br /></span><span class="syntaxdefault"> next if d</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">count_instances </span><span class="syntaxkeyword">==</span><span class="syntaxdefault"> 0<br /> faces </span><span class="syntaxkeyword">+=</span><span class="syntaxdefault"> </span><span class="syntaxkeyword">(</span><span class="syntaxdefault"> d</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">entities</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">select</span><span class="syntaxkeyword">{|</span><span class="syntaxdefault">e</span><span class="syntaxkeyword">|</span><span class="syntaxdefault"> e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">is_a</span><span class="syntaxkeyword">?(</span><span class="syntaxdefault"> Sketchup</span><span class="syntaxkeyword">;;</span><span class="syntaxdefault">Face </span><span class="syntaxkeyword">)</span><span class="syntaxdefault"> </span><span class="syntaxkeyword">}.</span><span class="syntaxdefault">length </span><span class="syntaxkeyword">*</span><span class="syntaxdefault"> d</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">count_instances </span><span class="syntaxkeyword">)<br /></span><span class="syntaxdefault"> </span><span class="syntaxkeyword">}<br /></span><span class="syntaxdefault">end</span>
-
Or - even easier if you can settle with SU7.1 or higher:
model.number_faces
-
Oh, wait - you actually need arrays of all the face entities?
-
@thomthom said:
Oh, wait - you actually need arrays of all the face entities?
Well, I really just needed to iterate through all the Faces in the model... the array thing is just useful for testing.
Bah, I should've realized the instances issue... So your code in the 2nd post isn't quite right
-
@draftomatic said:
Bah, I should've realized the instances issue... So your code in the 2nd post isn't quite right
It depends what you do with it...
If you need to count the faces you need to take into account all instances.But if you need to just iterate over all faces you only need to process model.entities and the entities of each definition, even if a definition has multiple instances, a face in that definition is the same in each instance. It just exist in multiple locations.
-
@thomthom said:
@draftomatic said:
Bah, I should've realized the instances issue... So your code in the 2nd post isn't quite right
It depends what you do with it...
If you need to count the faces you need to take into account all instances.But if you need to just iterate over all faces you only need to process model.entities and the entities of each definition, even if a definition has multiple instances, a face in that definition is the same in each instance. It just exist in multiple locations.
As you saw a few minutes ago, I'm writing an exporter, and it doesn't keep Component information. I need every Face.
-
Closer, but still not working:
Here's the get_face_count() method I'm using:
def get_face_count() count = 0 @model.entities.each { |e| if (e.is_a?(Sketchup;;Face)) count +=1 end } @model.definitions.each { |d| next if d.image? next if d.count_instances == 0 count += d.entities.select { |e| e.is_a?(Sketchup;;Face) }.length * d.count_instances } return count end
-
hm... instances inside other instance might throw the count of...
I think you need to traverse the model in a tree like structure
<span class="syntaxdefault"><br />def process_model<br /> walk_faces</span><span class="syntaxkeyword">( </span><span class="syntaxdefault">Sketchup</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">active_model </span><span class="syntaxkeyword">)<br /></span><span class="syntaxdefault">end<br /><br />def walk_faces</span><span class="syntaxkeyword">( </span><span class="syntaxdefault">entities</span><span class="syntaxkeyword">, </span><span class="syntaxdefault">transformation </span><span class="syntaxkeyword">= </span><span class="syntaxdefault">Geom</span><span class="syntaxkeyword">;;</span><span class="syntaxdefault">Transformation</span><span class="syntaxkeyword">.new )<br /> </span><span class="syntaxdefault">faces </span><span class="syntaxkeyword">= []<br /> for </span><span class="syntaxdefault">e in entities<br /> </span><span class="syntaxkeyword">if </span><span class="syntaxdefault">e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">is_a</span><span class="syntaxkeyword">?( </span><span class="syntaxdefault">Sketchup</span><span class="syntaxkeyword">;;</span><span class="syntaxdefault">Face </span><span class="syntaxkeyword">)<br /> </span><span class="syntaxdefault">faces </span><span class="syntaxkeyword"><< </span><span class="syntaxdefault">e<br /> </span><span class="syntaxkeyword">elseif </span><span class="syntaxdefault">e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">is_a</span><span class="syntaxkeyword">?( </span><span class="syntaxdefault">Sketchup</span><span class="syntaxkeyword">;;</span><span class="syntaxdefault">Group </span><span class="syntaxkeyword">)<br /> </span><span class="syntaxdefault">faces</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">concat</span><span class="syntaxkeyword">( </span><span class="syntaxdefault">walk_faces</span><span class="syntaxkeyword">( </span><span class="syntaxdefault">e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">entities</span><span class="syntaxkeyword">, </span><span class="syntaxdefault">transformation </span><span class="syntaxkeyword">* </span><span class="syntaxdefault">e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">transformation </span><span class="syntaxkeyword">) )<br /> elseif </span><span class="syntaxdefault">e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">is_a</span><span class="syntaxkeyword">?( </span><span class="syntaxdefault">Sketchup</span><span class="syntaxkeyword">;;</span><span class="syntaxdefault">ComponentInstance </span><span class="syntaxkeyword">)<br /> </span><span class="syntaxdefault">faces</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">concat</span><span class="syntaxkeyword">( </span><span class="syntaxdefault">walk_faces</span><span class="syntaxkeyword">( </span><span class="syntaxdefault">e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">definition</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">entities</span><span class="syntaxkeyword">, </span><span class="syntaxdefault">transformation </span><span class="syntaxkeyword">* </span><span class="syntaxdefault">e</span><span class="syntaxkeyword">.</span><span class="syntaxdefault">transformation </span><span class="syntaxkeyword">) )<br /> </span><span class="syntaxdefault">end<br /> end<br /> faces<br />end<br /></span>
(Untested - but something like this)
-
Your code had a few lil typos; this one works:
def process_model() return walk_faces( Sketchup.active_model.entities ) end def walk_faces( entities, transformation = Geom;;Transformation.new ) faces = [] entities.each { |e| if e.is_a?( Sketchup;;Face ) faces << e elsif e.is_a?( Sketchup;;Group ) faces.concat( walk_faces( e.entities, transformation * e.transformation ) ) elsif e.is_a?( Sketchup;;ComponentInstance ) faces.concat( walk_faces( e.definition.entities, transformation * e.transformation ) ) end } return faces end
Thanks Tom, you're the best!
-
There we go - got there in the end!
-
One more question - I see you're messing with a transformation - if I ask a nested instance for, say, it's Face's vertices locations (assuming it's just a rectangle or something simple), will it give me the (globally) correct coordinates, or something relative to the Component's origin?
I guess ComponentDefinitions have entities, so I can ask for their locations. But ComponentInstances are transformed somewhere... I don't have much experience with transformations...
EDIT: Ah nevermind, I see now that you're carrying the transformation through each nesting of an instance. Gotcha.
Thanks again Tom
-
Had a feeling the transformation would be needed.
Advertisement