Command in Tag Plugin [SOLVED]
-
On 10/10/2014 at 17:12, xxxxxxxx wrote:
I follow you on the GetDirty method, however, I'm not having much luck getting it to work..
I added the op.GetDirty(c4d.DIRTYFLAGS_DATA) to the Message function.
How to I make it only poll a slider and not the entire plugin?
If you could post a sample code of getting a sliders value change, that would be perfect. And thats for the LMB trick, that will come in handy in the future.
Thanks again,
Joe -
On 10/10/2014 at 17:29, xxxxxxxx wrote:
Even if that works, I don't think it will achieve what I'm after. I have it working in a script. Can I email you that and see if you can translate it to a tag plugin?
I don't know if it's possible in the way I need it to work.
Thanks
-
On 10/10/2014 at 17:36, xxxxxxxx wrote:
Originally posted by xxxxxxxx
How to I make it only poll a slider and not the entire plugin?
You can't. At least I don't know any way to do that.
Dirty can only test if "any" of the object's tag was changed in some manner. It can't tell which specific gizmo was changed.Grabbing the slider's value and comparing it to a class member variable to see if they are the same is the most common way to tell if a specific gimzo was changed.
-ScottA
-
On 10/10/2014 at 18:01, xxxxxxxx wrote:
import c4d
from c4d import plugins, gui, bitmapsclass ExampleDlg(gui.GeDialog) :
def CreateLayout(self) :
self.AddEditSlider(101, c4d.BFH_SCALEFIT, initw=50, inith=0)
self.AddEditSlider(102, c4d.BFH_SCALEFIT, initw=50, inith=0)
self.AddEditSlider(103, c4d.BFH_SCALEFIT, initw=50, inith=0)
self.AddSeparatorH(2, c4d.BFH_SCALEFIT)
self.AddEditSlider(104, c4d.BFH_SCALEFIT, initw=50, inith=0)
return Truedef InitValues(self) :
self.SetFloat(101, 1, min=0, max=1, step=.01, format=c4d.FORMAT_PERCENT)
self.SetFloat(102, 1, min=0, max=1, step=.01, format=c4d.FORMAT_PERCENT)
self.SetFloat(103, 1, min=0, max=1, step=.01, format=c4d.FORMAT_PERCENT)
self.SetFloat(104, 1, min=0, max=1, step=.01, format=c4d.FORMAT_PERCENT)
self.a = 1
self.b = 1
self.c = 1
return Truedef Command(self, id, msg) :
if id == 101:
self.a = self.GetFloat(101)if id == 102:
self.b = self.GetFloat(102)
if id == 103:
self.c = self.GetFloat(103)
if id == 104:
changea = 1 / self.a
changeb = 1 / self.b
changec = 1 / self.cself.SetFloat(101, self.GetFloat(104) / changea, min=0, max=1, step=.01, format=c4d.FORMAT_PERCENT)
self.SetFloat(102, self.GetFloat(104) / changeb, min=0, max=1, step=.01, format=c4d.FORMAT_PERCENT)
self.SetFloat(103, self.GetFloat(104) / changec, min=0, max=1, step=.01, format=c4d.FORMAT_PERCENT)
return Truedialog = ExampleDlg()
dialog.Open(c4d.DLG_TYPE_ASYNC)Mess around with this. It's basically what I need to do..
-
On 11/10/2014 at 03:42, xxxxxxxx wrote:
Hi,
in my Tag plugin I solved it like this:
def Init(self, node) : tag = node data = tag.GetDataInstance() data.SetReal(10007, 0.5) #the slider id and the initial value self.a = data.GetReal(10007) #you can set it to your initial value, too like self.a = 0.5 def Message(self, node, type, data) : tag = node instance = tag.GetDataInstance() if (type == c4d.MSG_DESCRIPTION_CHECKUPDATE) : if self.a != instance.GetReal(10007) : print "slider has changed" self.a = instance.GetReal(10007) print self.a
Or have a look to this post
https://developers.maxon.net/forum/topic/8169/10643_tagplugin-workflowcheers,
Martin -
On 13/10/2014 at 04:44, xxxxxxxx wrote:
Hi,
did it work for you?
Found out that the succestion from Niklas:
MSG_DESCRIPTION_POSTSETPARAMETER
is the fastest way to solve it.(it´s lighter no additional check for doc or draw like in checkupdate)
But it seems thatc4d.DescriptionPostSetValue() (this should give you the desc id of the changed parameter)
is not defined in Python and therefore you have to set a variable
and compare for changes like in the script I´ve posted before.Cheers,
Martin -
On 13/10/2014 at 14:11, xxxxxxxx wrote:
Hi. Unfortunately I realized that it is not possible what I want to do. Take that script i posted and run it in script manager. A master slider will change the values of "child" sliders. But that will still be recognized by the MSG_DESCRIPTION_POSTSETPARAMETER.
I don't think its possible. Thanks though.
-
On 14/10/2014 at 00:54, xxxxxxxx wrote:
Hi,
it is possible.
What you need is some more if clauses, to decide if the masterslider controll the values or an individual sliders does it, like:def Init(self, node) : tag = node data = tag.GetDataInstance() data.SetReal(10200, 1)#the masterslider data.SetReal(10201, 1)#slider_1 data.SetReal(10202, 1)#slider_2 data.SetReal(10203, 1)#slider_3 self.d = data.GetReal(10200) self.a = data.GetReal(10201) self.b = data.GetReal(10202) self.c = data.GetReal(10203) def Message(self, node, type, data) : tag = node instance = tag.GetDataInstance() if (type == c4d.MSG_DESCRIPTION_POSTSETPARAMETER) : if self.d != instance.GetReal(10200) : self.d = instance.GetReal(10200) changea = self.d*self.a instance.SetReal(10201, changea) changeb = self.d*self.b instance.SetReal(10202, changeb) changec = self.d*self.c instance.SetReal(10203, changec) else: if self.a != instance.GetReal(10201) : self.a = instance.GetReal(10201) if self.b != instance.GetReal(10202) : self.b = instance.GetReal(10202) if self.c != instance.GetReal(10203) : self.c = instance.GetReal(10203) print self.a, self.b, self.c, self.d, "final"
That´s what you want, I guess?
(By the way, in the the script you´ve posted keep an eye on avoiding divisions by zero.)Cheers,
Martin -
On 15/10/2014 at 13:05, xxxxxxxx wrote:
Okay. That worked! However, the console would display some errors saying that self.d didn't exist. So I put it in a try/except. Is that a safe way to fix it?
if (type == c4d.MSG_DESCRIPTION_POSTSETPARAMETER) : try: if self.d != instance.GetReal(1201) : self.d = instance.GetReal(1201) changea = self.d*self.a instance.SetReal(1012, changea) changeb = self.d*self.b instance.SetReal(1013, changeb) changec = self.d*self.c instance.SetReal(1015, changec) else: if self.a != instance.GetReal(1012) : self.a = instance.GetReal(1012) if self.b != instance.GetReal(1013) : self.b = instance.GetReal(1013) if self.c != instance.GetReal(1015) : self.c = instance.GetReal(1015) except: pass
Ignore the indents. Didn't copy correctly.
-
On 16/10/2014 at 00:09, xxxxxxxx wrote:
Hi,
I actually can´t see a reason why self.d didn´t exist, if the variables where initialized correctly.
Please post the whole thing or send me a private message.In my plugin it works like a charme.
Cheers,
Martin