attributes_drop.ts 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. import { _decorator, Component, EditBox, instantiate, Label, Node, Prefab, Size } from 'cc';
  2. import { att_drag_data, other_widget_finish_listen_item } from '../../../data/data';
  3. import { other_drag_list_item } from './other_drag_list_item';
  4. import { other_widget_finish_item } from './other_widget_finish_item';
  5. const { ccclass, property } = _decorator;
  6. @ccclass('attributes_drop')
  7. export class attributes_drop extends Component {
  8. @property(EditBox) drag_width:EditBox = null;
  9. @property(EditBox) drag_height:EditBox = null;
  10. @property(EditBox) drag_x:EditBox = null;
  11. @property(EditBox) drag_y:EditBox = null;
  12. @property(Node) btn_is_err_back_pos:Node = null;
  13. @property(Node) lab_is_err_back_pos:Node = null;
  14. @property(Node) btn_add_other_drag_dis:Node = null;
  15. @property(Node) content:Node = null;
  16. @property(Prefab) other_drag_item:Prefab = null;
  17. @property(Node) btn_add_listen_other_widget_finish_event:Node = null;
  18. @property(Prefab) other_widget_finish_item:Prefab = null;
  19. @property(Node) other_widget_finish_content:Node = null;
  20. private call_back = null;
  21. private _err_back_status_call = null;
  22. private _is_err_drag_back:boolean = false;
  23. private m_data:att_drag_data = null;
  24. public update_att(data:att_drag_data){
  25. this.m_data = data;
  26. this.drag_width.string = data.drag_size_width.toString()
  27. this.drag_height.string = data.drag_size_height.toString()
  28. this.drag_x.string = data.drag_pos_x.toString()
  29. this.drag_y.string = data.drag_pos_y.toString()
  30. this._is_err_drag_back = data.is_err_drag_back;
  31. this.lab_is_err_back_pos.getComponent(Label).string = this._is_err_drag_back ?"是":"否"
  32. this.onUpdateOtherDragList()
  33. if(this.m_data.other_widget_finish_listen_list==undefined){
  34. this.m_data.other_widget_finish_listen_list = []
  35. }
  36. this.other_widget_finish_content.removeAllChildren()
  37. for (let index = 0; index < this.m_data.other_widget_finish_listen_list.length; index++) {
  38. let item = instantiate(this.other_widget_finish_item)
  39. item.parent = this.other_widget_finish_content;
  40. let item_data = this.m_data.other_widget_finish_listen_list[index]
  41. item.getComponent(other_widget_finish_item).initView(item_data,this.onOtherWidgetFinishListenItemClickDelete.bind(this))
  42. }
  43. }
  44. protected start(): void {
  45. this.drag_width.node.on('editing-did-ended', this.change, this);
  46. this.drag_height.node.on('editing-did-ended', this.change, this);
  47. this.drag_x.node.on('editing-did-ended', this.change, this);
  48. this.drag_y.node.on('editing-did-ended', this.change, this);
  49. this.btn_is_err_back_pos.on(Node.EventType.TOUCH_END,()=>{
  50. if(this._err_back_status_call!=null){
  51. this._is_err_drag_back = !this._is_err_drag_back
  52. this._err_back_status_call(this._is_err_drag_back)
  53. this.lab_is_err_back_pos.getComponent(Label).string = this._is_err_drag_back?"是":"否"
  54. }
  55. })
  56. this.btn_add_other_drag_dis.on(Node.EventType.TOUCH_END,()=>{
  57. this.addOtherDragItem()
  58. })
  59. this.btn_add_listen_other_widget_finish_event.on(Node.EventType.TOUCH_END,()=>{
  60. this.addOtherWidgetFinishListenItem()
  61. })
  62. }
  63. public initView(call,err_back_status_call){
  64. this.call_back = call;
  65. this._err_back_status_call = err_back_status_call;
  66. }
  67. onUpdateOtherDragList() {
  68. this.content.removeAllChildren()
  69. if(this.m_data.other_drag_list==undefined){
  70. this.m_data.other_drag_list = []
  71. }
  72. for (let index = 0; index < this.m_data.other_drag_list.length; index++) {
  73. let item = instantiate(this.other_drag_item)
  74. item.parent = this.content;
  75. let item_data = this.m_data.other_drag_list[index]
  76. item.getComponent(other_drag_list_item).initView(index, this.m_data.other_drag_list.length, item_data,this.onOtherDragItemClickDelete.bind(this),this.onOtherDragItemUpDown.bind(this))
  77. }
  78. }
  79. addOtherWidgetFinishListenItem(){
  80. let item = instantiate(this.other_widget_finish_item)
  81. item.parent = this.other_widget_finish_content;
  82. let item_data = new other_widget_finish_listen_item;
  83. this.m_data.other_widget_finish_listen_list.push(item_data)
  84. item.getComponent(other_widget_finish_item).initView(this.m_data.other_widget_finish_listen_list[this.m_data.other_widget_finish_listen_list.length-1],this.onOtherWidgetFinishListenItemClickDelete.bind(this))
  85. this.change()
  86. }
  87. onOtherWidgetFinishListenItemClickDelete(data:other_widget_finish_listen_item){
  88. let index = this.m_data.other_widget_finish_listen_list.indexOf(data)
  89. this.m_data.other_widget_finish_listen_list.splice(index,1)
  90. this.change()
  91. }
  92. addOtherDragItem(){
  93. let item = instantiate(this.other_drag_item)
  94. item.parent = this.content;
  95. let item_data = new att_drag_data
  96. item_data.drag_pos_x = this.m_data.drag_pos_x+50;
  97. item_data.drag_pos_y = this.m_data.drag_pos_y;
  98. item_data.drag_size_width = this.m_data.drag_size_width;
  99. item_data.drag_size_height = this.m_data.drag_size_height;
  100. this.m_data.other_drag_list.push(item_data)
  101. let index = this.m_data.other_drag_list.length-1
  102. item.getComponent(other_drag_list_item).initView(index, this.m_data.other_drag_list.length, this.m_data.other_drag_list[index],this.onOtherDragItemClickDelete.bind(this),this.onOtherDragItemUpDown.bind(this))
  103. this.change()
  104. }
  105. onOtherDragItemClickDelete(data:att_drag_data){
  106. let index = this.m_data.other_drag_list.indexOf(data)
  107. this.m_data.other_drag_list.splice(index,1)
  108. this.change()
  109. }
  110. onOtherDragItemUpDown(item:other_drag_list_item, is_up:boolean) {
  111. let list = this.m_data.other_drag_list
  112. let c_index = item.getIndex()
  113. let c_data = list[c_index]
  114. let move_index=-1;
  115. if(is_up) {
  116. move_index = c_index - 1
  117. } else {
  118. move_index = c_index + 1
  119. }
  120. if(move_index == -1) {return}
  121. let move_data = list[move_index]
  122. list[c_index] = move_data
  123. list[move_index] = c_data
  124. this.onUpdateOtherDragList()
  125. this.change()
  126. }
  127. change(){
  128. this.m_data.drag_pos_x = parseInt(this.drag_x.string);
  129. this.m_data.drag_pos_y = parseInt(this.drag_y.string);
  130. this.m_data.drag_size_width = parseInt(this.drag_width.string);
  131. this.m_data.drag_size_height = parseInt(this.drag_height.string);
  132. if(this.call_back!=null){
  133. this.call_back(this.m_data)
  134. }
  135. }
  136. }