WxWindows for SketchUp Dialogs
-
@unknownuser said:
BTW. Why Sketchup.active_model.name returns always an empty string. Shouldn't it refer to the file name??
No - form the manual: http://code.google.com/intl/nb/apis/sketchup/docs/ourdoc/model.html#name
The name method retrieves the string name of the model.
Does not refer to filename. But I think it's similar to definition.name. When you import one model into another it comes in as a component - and I think this property refers to what the definition name will be.
But you have
model.path
instead:
http://code.google.com/intl/nb/apis/sketchup/docs/ourdoc/model.html#path -
@unknownuser said:
model_name=File.basename(model_path,".skp")
was
model_name=File.basename(model_path)
which was including extension of a SU file.The
Model.title
method returns the basename (ie filename,) minus the file extension.Note comparison:
model_name=File.basename(model_path,".skp") Sketchup.active_model.title == model_name # would return true
-
@dan rathbun said:
The
Model.title
method returns the basename (ie filename,) minus the file extension.Uh? is that something SU implements? don't see it in the manual...
-
@thomthom said:
@dan rathbun said:
The
Model.title
method returns the basename (ie filename,) minus the file extension.Uh? is that something SU implements? don't see it in the manual...
Woops.. sorry omitted the link. Here is is:
http://code.google.com/apis/sketchup/docs/ourdoc/model.html#title -
I'm going crosseyed. didn't see that. think I looked at
Sketchup
class when I looked... -
@dan rathbun said:
The
Model.title
method returns the basename (ie filename,) minus the file extension.Thanks. I wasn't aware of the method.
-
@unknownuser said:
Why Sketchup.active_model.name returns always an empty string.
ANSWER: It doesn't ALWAYS return an empty
String
, it always returns the value of thename
attribute (which is classString
.)But IF you never set the value of the
name
attribute, then of course it will 'seem' to always be an empty value, because it is.The value can be set easily using the
Model.name=
method.Example Code:
n = Sketchup.active_model.name n.inspect #>> "" Sketchup.active_model.name="A newly set name for my model." n.inspect #>> "A newly set name for my model."
IF you are writing plugins for other users, you should not expect the
name
attribute to always be empty, and should (in your code,) allow for those times when themodel
has been assigned aname
value (by the user or another plugin.)ALSO, in the Outliner Window, the model will be listed by
.title
value, NOT by the.name
attribute.P.S.: I can't find a edit control, anywhere in the UI that allows setting the
.name
(or the.tags
) attribute. They SHOULD be on the 'File' page of the Model Info ToolDialog, but are not. (This forces us to use the Console to set the name or write a lil' script to make an inputbox.)Edited: meant to say '
.tags
' attribute instead of '.note'; anote
is just aText
class object, and not a attribute of theModel
. -
@unknownuser said:
Have you used the WxFormBuilder? It would be nice to have a straight output compatible with WxSU! There is a beta which works with Python.
Tomasz
or you can export your design to a xrc file (xml style) and load it with xml methods from the Wx module.
xml = Wx::XmlResource.get
xml.load(your_file.xrc)(google for "xrcise", this utility write for you the code needed to load your xrc)
-
@unknownuser said:
I would appreciate any help with solving this strange bugsplat which appears instead of a simple ruby error message in the console.
It happens after triggering an 'evt_button'.It looks like WxSU doesn't handle errors communication between WxRuby and Sketchup.
The best way to get rid of bugsplats is to handle exceptions by yourself, at the end of each method that uses WxSU:
That way, you display the call stack, letting you know where the bug is.rescue => detail puts detail.message puts detail.backtrace.join("\n")
-
@malkomitch said:
The best way to get rid of bugsplats is to handle exceptions by yourself, at the end of each method that uses WxSU:
That way, you display the call stack, letting you know where the bug is.Thanks a lot for your help.
I get a bugsplat when closing SU, but it is definitely better this way.
I though thatbegin ... rescue ... end
is required, but I am glad to hear that rescue alone is sufficient.Writing about xml loading I must say that I prefer to write my own Ruby code based on 'initial' FormBuilder layout, as it helps me better understand WxRuby. Thanks for hint anyway!
Tomasz
-
@unknownuser said:
I thought that
begin ... rescue ... end
is required, but I am glad to hear that rescue alone is sufficient.That is because in module definitions, the
module
statement is a block statement so the wordmodule
works the same asbegin
(after all, themodule
does need anend
.)module My_Module # method defs # code goes here rescue # error handling code else # only do code if no exceptions ensure # always do this code on exit end # the end of the method def
The same is true for
method
definitions, where thedef
keyword 'begins' the block.def my_method # code goes here rescue # error handling code else # only do code if no exceptions ensure # always do this code end # the end of the module
-
@dan rathbun said:
That is because in module definitions, the
module
statement is a block statement so the wordmodule
works the same asbegin
(after all, themodule
does need anend
.)Thanks for the explanation.
Advertisement