• Change a rendering parameter in python xpresso node

    12
    0 Votes
    12 Posts
    2k Views
    Passion3DP
    @Cairyn Thanks, all work fine for this module
  • Copying Layers along with Objects

    c++ r20 sdk
    6
    0 Votes
    6 Posts
    746 Views
    D
    @Cairyn Thanks again! That's what I was afraid of, but thanks for the information!
  • 1 Votes
    8 Posts
    1k Views
    r_giganteR
    Thanks @moGRR for reaching out us. With regard to your question, as pointed out by @zipit, it's not possible to have a Python Generator to generate object which can be recognized as real spline by generators/deformers expecting a spline as input due to the Python Generator flags used in its registration. Beside the option mentioned by @zipit I also invite to have a look at this post where it's presented a generator outputting spline and accepting splines as input. Best, R
  • Cinema 4D R20 plugin's conflict with Redshift

    r20 c++
    3
    1 Votes
    3 Posts
    682 Views
    Danchyg1337D
    @m_magalhaes No other dependencies. Plugin type is deformer. Yes, i should probably ask it on Redshift forum. Thanks for reply!
  • CommandData trigger from GeDialog

    c++ r19 r20 r21
    6
    0 Votes
    6 Posts
    643 Views
    C4DSC
    Nevermind. Trying to explain will probably lead us too far. I was only wondering if messaging was possible between a CommandData and its GeDialog.
  • XPresso: enable/disable user data

    Moved
    5
    0 Votes
    5 Posts
    2k Views
    Passion3DP
    Work fine Thanks a lot Manuel
  • Is it still not possible to create Xrefs from Python?

    2
    0 Votes
    2 Posts
    517 Views
    M
    Hi @tdapper, unfortunately, I confirm this is still not possible. Cheers, Maxime.
  • Tracer and User Date

    4
    0 Votes
    4 Posts
    610 Views
    SwinnS
    I figured out the problem. I needed to assign the UD in Main.
  • Inconsistent GeDialog::Open position

    r20 c++ r21
    5
    0 Votes
    5 Posts
    664 Views
    C4DSC
    Extra info! While I had set this topic as solved, without an actual WORKING solution being provided, I simply wanted to point out for future reference that R16 - R19 has a slight different behaviour. As with R20 and R21 the first time the dialog is opened it gets positioned centered on the current mouse position. On all subsequent opening it gets positioned with its upper left corner at 0,0. Something got "fixed" between R19 and R20, but not "fixed enough".
  • Python Tag not updating (The Sequel)

    7
    0 Votes
    7 Posts
    951 Views
    SwinnS
    Ah! Okay. Thanks.
  • ShaderEffector: IsDirty(DIRTYFLAGS::DATA) always true?

    c++ python r21 maxon api
    5
    0 Votes
    5 Posts
    560 Views
    M
    Hi @fwilleke80, unfortunately, I confirm the shader effect is almost always dirty. I don't have any real workaround maybe you can retrieve all noises and compute their dirtiness, but this is indeed a very hard topic to handle all cases because you will also need to handle the actual parameter of the shader effector itself. Cheers, Maxime.
  • Which lock to use?

    r21 r20 s22 c++ macos windows
    3
    0 Votes
    3 Posts
    358 Views
    fwilleke80F
    Always using the threadIndex, of course Thanks, I'll try that!
  • Another mouse position and GeDialog topic

    1
    1
    0 Votes
    1 Posts
    238 Views
    No one has replied
  • Remove Stray ShowPopUpDialog?

    r21 python
    8
    0 Votes
    8 Posts
    834 Views
    B
    @m_adam Thanks for the response (and the reference link) Works as expected.
  • Python Tag not updating

    Moved python
    9
    0 Votes
    9 Posts
    1k Views
    M
    make sure to pass a str value aka str(yourMessage) if this doesn't solve the issue open a new topic Cheers, Maxime
  • Unexpected ShowPopUpDialog Behavior

    r21 python
    3
    0 Votes
    3 Posts
    307 Views
    B
    @zipit Thanks for the response. You are right. It should have worked if there is padding between buttons. For now, I just chose either buttonData["w"] or buttonData["h"]. And it works as expected. RE: hard to read your code due to the lack of documentation and its disregard of PEP8 Sorry about that.
  • Creating and saving a 32bit grayscale bitmap

    c++ macos r21 maxon api classic api
    4
    0 Votes
    4 Posts
    766 Views
    fwilleke80F
    Ah, great, thank for checking! Then I don't need to worry about my bmp code Cheers, Frank
  • Identify Critical Stop Please?

    python r21
    6
    0 Votes
    6 Posts
    1k Views
    K
    @m_magalhaes said in Identify Critical Stop Please?: hello, For your next threads, please help us keeping things organised and clean. I know it's not your priority but it really simplify our work here. Q&A New Functionality. About the error it's related to FileName. But we need more information to help more. Be careful about the other thread, it may happen that we add stuff and the line will not refer to the correct DataType anymore. Cheers, Manuel Dammit! No wonder my code keeps breaking... I can't even follow simple forum instructions lol! But hey, at least I got it down to one link. Haha, progress! Yes, Filename, that actually makes perfect sense, so I'm pretty confident I've conquered this error. You're right that I shouldn't rely too strongly on those line numbers. Hell, the next bug fix could make that info obsolete, let alone a reference from years ago. But sometimes you can glean value from outdated info. Maybe in the future line 277 doesn't refer to Filename, but if that error pops up and all my Filename calls look to be in good order I might be able to make some guesses that increase my luck in identifying the issue faster. For instance, I might look at string or static text parameters first, thinking that like datatypes may have been grouped together in the source code. If 329 doesn't refer to baselink in the future I might start looking at in/exclude boxes or shader links first for the same reason. Maybe the list of datatypes in the description manual in the sdk is ordered how they are in ge_container.h and I can use that to choose my next lead. Shot in the dark type stuff, for sure, but maybe gets me generally in the right direction. You know what, this may have to do with me tracking down a weird behavior where Init() seemed to be the cause of every parameter invoking a MSG_DESCRIPTION_POSTSETPARAMETER message on any parameter change... but I have both debugging AND pandemic fog on my brain, so I don't even know exactly which thing I was doing wrong that may have been the culprit, so there's no point getting into all that... doesn't help that a VS Code update seems to like breaking my local git repo's randomly, so that makes reviewing previous code fun. In any case, the error hasn't popped up at all after ensuring all my base container calls were proper and there were no missing parameter initializations. Not that it was a readily reproduce-able error, just one that would pop up sometimes after a heavy testing session... so I had to do a lot of those to ensure it's really gone. But it does raise a question. Since the Filename object doesn't exist in python, what's the best way to initialize it? Docs say it's a string, but I saw something in a forum post that someone was initializing their filename parameter directly through the base container. I figured this had to do with how the python wrapper is internally converting the path to Filename object or something, so that's what I've been doing, but that WAS from 2013. So which is the proper way to initialize it? self.InitAttr(node, str, c4d.ID_FILENAME_PARAMETER) or data.SetFilename(c4d.ID_FILENAME_PARAMETER, "") And even if it's the former, do I set its default value through the basecontainer or in the normal way like so: node[c4d.ID_FILENAME_PARAMETER] = "" @r_gigante said in Identify Critical Stop Please?: Hi @kvb, with regard to the scope and purpose of the CriticalStop I warmly recommend you to have a look at: FAQ CriticalStop() Debug and Output Functions These pages properly explain how the CriticalStop is used in Cinema 4D, how it can be used in plugins and what to expect when it's hit. In you case, as already pointed out by @m_magalhaes , it's likely you're using a GeData::GetFilename() with a GeData whose type was not a Filename. Please recheck your code and if you don't spot the issue, provide us with an example or snippet to reproduce it. Cheers, R Thanks for the links. They'll come in handy on my next project, which will be in c++ (and I will be abusing the hell out of all the debugging options!). Could it have been caused by the filename returning None? Is that even a thing or just something I noticed while I was missing any initialization on my Filename parameter? I can't see it being anything else... unless an empty string could trigger that error? Thanks all! Kevin
  • 0 Votes
    3 Posts
    419 Views
    C4DSC
    @m_magalhaes said in GeUserArea - RemoveLastCursorInfo not compatible with ActivateFading: ActivateFading is also using RemoveLastCursorInfo internally. I more or less assumed this was the case. As such I went with an alternative solution using RemoveLastCursorInfo to be able to detect the mouse leaving the GeUserArea, while providing an own implementation for fading in and out. Thanks for confirming.
  • TagData plugin to "return" Vertex map?

    9
    0 Votes
    9 Posts
    2k Views
    intenditoreI
    Yeah, sure)