It's not impossible to use - you only have access to the message data in a trigger; if you need it later, you can save it in a global variable.
It should work - it just compares the ControllerValue expression, which is set in a 'Control change' message, so it doesn't need the controller number to be passed.
The next LTS release (in ~6 months) will continue to support both NW.js and legacy SDK v1 addons, and that will be supported until the end of 2026, so you should aim to use that if you need extended support.
Steam has fallbacks that show the actual Steam UI instead of an in-game overlay, so Valve have an alternative implementation there that WebView2 uses. As NW.js is essentially unmaintained, may well be retired at some point, and integrating custom native code in NW.js for things like Steam integration is extremely difficult and requires constant maintenance (and has finnicky version matching requirements), I don't think it makes sense to continue to support NW.js just to get the in-game overlay instead of the fallback.
It's not like we've ignored the community over this - we have in fact gone to great lengths to try to support the in-game overlay, but various problems and limitations with Valve's implementation make it infeasible. So while it is unfortunate we can't support that, if you want it supported the best thing to do is contact Valve, as it seems only they can solve the problem.
There is a Steam plugin for WebView2: construct.net/en/make-games/addons/1105/steamworks
.capx files are for Construct 2 which was retired in 2021. For Construct 3, it's built in to the Example Browser, and you can open it here.
It does trigger for single instances - an instance without any children still counts as the root of a hierarchy, as it has no parent, and so 'On hierarchy ready' still triggers for it after 'On created'. It doesn't trigger for children, as then we have to decide what sequence to trigger in: top-to-bottom, bottom-to-top, or some other sequence, and whatever we choose, someone will need some other sequence. Therefore it only triggers for the root of the hierarchy, and you can then initialize children in whatever sequence is best for your project.
It looks like you emailed us on Friday December 6th, and we already sent a response on Monday December 9th.
You have to use an action to go to the next layout. Construct won't change the layout automatically.
Yeah, notarization only applies to the end app, not individual libraries.
If Construct adds an expression that is already used as an instance variable/behavior/effect name, you'll see an error when opening the project explaining the problem and indicating that you need to rename the item to be able to open it in the newer version.
That's normal - the console basically works in global scope, and it can't access variables declared in other functions (and script blocks in event sheets are actually inside functions), just like how you can't write code in one function that accesses a local variable inside a different function.
That's right, images added as project files are just copied to the export as-is and aren't processed any further.
Electron is very similar to NW.js and so shares many of the downsides noted in this blog.
NW.js provides both sync and async file system operations. Basically it was a mistake that when making the NW.js plugin we used sync file system operations. We should have chosen async.
I'm not sure what you're trying to achieve with the other details about the File System plugin. I imagined most games would do something like write a handful of files for save data and that would be it. If you have complex use cases involving listing lots of files and passing data along with file system operations, what is it you're trying to achieve? It might be better to move to the forum to discuss this.
Member since 21 May, 2007
The official blog for all things Construct and Scirra run by our employees!
Wider technology issues from Ashley's perspective.