UEMergeTip.ts 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. import Gamecfg from "../../common/gameCfg";
  2. import GameDataCenter from "../../data/GameDataCenter";
  3. import { MergeItem } from "../../data/model/GridMap/GridMapModel";
  4. import ResSprite from "../../frameWork/compment/ResSprite";
  5. import UEBase from "../../frameWork/compment/UEBase";
  6. import AssetMgr from "../../utils/AssetMgr";
  7. import UECube, { E_CubeType } from "./UECube";
  8. import UEMergeTipItem from "./UEMergeTipItem";
  9. const { ccclass, property } = cc._decorator;
  10. export interface I_MergeTipData {
  11. idx: number;
  12. ueCube1: UECube;
  13. ueCube2: UECube;
  14. }
  15. @ccclass
  16. export default class UEMergeTip extends UEBase {
  17. static readonly BundleKey: string = "gridMap";
  18. static readonly PrefabUrl: string = "UEMergeTip";
  19. static readonly CLS: string = "UEMergeTip";
  20. @property(cc.Prefab)
  21. prefab_item: cc.Prefab = null!;
  22. @property(cc.Node)
  23. node_content: cc.Node = null!;
  24. data: I_MergeTipData = null!;
  25. Init(data: I_MergeTipData) {
  26. //检测是否重复位置和重复合成链
  27. if (this.data && data.idx == this.data.idx) {
  28. return;
  29. }
  30. this.data = data;
  31. let mergeArr = GameDataCenter.gridMap.GetMergeItems(data.ueCube1, data.ueCube2);
  32. if (mergeArr.length > 0) {
  33. this.node.active = true;
  34. for (let i = 1; i <= 4; i++) {
  35. let itemNode = this.node_content.children[i - 1];
  36. if (!itemNode) {
  37. itemNode = cc.instantiate(this.prefab_item);
  38. this.node_content.addChild(itemNode);
  39. }
  40. let pos = this.GetCirclePosition(i - 1, mergeArr.length);
  41. itemNode.setPosition(pos);
  42. itemNode.getComponent(UEMergeTipItem).Init({ data: mergeArr[i - 1] });
  43. }
  44. } else {
  45. this.node.active = false;
  46. }
  47. }
  48. /** 计算圆上的位置 */
  49. private GetCirclePosition(index: number, total: number): cc.Vec2 {
  50. const radius = 100; // 圆的半径
  51. if (total === 1) {
  52. // 只有一个元素时,放在正上方
  53. return cc.v2(0, radius);
  54. }
  55. // 计算每个元素之间的角度
  56. const angleStep = 60; // 相邻两个元素之间的角度
  57. const startAngle = 90 + -total * angleStep / 2 + angleStep / 2; // 从90度(正上方)开始,向右分布
  58. // 计算当前元素的角度(角度转弧度)
  59. const angle = (startAngle + index * angleStep) * Math.PI / 180; // 减去角度使其向右分布
  60. // 计算圆上的位置
  61. const x = radius * Math.cos(angle);
  62. const y = radius * Math.sin(angle);
  63. return cc.v2(x, y);
  64. }
  65. }