CocosCreator Skeleton Animation Dragon Bones

CocosCreator Skeleton Animation Dragon Bones

CocosCreator version 2.3.4

Dragon bone animation

Put the keel animation under Cocos assets. The dragon bone animation here is the binary animation exported by Dragonbones.

Drag the keel animation (bone icon) directly to the stage

Set the properties of skeletal animation, DragonAtlasAsset images, Animation actions, PlayTime loop playback, etc.

Code generated keel animation

The dragon bone resource path is assets/resources/dragonbones, and loadResDir only needs to fill in dragonbones.

//Load resources according to the path cc.loader.loadResDir("dragonbones",cc.Asset,null,(err, resource)=>{
      console.log("resource:",resource);
      //Generate skeletal animation let node:cc.Node = new cc.Node();
      let armatureDisplay:dragonBones.ArmatureDisplay = node.addComponent(dragonBones.ArmatureDisplay);
      armatureDisplay.dragonAsset = resource[0];
      armatureDisplay.dragonAtlasAsset = resource[3];
      armatureDisplay.armatureName = "role3";
      armatureDisplay.playAnimation("move",0);
      node.x = 100;
      node.y = 100;
      this.node.addChild(node);
});

Replace skin

//Load resourcescc.loader.loadResDir("dragonbones",cc.Asset,null,(err, resource)=>{
     console.log("resource:",resource);
 
    //Generate animation 1
    let node:cc.Node = new cc.Node();
    let armatureDisplay:dragonBones.ArmatureDisplay = node.addComponent(dragonBones.ArmatureDisplay);
    armatureDisplay.dragonAsset = resource[0];
    armatureDisplay.dragonAtlasAsset = resource[3];
    armatureDisplay.armatureName = "role3";
    armatureDisplay.playAnimation("move",0);
    node.x = 100;
    node.y = 100;
    this.node.addChild(node);
 
    //Generate animation 2
    let node2:cc.Node = new cc.Node();
    let armatureDisplay2:dragonBones.ArmatureDisplay = node2.addComponent(dragonBones.ArmatureDisplay);
    armatureDisplay2.dragonAsset = resource[4];
    armatureDisplay2.dragonAtlasAsset = resource[7];
    armatureDisplay2.armatureName = "role4";
    armatureDisplay2.playAnimation("move",0);
    node2.x = 150;
    node2.y = 150;
    this.node.addChild(node2);
     
 
    //Apply the skin of animation 2 to animation 1 let factory = dragonBones.CCFactory.getInstance();
    factory.replaceSkin(armatureDisplay.armature(), (armatureDisplay2.armature() as dragonBones.Armature).armatureData.defaultSkin, true);
});

The above is the detailed content of CocosCreator skeletal animation DragonBones. For more information about CocosCreator skeletal DragonBones, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Unity uses physics engine to simulate the flight of multi-rotor drones
  • Simple example of using Box2d, a 2D physics engine for Android
  • Interpretation of CocosCreator source code: engine startup and main loop
  • CocosCreator general framework design resource management
  • How to make a List in CocosCreator
  • Analysis of CocosCreator's new resource management system
  • Detailed explanation of making shooting games with CocosCreator
  • How to draw a cool radar chart in CocosCreator
  • Detailed explanation of CocosCreator MVC architecture
  • How to use physics engine joints in CocosCreator

<<:  Linux virtual memory settings tutorial and practice

>>:  MySQL prepare principle detailed explanation

Recommend

Detailed example of mysql similar to oracle rownum writing

Rownum is a unique way of writing in Oracle. In O...

Add ?v= version number after js or css to prevent browser caching

Copy code The code is as follows: <span style=...

Mysql SQL statement operation to add or modify primary key

Add table fields alter table table1 add transacto...

Summary of seven sorting algorithms implemented in JavaScript (recommended!)

Table of contents Preface Bubble Sort Basic Algor...

Several ways to center a box in Web development

1. Record several methods of centering the box: 1...

Mysql 5.7.18 Using MySQL proxies_priv to implement similar user group management

Use MySQL proxies_priv (simulated role) to implem...

Automatic failover of slave nodes in replication architecture in MySQL 8.0.23

I have been in contact with MGR for some time. Wi...

Nginx reverse proxy forwards port 80 requests to 8080

Let's first understand a wave of concepts, wh...

Detailed explanation of the correct way to open em in CSS

Why do we say “usually 1em=16px”? The default tex...

React encapsulates the global bullet box method

This article example shares the specific code of ...

Several ways to run Python programs in the Linux background

1. The first method is to use the unhup command d...

Script example for starting and stopping spring boot projects in Linux

There are three ways to start a springboot projec...

MySQL tutorial thoroughly understands stored procedures

Table of contents 1. Concepts related to stored p...

Graphical explanation of the solutions for front-end processing of small icons

Preface Before starting this article, let’s do a ...