position-groups.ts 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. /**
  2. * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
  3. * SPDX-License-Identifier: MIT
  4. */
  5. import type { PositionSchema } from '@flowgram.ai/free-layout-editor';
  6. export interface PositionGroup {
  7. [key: string]: PositionSchema;
  8. }
  9. const originPosition: PositionGroup = {
  10. '1': {
  11. x: 0,
  12. y: 0,
  13. },
  14. '2': {
  15. x: 110,
  16. y: 0,
  17. },
  18. '3': {
  19. x: 220,
  20. y: 0,
  21. },
  22. '4': {
  23. x: 330,
  24. y: 0,
  25. },
  26. };
  27. export const positionGroups: PositionGroup[] = [
  28. // 水平线形态
  29. {
  30. '1': {
  31. x: 60,
  32. y: 0,
  33. },
  34. '2': {
  35. x: 120,
  36. y: 0,
  37. },
  38. '3': {
  39. x: 180,
  40. y: 0,
  41. },
  42. '4': {
  43. x: 240,
  44. y: 0,
  45. },
  46. },
  47. originPosition,
  48. // 锯齿形态
  49. {
  50. '1': {
  51. x: 0,
  52. y: -40,
  53. },
  54. '2': {
  55. x: 110,
  56. y: 40,
  57. },
  58. '3': {
  59. x: 220,
  60. y: -40,
  61. },
  62. '4': {
  63. x: 330,
  64. y: 40,
  65. },
  66. },
  67. originPosition,
  68. // 弧形形态
  69. {
  70. '1': {
  71. x: 50,
  72. y: -30,
  73. },
  74. '2': {
  75. x: 120,
  76. y: -50,
  77. },
  78. '3': {
  79. x: 190,
  80. y: -50,
  81. },
  82. '4': {
  83. x: 260,
  84. y: -30,
  85. },
  86. },
  87. originPosition,
  88. // 散布形态
  89. {
  90. '1': {
  91. x: 30,
  92. y: 60,
  93. },
  94. '2': {
  95. x: 180,
  96. y: -40,
  97. },
  98. '3': {
  99. x: 80,
  100. y: -60,
  101. },
  102. '4': {
  103. x: 280,
  104. y: 40,
  105. },
  106. },
  107. originPosition,
  108. // 对角上升形态
  109. {
  110. '1': {
  111. x: 0,
  112. y: 75,
  113. },
  114. '2': {
  115. x: 110,
  116. y: 25,
  117. },
  118. '3': {
  119. x: 220,
  120. y: -25,
  121. },
  122. '4': {
  123. x: 330,
  124. y: -75,
  125. },
  126. },
  127. originPosition,
  128. // 波浪形态
  129. {
  130. '1': {
  131. x: 0,
  132. y: 0,
  133. },
  134. '2': {
  135. x: 110,
  136. y: 80,
  137. },
  138. '3': {
  139. x: 220,
  140. y: 40,
  141. },
  142. '4': {
  143. x: 330,
  144. y: -20,
  145. },
  146. },
  147. originPosition,
  148. // 垂直堆叠形态
  149. {
  150. '1': {
  151. x: 165,
  152. y: -60,
  153. },
  154. '2': {
  155. x: 165,
  156. y: -20,
  157. },
  158. '3': {
  159. x: 165,
  160. y: 20,
  161. },
  162. '4': {
  163. x: 165,
  164. y: 60,
  165. },
  166. },
  167. originPosition,
  168. // 钻石形态
  169. {
  170. '1': {
  171. x: 165,
  172. y: -40,
  173. },
  174. '2': {
  175. x: 110,
  176. y: 0,
  177. },
  178. '3': {
  179. x: 165,
  180. y: 40,
  181. },
  182. '4': {
  183. x: 220,
  184. y: 0,
  185. },
  186. },
  187. originPosition,
  188. ];