useDnD.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. // import { useVueFlow,Position,MarkerType } from '@vue-flow/core';
  2. import { useVueFlow,Position,MarkerType} from '@vue-flow/core';
  3. import { ref, watch } from 'vue'
  4. import gc1 from '@/assets/flowimg/gc1.png'
  5. import gc2 from '@/assets/flowimg/gc2.png'
  6. import gc3 from '@/assets/flowimg/gc3.png'
  7. import wen from '@/assets/flowimg/wen.png'
  8. import xuek1 from '@/assets/flowimg/xuek1.png'
  9. import xuek0 from '@/assets/flowimg/xuek0.png'
  10. import xuek2 from '@/assets/flowimg/xuek2.png'
  11. import xuek3 from '@/assets/flowimg/xuek3.png'
  12. import xuek4 from '@/assets/flowimg/xuek4.png'
  13. import xuek5 from '@/assets/flowimg/xuek5.png'
  14. import xuek6 from '@/assets/flowimg/xuek6.png'
  15. import xuek7 from '@/assets/flowimg/xuek7.png'
  16. import xuek8 from '@/assets/flowimg/xuek8.png'
  17. import xuek9 from '@/assets/flowimg/xuek9.png'
  18. import xuek10 from '@/assets/flowimg/xuek10.png'
  19. import xuek11 from '@/assets/flowimg/xuek11.png'
  20. import xuek12 from '@/assets/flowimg/xuek12.png'
  21. let nid = 0;
  22. let id=0
  23. let datas={}
  24. /**
  25. * @returns {string} - A unique id.
  26. */
  27. function getId() {
  28. return `node_${id++}`
  29. }
  30. function imagefun(){
  31. console.log(nid);
  32. if(nid=='1-1'){
  33. return datas = {label: '优化问题', image:gc1}
  34. }else if(nid=='1-2'){
  35. return datas = {label:'分析流程', image:gc2}
  36. }else if(nid=='1-3'){
  37. return datas = {label:'优化器', image:gc3}
  38. }else if(nid=='2_1'){
  39. return datas = {label:'优化问题', image:wen}
  40. }else if(nid=='3-1'){
  41. return datas = {label:'CATIA', image:xuek1}
  42. }else if(nid=='3-0'){
  43. return datas = {label:'CST', image:xuek0}
  44. } else if(nid=='3-2'){
  45. return datas = {label:'Excel', image:xuek2}
  46. }else if(nid=='3-3'){
  47. return datas = {label:'Feko', image:xuek3}
  48. }else if(nid=='3-4'){
  49. return datas = {label:'Fluent', image:xuek4}
  50. }else if(nid=='3-5'){
  51. return datas = {label:'HCFD', image:xuek5}
  52. }else if(nid=='3-6'){
  53. return datas = {label:'Matlab', image:xuek6}
  54. }else if(nid=='3-7'){
  55. return datas = {label:'Nastran', image:xuek7}
  56. }else if(nid=='3-8'){
  57. return datas = {label:'Rosenbrock', image:xuek8}
  58. }else if(nid=='3-9'){
  59. return datas = {label:'AirfoilAero', image:xuek9}
  60. }else if(nid=='4-1'){
  61. return datas = {label:'进化优化器', image:xuek10}
  62. }else if(nid=='4-2'){
  63. return datas = {label:'代理优化器', image:xuek11}
  64. }else if(nid=='4-3'){
  65. return datas = {label:'梯度优化器', image:xuek12}
  66. }
  67. else{
  68. return null;
  69. }
  70. }
  71. /**
  72. * In a real world scenario you'd want to avoid creating refs in a global scope like this as they might not be cleaned up properly.
  73. * @type {{draggedType: Ref<string|null>, isDragOver: Ref<boolean>, isDragging: Ref<boolean>}}
  74. */
  75. const state = {
  76. /**
  77. * The type of the node being dragged.
  78. */
  79. draggedType: ref(null),
  80. isDragOver: ref(false),
  81. isDragging: ref(false),
  82. }
  83. export default function useDragAndDrop() {
  84. const { draggedType, isDragOver, isDragging } = state
  85. const { addNodes, addEdges,screenToFlowCoordinate, onNodesInitialized, updateNode } = useVueFlow()
  86. watch(isDragging, (dragging) => {
  87. document.body.style.userSelect = dragging ? 'none' : ''
  88. })
  89. function onDragStart(event, type,id) {
  90. if (event.dataTransfer) {
  91. nid=id;
  92. event.dataTransfer.setData('application/vueflow', type)
  93. event.dataTransfer.effectAllowed = 'move'
  94. console.log(1122344)
  95. }
  96. draggedType.value =type;
  97. //draggedType.value = 'smoothstep'
  98. isDragging.value = true
  99. document.addEventListener('drop', onDragEnd)
  100. }
  101. /**
  102. * Handles the drag over event.
  103. *
  104. * @param {DragEvent} event
  105. */
  106. function onDragOver(event) {
  107. event.preventDefault()
  108. if (draggedType.value) {
  109. isDragOver.value = true
  110. if (event.dataTransfer) {
  111. event.dataTransfer.dropEffect = 'move'
  112. }
  113. }
  114. }
  115. function handleNodeDrop(e){
  116. }
  117. function onDragLeave(e) {
  118. isDragOver.value = false
  119. }
  120. function onDragEnd() {
  121. isDragging.value = false
  122. isDragOver.value = false
  123. draggedType.value = null
  124. nid=''
  125. document.removeEventListener('drop', onDragEnd)
  126. }
  127. /**
  128. * Handles the drop event.
  129. *
  130. * @param {DragEvent} event
  131. */
  132. function onDrop(event) {
  133. const position = screenToFlowCoordinate({
  134. x: event.clientX,
  135. y: event.clientY,
  136. })
  137. const nodeId = getId()
  138. const image1=imagefun();
  139. let snodes=ref([]);
  140. let sedges=ref([]);
  141. if(nid=='4'){
  142. // const nodes = ref([])
  143. // const edges = ref([])
  144. }else{
  145. snodes.value=[];
  146. sedges.value=[];
  147. const newNode = {
  148. id: nodeId,
  149. type: draggedType.value,
  150. position,
  151. data: image1,
  152. }
  153. snodes.value.push(newNode)
  154. }
  155. const { off } = onNodesInitialized(() => {
  156. updateNode(nodeId, (node) => ({
  157. position: { x: node.position.x - node.dimensions.width / 2, y: node.position.y - node.dimensions.height / 2 },
  158. }))
  159. off()
  160. })
  161. addNodes(snodes.value)
  162. // addEdges(sedges.value)
  163. }
  164. return {
  165. draggedType,
  166. isDragOver,
  167. isDragging,
  168. onDragStart,
  169. onDragLeave,
  170. onDragOver,
  171. onDrop,
  172. handleNodeDrop,
  173. }
  174. }