-
Notifications
You must be signed in to change notification settings - Fork 33
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for animated tiles #6
Comments
I got an idea : You make a Tile class and each Tile will have a std::map<std::string /Property/, std::string /Value/> mProperties With that the user can set property for animated tile or any property he wants The Tile are stored on a Layer (I think you can also make a class Layer) maybe on a std::vector <std::vector > A Tile can modify the texture of itself directly by modify the VertexArray of the Layer Then the user can do that : For (layer.getTile ()) And then he can modify the texture each x second like that : Void update(time) My code is an example in pseudo code but I think you understand what I mean :) (I'm on my phone and I'm French so the corrector automatic isnt cool at all for speaking English and write code...) |
Little bug for the container of Tile in Layer : Std::vector < std::vector < Tile > > |
OK I think I get what you mean. There are already Tile and Layer structs so modifying them wouldn't be a stretch. What I really need to think about is how Tiled itself should mark a tile as being animated. When you design a map it has no direct support for animated tile maps. Perhaps it would be as simple as adding a pointer to an sf::Drawable to the tile struct and providing public access so users can attach any drawable they like (including animated sprite) which the map loader will draw when the pointer != nullPtr |
In the Tiled editor you can add properties to Tiles I will see in the anothers tiled loader how they handle animated tiles |
Okay I've just seen the TinyXML Loader : http://code.google.com/p/tmx-parser/ It use a system like I told you with property :) |
Right, in which case there's probably not much to do. Object properties are already parsed and publicly available, so if a user wants to look for an animated property in an object and handle it in whichever way they see fit, they can. |
Actually animated tiles were first implemented in Tiled around the time this issue was posted. These are stored in xml like this: <tile id="31">
<animation>
<frame tileid="31" duration="100"/>
<frame tileid="34" duration="100"/>
</animation>
</tile> |
always happy to accept pull requests on the Next branch! ;) |
Any news on this? I've been able to grab the animation data like @Kojirion showed and load it into TileInfo but that's as far as I've gotten while I pick apart your code. The first problem I'm going to have is that I don't know how to easily convert the local tile ID given in the tag to the global ID that would presumably be needed for rendering the appropriate frame. The second problem I'm going to have is that I'm not quite sure how the rendering itself works in your code at this time. It looks like you are rendering layer sets which use MapTile but it seems that MapTile is only used in Image layers which I'm not using. |
I know it's probably not what you want to hear, but I've pretty much abandoned this in favour of tmxlite - although I see you've already forked it ;) You'll be able to get all of your animation data out of it, but will have to set up the rendering yourself. |
It would be nice to eventually add support for animated tiles. This isn't a feature in Tiled so would need some serious consideration as to how animated tiles would be designated in the editor. Overall this feature is low priority but I would love input from anyone who has ideas about how this could be done.
The text was updated successfully, but these errors were encountered: