Skip to content

depilz/spinePlugin

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Solar2D Spine Plugin

A native Spine plugin for Solar2D, enabling seamless integration of Spine 4.2 animations into your Solar2D projects with enhanced performance and features.

🎉 Introduction

I’m excited to announce the Solar2D Spine Plugin! After a long time of having this within my goals, the plugin is now available in its early stages. This native plugin allows you to incorporate Spine 4.2 animations directly into your Solar2D applications, enhancing your project’s visual appeal and performance.

The plugin is still in development and not ready to use on production builds. However, I will keep working on this and in the following weeks, I expect the plugin to gain more stability and have all the basic functionalities working.

See the Roadmap section for more details on upcoming features and improvements.

🚀 To follow the discussion and updates, go to the Solar2D Forums.

📚 Usage

Using the Solar2D Spine Plugin is straightforward. Here’s a basic example to help you get started:

local spine = require("plugin.spine")

local jsonPath = system.pathForFile("art/raptor.json", system.ResourceDirectory)
local atlasPath = system.pathForFile("art/raptor.atlas", system.ResourceDirectory)

local atlas = spine.loadAtlas(atlasPath)
local skeletonData = spine.loadSkeleton(jsonPath, atlas, 0.2)
local skeleton = spine.create(skeletonData, listener)

skeleton:setAnimation(0, "walk", true)

parent:insert(skeleton)

📈 Roadmap

Here’s what’s coming next for the Plugin:

  • Properly Update Meshes: Resolve current crashes related to mesh updates.
  • Platform Support: Extend the plugin to support to :
    • Mac
    • Windows
    • iOS
    • Android
  • Make it available for free in Solar2D plugin Marketplace.
  • Interface to Animation Mix Times: Provide controls for blending transitions.
  • Event Listeners: Implement event listeners for animation events.
  • A More Robust Update Cycle: Enhance the update mechanism for better performance and reliability. (Worth using threads?)
  • Physics Controls: Integrate new physics features from Spine 4.2.
  • Correct Memory Management: Optimize memory usage to prevent leaks and crashes.
  • Include a sample project.
  • Draw the Meshes Using Solar’s Native API: Utilize Solar2D’s native drawing capabilities for improved performance.
  • Provide documentation.
  • Implement display object injections into spine.
  • Add scripts to facilitate building the plugin to the different platforms.

🤝 Contributing

I warmly welcome contributions from the community! Whether you’re an expert in native code and plugins or just getting started, your help can make a significant difference.

How to Contribute:

• Report Issues: If you encounter any bugs or have feature requests, please open an issue. • Submit Pull Requests: Feel free to fork the repository and submit pull requests with your improvements. • Collaborate: If you’re unsure where to start, reach out! I’m here to guide you through the code and the build process.

🦴 Using the plugin

This plugin utilizes the Spine Runtime to enable animation functionalities. The Spine Runtime is licensed under the Spine Runtime License, a copy of which is available in our repository. Spine technology by Esoteric Software. Please see Spine’s website for more details on licensing and usage.

A Spine license is required to use this Solar2D plugin.

📄 License

This project is licensed under the MIT License.

📫 Contact

Feel free to reach out for any questions, collaborations, or to share your Spine animations:

Stay tuned for more updates, and thank you for your support!