ResSpine.js 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  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/ResSpine.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, 'd4c5dupxW5Hw7tvypXWSElT', 'ResSpine');
  13. // script/frameWork/compment/ResSpine.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. var ResBaseAsset_1 = require("./ResBaseAsset");
  36. var _a = cc._decorator, ccclass = _a.ccclass, menu = _a.menu, disallowMultiple = _a.disallowMultiple, requireComponent = _a.requireComponent;
  37. /**
  38. * spine组件,自动管理资源的引用计数
  39. */
  40. var ResSpine = /** @class */ (function (_super) {
  41. __extends(ResSpine, _super);
  42. function ResSpine() {
  43. var _this = _super !== null && _super.apply(this, arguments) || this;
  44. _this._spSkeleton = null;
  45. _this._url = '';
  46. return _this;
  47. }
  48. Object.defineProperty(ResSpine.prototype, "spSkeleton", {
  49. get: function () {
  50. var _a, _b;
  51. return this._spSkeleton || (this._spSkeleton = ((_a = this.node) === null || _a === void 0 ? void 0 : _a.getComponent(sp.Skeleton)) || ((_b = this.node) === null || _b === void 0 ? void 0 : _b.addComponent(sp.Skeleton)));
  52. },
  53. enumerable: false,
  54. configurable: true
  55. });
  56. Object.defineProperty(ResSpine.prototype, "skeletonData", {
  57. get: function () {
  58. return this.spSkeleton.skeletonData;
  59. },
  60. enumerable: false,
  61. configurable: true
  62. });
  63. // private m_CompleteFunc: Function;
  64. /**
  65. * 通过 url 设置Spine
  66. * @param bundle
  67. * @param url spine动画 的json文件 路径
  68. * @param extraData
  69. * @returns
  70. */
  71. ResSpine.prototype.setSpineData = function (bundle, url, cb, isPremultipliedAlpha, animationName, loop, speed) {
  72. var _this = this;
  73. if (isPremultipliedAlpha === void 0) { isPremultipliedAlpha = true; }
  74. if (animationName === void 0) { animationName = "standby"; }
  75. if (loop === void 0) { loop = true; }
  76. if (speed === void 0) { speed = 1; }
  77. this._url = url;
  78. this.loadAsset(bundle, url, sp.SkeletonData, function (asset) {
  79. if (asset && _this.spSkeleton && _this.spSkeleton.isValid) {
  80. _this.spSkeleton.skeletonData = asset;
  81. _this.spSkeleton.enableBatch = true;
  82. _this.spSkeleton.premultipliedAlpha = isPremultipliedAlpha;
  83. _this.spSkeleton.loop = loop;
  84. if (_this.spSkeleton.findAnimation(animationName) != null) {
  85. _this.spSkeleton.animation = animationName;
  86. }
  87. _this.spSkeleton.timeScale = speed;
  88. cb && cb(asset);
  89. }
  90. else {
  91. console.warn("\u52A0\u8F7D Spine \u5931\u8D25: " + bundle + " " + url);
  92. cb && cb(null);
  93. }
  94. });
  95. };
  96. ResSpine.prototype.setRoleSpine = function (url1, url2, cb, isPremultipliedAlpha, animationName, loop, speed) {
  97. if (isPremultipliedAlpha === void 0) { isPremultipliedAlpha = true; }
  98. if (animationName === void 0) { animationName = "standby"; }
  99. if (loop === void 0) { loop = true; }
  100. if (speed === void 0) { speed = 1; }
  101. this.setSpineData("spine", url1 + url2 + "/" + url2, cb, isPremultipliedAlpha, animationName, loop, speed);
  102. };
  103. ResSpine.prototype.setAnimation = function (animationName) {
  104. if (this.spSkeleton) {
  105. this.spSkeleton.animation = animationName;
  106. }
  107. };
  108. /**
  109. * 播放动作
  110. * @param aniName 动画名称
  111. * @param loop 是否循环
  112. * @param showLast 显示最后一帧
  113. */
  114. ResSpine.prototype.playAnimation = function (aniName, loop, showLast) {
  115. if (this.spSkeleton) {
  116. if (this.spSkeleton.findAnimation(aniName)) {
  117. this.spSkeleton.setAnimation(0, aniName, loop);
  118. if (showLast) {
  119. this.spSkeleton.timeScale = 100000;
  120. }
  121. }
  122. else {
  123. // console.error("动画名称不存在", this._url, aniName);
  124. }
  125. }
  126. };
  127. /** 是否存在动画 */
  128. ResSpine.prototype.isExistAnimation = function (aniName) {
  129. return this.spSkeleton.findAnimation(aniName) ? true : false;
  130. };
  131. ResSpine.prototype.setTimeScale = function (speed) {
  132. if (this.spSkeleton) {
  133. this.spSkeleton.timeScale = speed;
  134. }
  135. };
  136. ResSpine.prototype.enableBatch = function () {
  137. this.spSkeleton.enableBatch = true;
  138. };
  139. ResSpine.prototype.clearTracks = function () {
  140. if (this.spSkeleton) {
  141. this.spSkeleton.clearTracks();
  142. }
  143. };
  144. ResSpine.prototype.clearRes = function () {
  145. this.spSkeleton.skeletonData = null;
  146. this.resetRes();
  147. };
  148. /** 设置渲染模式 */
  149. ResSpine.prototype.setCacheMode = function (mode) {
  150. this.spSkeleton.setAnimationCacheMode(mode);
  151. };
  152. /** 后续废弃
  153. * 添加播放完成监听
  154. */
  155. ResSpine.prototype.addCompleteListener = function (callback) {
  156. // this.m_CompleteFunc = callback;
  157. this.spSkeleton.setCompleteListener(function (trackEntry, loopCount) {
  158. // this.spSkeleton.setCompleteListener(null);
  159. // if (this.m_CompleteFunc) this.m_CompleteFunc();
  160. // this.m_CompleteFunc = null;
  161. callback(trackEntry, loopCount);
  162. });
  163. };
  164. /**
  165. * 添加播放完成监听
  166. */
  167. ResSpine.prototype.AddSpineCompleteListener = function (callback) {
  168. // this.m_CompleteFunc = callback;
  169. this.spSkeleton.setCompleteListener(function (trackEntry, loopCount) {
  170. var name = trackEntry.animation ? trackEntry.animation.name : '';
  171. callback(name);
  172. });
  173. };
  174. /** 移除完成监听 */
  175. ResSpine.prototype.removeCompleteListener = function () {
  176. var _a;
  177. (_a = this.spSkeleton) === null || _a === void 0 ? void 0 : _a.setCompleteListener(null);
  178. };
  179. /** 添加事件帧监听 */
  180. ResSpine.prototype.addEventListener = function (callback) {
  181. this.spSkeleton.setEventListener(function (trackIndex, event) {
  182. var name = event.data.name;
  183. callback(name);
  184. });
  185. };
  186. /** 移除事件帧监听 */
  187. ResSpine.prototype.removeEventListener = function () {
  188. this.spSkeleton.setEventListener(null);
  189. };
  190. /** 获取插槽节点世界坐标 */
  191. ResSpine.prototype.getSlotWorldPos = function (slotName) {
  192. if (!slotName)
  193. return null;
  194. var slot = this.spSkeleton.findSlot(slotName);
  195. // 输出骨骼点的信息
  196. if (slot) {
  197. // 获取骨骼点的世界变换信息
  198. var worldX = slot.bone.worldX;
  199. var worldY = slot.bone.worldY;
  200. return this.node.convertToWorldSpaceAR(cc.v2(worldX, worldY)); //转换世界坐标
  201. }
  202. else {
  203. // console.error("未找到骨骼点: ", slotName);
  204. return null;
  205. }
  206. };
  207. /** 获取骨骼节点世界坐标 */
  208. ResSpine.prototype.getBoneWorldPos = function (boneName) {
  209. if (!boneName)
  210. return null;
  211. var bone = this.spSkeleton.findBone(boneName);
  212. // 输出骨骼点的信息
  213. if (bone) {
  214. // 获取骨骼点的世界变换信息
  215. var worldX = bone.worldX;
  216. var worldY = bone.worldY;
  217. return this.node.convertToWorldSpaceAR(cc.v2(worldX, worldY)); //转换世界坐标
  218. }
  219. else {
  220. // console.error("未找到骨骼点: ", boneName);
  221. return null;
  222. }
  223. };
  224. ResSpine.prototype.PauseAction = function () {
  225. if (this.spSkeleton && this.spSkeleton.isValid)
  226. this.spSkeleton.paused = true;
  227. };
  228. ResSpine.prototype.ResumeAction = function () {
  229. if (this.spSkeleton && this.spSkeleton.isValid)
  230. this.spSkeleton.paused = false;
  231. };
  232. ResSpine.prototype.StopAction = function () {
  233. if (this.spSkeleton && this.spSkeleton.isValid)
  234. this.spSkeleton.clearTracks();
  235. };
  236. ResSpine = __decorate([
  237. ccclass,
  238. disallowMultiple,
  239. requireComponent(sp.Skeleton),
  240. menu("UI/ResSpine")
  241. ], ResSpine);
  242. return ResSpine;
  243. }(ResBaseAsset_1.ResBaseAsset));
  244. exports.default = ResSpine;
  245. cc._RF.pop();
  246. }
  247. if (nodeEnv) {
  248. __define(__module.exports, __require, __module);
  249. }
  250. else {
  251. __quick_compile_project__.registerModuleFunc(__filename, function () {
  252. __define(__module.exports, __require, __module);
  253. });
  254. }
  255. })();
  256. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["assets/script/frameWork/compment/ResSpine.ts"],"names":[],"mappings":"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","file":"","sourceRoot":"/","sourcesContent":["import { IconUrl } from \"../../data/const/ResConst\";\nimport { ResBaseAsset } from \"./ResBaseAsset\";\n\nconst { ccclass, menu, disallowMultiple, requireComponent } = cc._decorator;\n\n/**\n * spine组件，自动管理资源的引用计数\n */\n@ccclass\n@disallowMultiple\n@requireComponent(sp.Skeleton)\n@menu(\"UI/ResSpine\")\nexport default class ResSpine extends ResBaseAsset<sp.SkeletonData> {\n\tprivate _spSkeleton: sp.Skeleton = null;\n\tprivate _url: string = '';\n\tget spSkeleton() {\n\t\treturn this._spSkeleton || (this._spSkeleton = this.node?.getComponent(sp.Skeleton) || this.node?.addComponent(sp.Skeleton));\n\t}\n\tpublic get skeletonData() {\n\t\treturn this.spSkeleton.skeletonData;\n\t}\n\t// private m_CompleteFunc: Function;\n\t/**\n\t * 通过 url 设置Spine\n\t * @param bundle\n\t * @param url spine动画 的json文件 路径\n\t * @param extraData\n\t * @returns\n\t */\n\tsetSpineData<EXTRA_DATA = any>(bundle: string, url: string, cb?: (asset: sp.SkeletonData) => void, isPremultipliedAlpha: boolean = true, animationName: string = \"standby\", loop: boolean = true, speed: number = 1) {\n\t\tthis._url = url;\n\t\tthis.loadAsset(bundle, url, sp.SkeletonData, (asset: sp.SkeletonData) => {\n\t\t\tif (asset && this.spSkeleton && this.spSkeleton.isValid) {\n\t\t\t\tthis.spSkeleton.skeletonData = asset;\n\t\t\t\tthis.spSkeleton.enableBatch = true;\n\t\t\t\tthis.spSkeleton.premultipliedAlpha = isPremultipliedAlpha;\n\t\t\t\tthis.spSkeleton.loop = loop;\n\t\t\t\tif (this.spSkeleton.findAnimation(animationName) != null) {\n\t\t\t\t\tthis.spSkeleton.animation = animationName;\n\t\t\t\t}\n\t\t\t\tthis.spSkeleton.timeScale = speed;\n\t\t\t\tcb && cb(asset);\n\t\t\t} else {\n\t\t\t\tconsole.warn(`加载 Spine 失败: ${bundle} ${url}`);\n\t\t\t\tcb && cb(null);\n\t\t\t}\n\t\t});\n\t}\n\n\tsetRoleSpine(url1: IconUrl, url2: string, cb?: (asset: sp.SkeletonData) => void, isPremultipliedAlpha: boolean = true, animationName: string = \"standby\", loop: boolean = true, speed: number = 1) {\n\t\tthis.setSpineData(\"spine\", url1 + url2 + \"/\" + url2, cb, isPremultipliedAlpha, animationName, loop, speed);\n\t}\n\n\tsetAnimation(animationName: string) {\n\t\tif (this.spSkeleton) {\n\t\t\tthis.spSkeleton.animation = animationName;\n\t\t}\n\t}\n\n\t/**\n\t * 播放动作\n\t * @param aniName 动画名称\n\t * @param loop 是否循环\n\t * @param showLast 显示最后一帧\n\t */\n\tplayAnimation(aniName: string, loop: boolean, showLast?: boolean) {\n\t\tif (this.spSkeleton) {\n\t\t\tif (this.spSkeleton.findAnimation(aniName)) {\n\t\t\t\tthis.spSkeleton.setAnimation(0, aniName, loop);\n\t\t\t\tif (showLast) {\n\t\t\t\t\tthis.spSkeleton.timeScale = 100000;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// console.error(\"动画名称不存在\", this._url, aniName);\n\t\t\t}\n\t\t}\n\t}\n\n\t/** 是否存在动画 */\n\tisExistAnimation(aniName: string): boolean {\n\t\treturn this.spSkeleton.findAnimation(aniName) ? true : false;\n\t}\n\n\tsetTimeScale(speed: number) {\n\t\tif (this.spSkeleton) {\n\t\t\tthis.spSkeleton.timeScale = speed;\n\t\t}\n\t}\n\n\tenableBatch() {\n\t\tthis.spSkeleton.enableBatch = true;\n\t}\n\n\tclearTracks() {\n\t\tif (this.spSkeleton) {\n\t\t\tthis.spSkeleton.clearTracks()\n\t\t}\n\t}\n\tclearRes() {\n\t\tthis.spSkeleton.skeletonData = null;\n\t\tthis.resetRes();\n\t}\n\n\t/** 设置渲染模式 */\n\tsetCacheMode(mode: sp.Skeleton.AnimationCacheMode) {\n\t\tthis.spSkeleton.setAnimationCacheMode(mode);\n\t}\n\n\t/** 后续废弃\n\t * 添加播放完成监听 \n\t */\n\taddCompleteListener(callback: Function) {\n\t\t// this.m_CompleteFunc = callback;\n\t\tthis.spSkeleton.setCompleteListener((trackEntry, loopCount) => {\n\t\t\t// this.spSkeleton.setCompleteListener(null);\n\t\t\t// if (this.m_CompleteFunc) this.m_CompleteFunc();\n\t\t\t// this.m_CompleteFunc = null;\n\t\t\tcallback(trackEntry, loopCount);\n\t\t});\n\t}\n\n\t/** \n\t * 添加播放完成监听 \n\t */\n\tAddSpineCompleteListener(callback: Function) {\n\t\t// this.m_CompleteFunc = callback;\n\t\tthis.spSkeleton.setCompleteListener((trackEntry, loopCount) => {\n\t\t\tlet name = trackEntry.animation ? trackEntry.animation.name : '';\n\t\t\tcallback(name);\n\t\t});\n\t}\n\n\t/** 移除完成监听 */\n\tremoveCompleteListener() {\n\t\tthis.spSkeleton?.setCompleteListener(null);\n\t}\n\n\t/** 添加事件帧监听 */\n\taddEventListener(callback: Function): void {\n\t\tthis.spSkeleton.setEventListener((trackIndex, event: any) => {\n\t\t\tlet name = event.data.name;\n\t\t\tcallback(name);\n\t\t});\n\t}\n\n\t/** 移除事件帧监听 */\n\tremoveEventListener() {\n\t\tthis.spSkeleton.setEventListener(null);\n\t}\n\n\t/** 获取插槽节点世界坐标 */\n\tgetSlotWorldPos(slotName: string): cc.Vec2 {\n\t\tif (!slotName) return null;\n\t\tlet slot: sp.spine.Slot = this.spSkeleton.findSlot(slotName);\n\t\t// 输出骨骼点的信息\n\t\tif (slot) {\n\t\t\t// 获取骨骼点的世界变换信息\n\t\t\tconst worldX = slot.bone.worldX;\n\t\t\tconst worldY = slot.bone.worldY;\n\t\t\treturn this.node.convertToWorldSpaceAR(cc.v2(worldX, worldY)); //转换世界坐标\n\t\t} else {\n\t\t\t// console.error(\"未找到骨骼点: \", slotName);\n\t\t\treturn null;\n\t\t}\n\t}\n\n\t/** 获取骨骼节点世界坐标 */\n\tgetBoneWorldPos(boneName: string): cc.Vec2 {\n\t\tif (!boneName) return null;\n\t\tlet bone: sp.spine.Bone = this.spSkeleton.findBone(boneName);\n\t\t// 输出骨骼点的信息\n\t\tif (bone) {\n\t\t\t// 获取骨骼点的世界变换信息\n\t\t\tconst worldX = bone.worldX;\n\t\t\tconst worldY = bone.worldY;\n\t\t\treturn this.node.convertToWorldSpaceAR(cc.v2(worldX, worldY)); //转换世界坐标\n\t\t} else {\n\t\t\t// console.error(\"未找到骨骼点: \", boneName);\n\t\t\treturn null;\n\t\t}\n\t}\n\n\tPauseAction() {\n\t\tif (this.spSkeleton && this.spSkeleton.isValid)\n\t\t\tthis.spSkeleton.paused = true;\n\t}\n\n\tResumeAction() {\n\t\tif (this.spSkeleton && this.spSkeleton.isValid)\n\t\t\tthis.spSkeleton.paused = false;\n\t}\n\n\tStopAction() {\n\t\tif (this.spSkeleton && this.spSkeleton.isValid)\n\t\t\tthis.spSkeleton.clearTracks();\n\t}\n}\n"]}