Overboy's Recent Forum Activity

  • EDIT : I released a Construct Tool allowing to do this and much much more :

    JSON+ overboy.itch.io/construct-3-json-plus

    Tagged:

  • Yeah true it can be useful for some usecases, but I'm pretty sure some people requesting for Hierarchy opacity don't realize this wouldn't be what they expect and it wouldn't solve their current issues.

    As I said at the end of my previous post, I think the other use cases should be done with Layers and would be really easier to do with Instanciating + Reordering Layers at runtime.

  • Don't forget Hierarchy Opacity is more complex than it seems. It's not just about syncing stuff.

    I'm pretty sure we all want Construct to consider a whole Hierarchy as a "single image" when it comes to opacity.

    If I have 3 objects stacked on top of each other and part of the same Hierarchy. If the Hierarchy is set to 20% opacity, I don't want to see each of those Objects through each other (like if each Object had a 20% opacity individually).

    We probably want the whole hierarchy to be at 20% opacity, not individual parts.

    Also what if one of the child had 50% opacity and then its parent changes its own opacity from 100% to 10% opacity ?

    However if one day Construct had this possibility to render a Hierarchy as a single merged stuff, it would be nice.

    Maybe it would also allow us to have effects applying to the whole Hierarchy as if it was a "single image/object".

    But then it raises other issue regarding ZOrdering with other Objects that are not part of the Hierarchy. => most probably this "render as single image Hierarchy" option should be an option we don't want in other cases. And the ZOrder/Layer of the whole Hierarchy would be the ZOrder/Layer of the parent. (Child original ZOrder/Layer wouldn't be useful anymore, except for defining the ZOrder for each Objects that is part of the Hierarchy and maybe the position if Layers have different Parallax/Zoom scale)

    => it looks a bit like a rabbit hole

    A probably easier way to achieve all those things would be to add the possibility to instanciate and reorder Layer at runtimes

  • Amazing, this will be game-changer

  • This is a great idea Ashley !

    Do the "split string" and "join string" actions have a field to define what is the separator ?

    As the token expressions works : you can choose "/" or ";" or anything you want as a separator.

    It would be really useful as it would allow "," to be part of each "tokens" without being treated as a separator for example.

    (That separator field could still be set to "," by default or even ", ")

  • Hi,

    Yesterday Ashley and I discussed about a possible enhancement to the Properties View.

    EDIT : updated link to new suggestion platform : github.com/Scirra/Construct-feature-requests/issues/10

    Be able to Add/Edit/Find all references (and more) for Variables, Behaviors and Effects directly from Property View thanks to new Right-Click context menus and actions.

    So I created a mockup for it :

    That would mean no need to open all those dedicated pop-up menus anymore for Object specific Variables/Behaviors/Effects (V/B/E) or even worse, the V/B/E of a related Family that we need to find in the Project View first and only then open the pop-up, to only then do what we want. This would be a great QOL and consistent with other "Find All References" feature we have everywhere in the engine and would save us a lot of time for a bunch of extremely common stuff

    I created a mockup to show what should be the context menu for each element/area of the V/B/E part of the properties view (I adapted them to make sure it makes sense in that specific context) and also to show that it is compatible with the fact the right-click is used to reset a value of a Replica to its Template Source Value :

    Bonus QOL : When we select an instance variable Row in Properties View, pressing F2 could directly open the related "Edit instance Variable pop-up" as shown in the mockup

    Additional Thoughts not mentionned in the Mockup :

    - I think it would be nice to add an "Inherited from FamilyX" row in the Instance Variables part of the Properties even if this Family doesn't have any Instance Variables yet. (right now only Families with variables have their row)

    This way we could quickly know all the Families this Object is part but also thanks to the new context menus, we could quickly open its related pop-up from there but also quickly remove the object from this family thanks to the new "Remove From Family" context menu action.

    - Maybe it would be more understandable and also more consistent if Behaviors and Effects were also under an "Inherited from FamilyX" row as the Instance Variables, to avoid confusion. (even if context menu aren't added btw)

  • It doesn't work well, for Photoshop it's really slow and sometimes doesn't even work to open multiple files as layer and even if it worked it means you need to manually create your automated action each time which is pretty slow too. Also you still need to be able to export all those layer in individual frames and it's not ideal either.

    I tried many many things and worklows, the best I found is that I created custom .bat scripts to automate the creation of Spritesheets from individual png directly from my Windows Explorer but even this method is not ideal and require extra steps each time.

  • Copy/Pasting animations and frames in the Editor and all the recent import improvements regarding the Animation Editor is 100% amazing, thank you so much for all those things !!

    I have a feature request not exactly related to Import but concerning Export.

    Export Current Animation or All Animations of the current Object as Spritesheets

    Right now we only can save Images as invidual frames,

    It would be totally awesome to be able to export each animation as an individual spritesheet.

    By Default each animation would be named AnimationName_Fx1 (where F is the number of frames in the animation) and all frames would be aligned horizontally in a single-row spritesheet.

    Why do we need export to spritesheets ?

    - Because it would be very easy to color swap or add glow/outlines or effects to all frames of a character thanks to external software such as Photoshop.

    (then we just have to drag and drop again each spritesheet in the corresponding animation in the Animation Editor, unless bulk import for Spritesheets is also implementing as in my previous suggestion).

    - Right now it's very difficult to do such things as we have to do it manually for every single frame which is quite impossible to do.

    - Also as always, spritesheets are better for file management, the whole animation is at just 1 location in our hard drive, it's easier to rename it, open the file in an external software in 1 click etc...

    Optional Enhancement to Export as Spritesheets

    1. Max Column Number option : When the current or all animations are exported as Spritesheet, it could first open a pop-up with a field asking the maximum number of columns the spritesheet should have.

    - By default, there is no maximum of columns. Which means if I have a character with a 8 frames Walk Animation and a 12 frames Idle, it would export the spritesheet as Walk_8x1 and Idle_12x1.

    - If i specify an other number of columns, let's say 3, it would export the spritesheets as Walk_3x3 (so it means the cell at X=3 and Y=3 would ne empty as there is only 8 frame in this animation) and Idle_4x3.

    2. No Empty Column Boolean : If I specified 9 for example, the spritesheet Walk would be Walk_9x1 with the last frame empty. But there could be a "No Empty columns" boolean that would make this spritesheet exported as Walk_8x1 even if I specified as column number >= 9

    3. Export Spritesheet with Data : In a second time, if bulk spritesheet import is implemented, there could also be a way to export Spritesheets with Points/Polygon Data so it can be imported later easily too.

    EDIT : I forgot one important thing, as frames for an animation can have different pivot point and sizes, 1 cell of the spritesheet need to be able to have enough place so even if all frames are on top of each other in a single cell, nothing exceed the cell, and all their previous pivot point should be at the exact same position in the spritesheet.

    Here is a visual example :

    I agree this is an interesting request but because of the limited dev ressources of Scirra, It would be frustrating if stuff that we can do by ourself pretty easily were pushed in priority.

    This has to do with the big focus Construct Animate is getting recently that makes dev ressources allocated to Gamedev Construct even more scarce. But also the fact that recently a few updates added features for which i can't find a single use case. For example, the "Compare Child Count" condition, or the "Copy Picked" Function feature (well this second one can have limited use cases but not the first). I opened my biggest and most complex project and i didn't find a single valid use case for those 2 features, both are very limitating and error-prone.

    It wouldn't be an issue if it had no slowdown impact on stuff that we're waiting for years and would be real game-changers.

    In case anyone is wondering how to implement those platformer mechanics with existing features :

    For coyote Time, I usually like to add a Timer Behavior to my Platformer Object. If it's not grounded anymore and it didn't "JustJump" (boolean set to true at the beginning of my Jump Function), I start a 0.3 second "Coyote" Timer.

    If I press my jump button and either the Platformer is grounded or either the "Coyote" timer is running, I call my own Jump Function using vector Y. That function is also used for my Double Jump (or not, again depending on the game i'm working on).

    I also implement my own Jump Sustain to really have full control on how it behaves as it can differ a lot from one game to an other. Sometimes i use a trick to "lower the gravity force" (by adding an opposite force for example) for the first 0.4 seconds the player sustain the jump button for example.

    To be honest, I don't feel Platformer behavior is limitated. I already created all kind of complex Platformer Controllers only thanks to Event Sheets, the existing features of the Platform behavior and the other behaviors. (emulated almost all controller features of games likes Celeste and Dead Cells without issue)

    Coyote Time could be handy to add by default for very beginners but it's very easy to implement by ourself ! It's not painful to do in any way contrary to many other things

    Regarding the jump sustain I prefer to implement my own anyway to really control the feel of the character.

    There are many things that could be improved in existing Construct features such as :

    - fixing the slide along solids issues with all other Movement Behaviors (Bullet for example)

    - a lot of missing ACE and expressions for existing things

    - Better event search/Project search workflow

    - Better Instance variables workflow

    - Better Hierarchy workflow

    - A way to get access to Object Template Name Lists thanks to expression

    I'm not talking about missing features here, only the existing ones. But if we also take missing features into consideration I feel like there is a ton of things that are very difficult or even impossible to do thanks to eventsheets that should be higher priority than that kind of things.

  • Nice tricks, I already use some of them but it's not ideal for different reasons.

    I think an effective Event Search would lessen the need of better Bookmarks as it would allow us to jump from any part of our project to any other part of our project very quickly and easily, without any manual setup to do.

    I added a 3rd part to my suggestion on the platform to also solve all issues related to Project View Search on top of the issues related to Event Search.

    construct3-21h2.ideas.aha.io/ideas/C321H2-I-425

    It might look complicated at first because it describes both technical implementation and expected behavior explicitely, but in fact what i does is pretty simple and it's really user friendly :

    - it would allow us to unfold Folders and Families that we search thanks to the Project View Search Field (which doesn't work right now)

    - it would implement the same "Fuzzy Search-like" algorithm as I described above

    - it would allow us to use Default Folders ("Layouts"/"Event Sheets"/"Families" etc..) and Custom Folders as effective filters for Project View search

  • Try Construct 3

    Develop games in your browser. Powerful, performant & highly capable.

    Try Now Construct 3 users don't see these ads
  • Edit: I wrote a dedicated suggestion for it, vote here :

    C3 Events Search improvements construct3-21h2.ideas.aha.io/ideas/C321H2-I-425

    - the filter algorithm would allow us to type half words in any order and still find the matching events. (kinda like some Fuzzy Search algorithm)

    - the results autoupdates as soon as the string changes

    - both the Find field and the results pop-ups merge in a single window

    I think it would avoid me to waste at least 45 minutes per day of Construct use and probably around 2h per days if you include the side-effects of those permanent flow-breakers.

    +1 To be honest this must be the most annoying thing in my daily use of Construct for many years,

    Because of the current limitation (it looks for event matching the exact requested string in the right order), you can only write 1 word at a time to find the event you're looking for, otherwise most of the time you end up with 0 results.

    So if i need to find an event related to my Player's Angle, i either need to type "Player" (and i get hundreds of results as Player is used in a huge amount of actions and conditions) or "angle" (and i also get hundreds of results related to all kind of Object Types in my project) => Because of this, it returns thousands of results or irrelevant things each time

    The expected result would be that i find all events related to Player's angle (or even related to instance variables names of Player that includes "angle" in their name) if I type either "Player angle" or "angle player".

    Both should work and show me results such as :

    - "Player:Set Angle_Aim to 90".

    Right now if I type "Player Angle" it doesn't work

    This enhancement would also be useful for all the other "find" fields in construct as it's the expected behavior in all cases we need to find stuff.

    Also nowadays most software have even better find algorithm such as fuzzy search, so maybe an even better algorithm could be implemented.

    In fact among the whole list of QOL stuff I wish Construct Team would add to the engine, I think this is the top priority right now.

    Other possible enhancements :

    Also the results of the "Find Results" pop-up should autoupdate when the user change the field "Find" in the "Find" pop-up. Right now we need to press the Find Button each time

    Also, I wonder if it wouldn't be better if those "Find" and "Find Results" pop-ups would be merged into a single one.

Overboy's avatar

Overboy

Member since 21 Oct, 2013

Twitter
Overboy has 8 followers

Connect with Overboy

Trophy Case

  • 11-Year Club
  • Entrepreneur Sold something in the asset store
  • Jupiter Mission Supports Gordon's mission to Jupiter
  • Forum Contributor Made 100 posts in the forums
  • Regular Visitor Visited Construct.net 7 days in a row
  • Steady Visitor Visited Construct.net 30 days in a row
  • Enduring Visitor Visited Construct.net 90 days in a row
  • RTFM Read the fabulous manual
  • x18
    Quick Draw First 5 people to up-vote a new Construct 3 release
  • x15
    Lightning Draw First person to up-vote a new Construct 3 release
  • x25
    Great Comment One of your comments gets 3 upvotes
  • Delicious Comment One of your comments gets 10 upvotes
  • Email Verified

Progress

23/44
How to earn trophies