SpriteAtlasAnim.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. (function() {
  2. var nodeEnv = typeof require !== 'undefined' && typeof process !== 'undefined';
  3. var __module = nodeEnv ? module : {exports:{}};
  4. var __filename = 'preview-scripts/assets/script/frameWork/compment/SpriteAtlasAnim.js';
  5. var __require = nodeEnv ? function (request) {
  6. return cc.require(request);
  7. } : function (request) {
  8. return __quick_compile_project__.require(request, __filename);
  9. };
  10. function __define (exports, require, module) {
  11. if (!nodeEnv) {__quick_compile_project__.registerModule(__filename, module);}"use strict";
  12. cc._RF.push(module, 'edf5956GoRKsaa/AvErwY37', 'SpriteAtlasAnim');
  13. // script/frameWork/compment/SpriteAtlasAnim.ts
  14. "use strict";
  15. var __extends = (this && this.__extends) || (function () {
  16. var extendStatics = function (d, b) {
  17. extendStatics = Object.setPrototypeOf ||
  18. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  19. function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
  20. return extendStatics(d, b);
  21. };
  22. return function (d, b) {
  23. extendStatics(d, b);
  24. function __() { this.constructor = d; }
  25. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  26. };
  27. })();
  28. var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
  29. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  30. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  31. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32. return c > 3 && r && Object.defineProperty(target, key, r), r;
  33. };
  34. Object.defineProperty(exports, "__esModule", { value: true });
  35. exports.SpriteAtlasAnim = void 0;
  36. var ResSpriteAtlas_1 = require("./ResSpriteAtlas");
  37. var UEBase_1 = require("./UEBase");
  38. var _a = cc._decorator, ccclass = _a.ccclass, property = _a.property;
  39. var SpriteAtlasAnim = /** @class */ (function (_super) {
  40. __extends(SpriteAtlasAnim, _super);
  41. function SpriteAtlasAnim() {
  42. return _super !== null && _super.apply(this, arguments) || this;
  43. }
  44. /**
  45. * @param url 动画 SpriteAtlas Url
  46. * @param animCfg 动画配置
  47. */
  48. SpriteAtlasAnim.prototype.LoadAnimAsync = function (bundleKey, url, animCfg, defaultAnim) {
  49. var _this = this;
  50. var that = this;
  51. that._animCfg = animCfg;
  52. that._anim = that.node.getComponent(cc.Animation);
  53. if (!this._anim) {
  54. this.node.addComponent(cc.Animation);
  55. }
  56. that._resSpriteAtlas = that.node.getComponent(ResSpriteAtlas_1.default);
  57. if (!that._resSpriteAtlas) {
  58. that.node.addComponent(ResSpriteAtlas_1.default);
  59. }
  60. return new Promise(function (resolve) {
  61. that._resSpriteAtlas.LoadSpriteAtlas(bundleKey, url, function (atlas) {
  62. if (atlas) {
  63. that.RemoveAllClips();
  64. var sp_1;
  65. var _loop_1 = function (clipName) {
  66. var animSpriteFrames = [];
  67. that._animCfg[clipName].frames.forEach(function (frameKey) {
  68. sp_1 = atlas.getSpriteFrame(frameKey);
  69. if (sp_1) {
  70. animSpriteFrames.push(sp_1);
  71. }
  72. else {
  73. console.error("\u56FE\u96C6(" + url + ")\u4E2D\u4E0D\u5B58\u5728\u52A8\u753B\u5E27: " + frameKey);
  74. }
  75. });
  76. that.AddClip(clipName, animSpriteFrames, that._animCfg[clipName].wrapMode, that._animCfg[clipName].sample);
  77. };
  78. for (var clipName in that._animCfg) {
  79. _loop_1(clipName);
  80. }
  81. if (defaultAnim)
  82. _this.PlayAnim(defaultAnim);
  83. resolve(true);
  84. }
  85. else {
  86. resolve(false);
  87. }
  88. });
  89. });
  90. };
  91. /**
  92. *
  93. * @param clipName
  94. * @param animSpriteFrames
  95. * @param sample 动画帧率,单位为帧/秒
  96. * @param wrapMode
  97. */
  98. SpriteAtlasAnim.prototype.AddClip = function (clipName, animSpriteFrames, wrapMode, sample) {
  99. // 创建一个动画
  100. var clip = cc.AnimationClip.createWithSpriteFrames(animSpriteFrames, sample);
  101. clip.name = clipName;
  102. clip.wrapMode = wrapMode;
  103. this._anim.addClip(clip);
  104. };
  105. SpriteAtlasAnim.prototype.RemoveAllClips = function () {
  106. if (!this._anim || !this._anim.isValid)
  107. return;
  108. var clips = this._anim.getClips();
  109. for (var i = clips.length - 1; i >= 0; --i) {
  110. this._anim.removeClip(clips[i]);
  111. }
  112. };
  113. /**
  114. * 播放动画
  115. * @param clipName
  116. */
  117. SpriteAtlasAnim.prototype.PlayAnim = function (clipName) {
  118. this._anim.play(clipName);
  119. };
  120. SpriteAtlasAnim.prototype.StopAllAnim = function () {
  121. this._anim.stop();
  122. };
  123. /**
  124. * 监听动画完成
  125. * @param complete
  126. */
  127. SpriteAtlasAnim.prototype.OnAnimComplete = function (complete) {
  128. this._anim.on(cc.Animation.EventType.FINISHED, function (type, state) {
  129. complete && complete(type);
  130. }, this);
  131. };
  132. SpriteAtlasAnim = __decorate([
  133. ccclass
  134. ], SpriteAtlasAnim);
  135. return SpriteAtlasAnim;
  136. }(UEBase_1.default));
  137. exports.SpriteAtlasAnim = SpriteAtlasAnim;
  138. cc._RF.pop();
  139. }
  140. if (nodeEnv) {
  141. __define(__module.exports, __require, __module);
  142. }
  143. else {
  144. __quick_compile_project__.registerModuleFunc(__filename, function () {
  145. __define(__module.exports, __require, __module);
  146. });
  147. }
  148. })();
  149. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["assets/script/frameWork/compment/SpriteAtlasAnim.ts"],"names":[],"mappings":"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","file":"","sourceRoot":"/","sourcesContent":["import ResSpriteAtlas from \"./ResSpriteAtlas\";\nimport UEBase from \"./UEBase\";\n\nconst { ccclass, property } = cc._decorator;\n\nexport interface IAnimationInfo {\n    bundle: string,\n    atlasUrl: string,\n    anim: {\n        run: { name: string, frames: string[], wrapMode: cc.WrapMode, sample: number }\n    }\n}\nexport interface Params_SpriteAtlasAnim {\n    [anim: string]: {\n        frames: string[],\n        wrapMode: cc.WrapMode,\n        sample: number, // 动画帧率，单位为帧/秒\n    }\n}\n\n@ccclass\nexport class SpriteAtlasAnim extends UEBase {\n    private _anim: cc.Animation;\n    private _resSpriteAtlas: ResSpriteAtlas;\n    private _animCfg: Params_SpriteAtlasAnim;\n\n    /**\n     * @param url 动画 SpriteAtlas Url\n     * @param animCfg 动画配置\n     */\n    protected LoadAnimAsync(bundleKey: string, url: string, animCfg: Params_SpriteAtlasAnim, defaultAnim: string): Promise<boolean> {\n        const that = this;\n        that._animCfg = animCfg;\n        that._anim = that.node.getComponent(cc.Animation);\n        if (!this._anim) {\n            this.node.addComponent(cc.Animation);\n        }\n        that._resSpriteAtlas = that.node.getComponent(ResSpriteAtlas);\n        if (!that._resSpriteAtlas) {\n            that.node.addComponent(ResSpriteAtlas);\n        }\n        return new Promise((resolve) => {\n            that._resSpriteAtlas.LoadSpriteAtlas(bundleKey, url, (atlas: cc.SpriteAtlas) => {\n                if (atlas) {\n                    that.RemoveAllClips();\n                    let sp: cc.SpriteFrame;\n                    for (let clipName in that._animCfg) {\n                        let animSpriteFrames: cc.SpriteFrame[] = [];\n                        that._animCfg[clipName].frames.forEach(frameKey => {\n                            sp = atlas.getSpriteFrame(frameKey);\n                            if (sp) {\n                                animSpriteFrames.push(sp);\n                            } else {\n                                console.error(`图集(${url})中不存在动画帧: ${frameKey}`);\n                            }\n                        });\n                        that.AddClip(clipName, animSpriteFrames, that._animCfg[clipName].wrapMode, that._animCfg[clipName].sample);\n                    }\n                    if (defaultAnim) this.PlayAnim(defaultAnim);\n                    resolve(true);\n                } else {\n                    resolve(false);\n                }\n            });\n        })\n    }\n\n    /**\n     * \n     * @param clipName \n     * @param animSpriteFrames \n     * @param sample 动画帧率，单位为帧/秒\n     * @param wrapMode \n     */\n    private AddClip(clipName: string, animSpriteFrames: cc.SpriteFrame[], wrapMode: cc.WrapMode, sample: number) {\n        // 创建一个动画\n        let clip = cc.AnimationClip.createWithSpriteFrames(animSpriteFrames, sample);\n        clip.name = clipName;\n        clip.wrapMode = wrapMode;\n        this._anim.addClip(clip);\n    }\n\n    private RemoveAllClips() {\n        if (!this._anim || !this._anim.isValid) return;\n        const clips = this._anim.getClips();\n        for (let i = clips.length - 1; i >= 0; --i) {\n            this._anim.removeClip(clips[i]);\n        }\n    }\n\n    /**\n     * 播放动画\n     * @param clipName \n     */\n    PlayAnim(clipName: string) {\n        this._anim.play(clipName);\n    }\n\n    StopAllAnim() {\n        this._anim.stop();\n    }\n\n    /**\n     * 监听动画完成\n     * @param complete \n     */\n    OnAnimComplete(complete: Function) {\n        this._anim.on(cc.Animation.EventType.FINISHED, (type: string, state: cc.AnimationState) => {\n            complete && complete(type);\n        }, this);\n    }\n}\n"]}