physics.dart 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. ///
  2. /// Spine Runtimes License Agreement
  3. /// Last updated July 28, 2023. Replaces all prior versions.
  4. ///
  5. /// Copyright (c) 2013-2023, Esoteric Software LLC
  6. ///
  7. /// Integration of the Spine Runtimes into software or otherwise creating
  8. /// derivative works of the Spine Runtimes is permitted under the terms and
  9. /// conditions of Section 2 of the Spine Editor License Agreement:
  10. /// http://esotericsoftware.com/spine-editor-license
  11. ///
  12. /// Otherwise, it is permitted to integrate the Spine Runtimes into software or
  13. /// otherwise create derivative works of the Spine Runtimes (collectively,
  14. /// "Products"), provided that each user of the Products must obtain their own
  15. /// Spine Editor license and redistribution of the Products in any form must
  16. /// include this license and copyright notice.
  17. ///
  18. /// THE SPINE RUNTIMES ARE PROVIDED BY ESOTERIC SOFTWARE LLC "AS IS" AND ANY
  19. /// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  20. /// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  21. /// DISCLAIMED. IN NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY
  22. /// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  23. /// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES,
  24. /// BUSINESS INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND
  25. /// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  26. /// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THE
  27. /// SPINE RUNTIMES, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  28. ///
  29. import 'package:spine_flutter/spine_flutter.dart';
  30. import 'package:flutter/material.dart';
  31. class PhysicsTest extends StatefulWidget {
  32. const PhysicsTest({Key? key}) : super(key: key);
  33. @override
  34. PhysicsState createState() => PhysicsState();
  35. }
  36. class PhysicsState extends State<PhysicsTest> {
  37. late SpineWidgetController controller;
  38. Offset? mousePosition;
  39. Offset? lastMousePosition;
  40. Offset? delta;
  41. @override
  42. void initState() {
  43. super.initState();
  44. controller = SpineWidgetController(onInitialized: (controller) {
  45. controller.animationState.setAnimationByName(0, "eyeblink-long", true);
  46. controller.animationState.setAnimationByName(1, "wings-and-feet", true);
  47. }, onAfterUpdateWorldTransforms: (controller) {
  48. if (lastMousePosition == null) {
  49. lastMousePosition = mousePosition;
  50. return;
  51. }
  52. if (mousePosition == null) {
  53. return;
  54. }
  55. final dx = mousePosition!.dx - lastMousePosition!.dx;
  56. final dy = mousePosition!.dy - lastMousePosition!.dy;
  57. final position = controller.skeleton.getPosition();
  58. position.x += dx;
  59. position.y += dy;
  60. controller.skeleton.setPosition(position.x, position.y);
  61. lastMousePosition = mousePosition;
  62. });
  63. }
  64. void _updateBonePosition(Offset position) {
  65. mousePosition = controller.toSkeletonCoordinates(position);
  66. }
  67. @override
  68. Widget build(BuildContext context) {
  69. reportLeaks();
  70. return Scaffold(
  71. appBar: AppBar(title: const Text('Physics (drag anywhere)')),
  72. body: GestureDetector(
  73. onPanDown: (drag) => _updateBonePosition(drag.localPosition),
  74. onPanUpdate: (drag) => _updateBonePosition(drag.localPosition),
  75. child: SpineWidget.fromAsset("assets/celestial-circus.atlas", "assets/celestial-circus-pro.skel", controller),
  76. ));
  77. }
  78. }