editpolyline.vue 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. <template>
  2. <div class="edit-line">
  3. <!-- 所有按钮 -->
  4. <div class="btn-list">
  5. <el-button
  6. :class="[cmdStatus=='create' ? 'heightLight' : '']"
  7. size="small"
  8. @click="create"
  9. >创建多边形
  10. </el-button>
  11. <el-tooltip class="item" effect="dark" content="双击 item 也可进入编辑状态" placement="top-start">
  12. <el-button
  13. :class="[cmdStatus=='edit' ? 'heightLight' : '']"
  14. size="small"
  15. @click="edit"
  16. >编辑多边形
  17. </el-button>
  18. </el-tooltip>
  19. <el-button
  20. :class="[cmdStatus=='deleteItem' ? 'heightLight' : '']"
  21. size="small"
  22. @click="deleteItem"
  23. >删除
  24. </el-button>
  25. <el-tooltip class="item" effect="dark" content="长按 Shoft 配合左键也可触发该功能" placement="top-start">
  26. <el-button
  27. :class="[cmdStatus=='eqDrawLine' ? 'heightLight' : '']"
  28. size="small"
  29. @click="eqDrawLine"
  30. >垂直水平绘制
  31. </el-button>
  32. </el-tooltip>
  33. </div>
  34. <div class="content">
  35. <div class="left">
  36. <canvas id="edit_polygon" width="700" height="460" tabindex="0"/>
  37. </div>
  38. <div class="line-property">
  39. <el-card shadow="always">
  40. <div slot="header" class="clearfix">
  41. <span>属性修改</span>
  42. </div>
  43. <div class="always-item">
  44. <span>边框宽:</span>
  45. <el-input-number
  46. size="small"
  47. v-model="lineWidth"
  48. @change="changeLineWidth"
  49. :min="1"
  50. :max="50"
  51. ></el-input-number>
  52. </div>
  53. <div class="always-item">
  54. <span>线类型:</span>
  55. <el-select
  56. style="width:130px"
  57. size="small"
  58. v-model="lineType"
  59. @change="changeType"
  60. placeholder="请选择"
  61. >
  62. <el-option
  63. v-for="item in options"
  64. :key="item.value"
  65. :label="item.label"
  66. :value="item.value"
  67. ></el-option>
  68. </el-select>
  69. </div>
  70. <div class="always-item">
  71. <span>线颜色:</span>
  72. <el-color-picker v-model="lineColor" @change="changeColor" show-alpha></el-color-picker>
  73. </div>
  74. <!-- <div class="always-item">
  75. <span>填充色:</span>
  76. <el-color-picker v-model="fillColor" @change="changeFillColor" show-alpha></el-color-picker>
  77. </div> -->
  78. </el-card>
  79. </div>
  80. </div>
  81. </div>
  82. </template>
  83. <script>
  84. import { SGraphScene, SGraphView, SLineStyle } from "@persagy-web/graph/";
  85. import { SItemStatus } from "@persagy-web/big/lib/enums/SItemStatus";
  86. import { SColor } from "@persagy-web/draw/";
  87. //注: 开发者引入 EditPolygonItem 包为: import {EditPolygonItem} from "@persagy-web/edit/";
  88. import { EditPolylineItem } from "./../../../../../guides/edit/items/src/EditPolylineItem";
  89. import { hexify } from "./../../../../public/until/rgbaUtil";
  90. /**
  91. * 编辑折线示例
  92. *
  93. * @author 郝洁 <haojie@persagy.com>
  94. */
  95. export default {
  96. name: "EditPolylineItem",
  97. data() {
  98. return {
  99. /** 命令所属的场景类 */
  100. scene: null,
  101. view: null, //view实例
  102. isCreated: false, //是否创建完成
  103. cmdStatus: "", //选中状态
  104. polylineItem: null, //存放创建的Item
  105. lineWidth: 1, //border线宽
  106. lineColor: "", //border线颜色
  107. fillColor: "", //填充色
  108. lineType: "", //border线类型
  109. options: [
  110. {
  111. value: "Solid",
  112. label: "实线"
  113. },
  114. {
  115. value: "Dashed",
  116. label: "虚线"
  117. },
  118. {
  119. value: "Dotted",
  120. label: "点"
  121. }
  122. ]
  123. };
  124. },
  125. /**
  126. * 页面挂载
  127. */
  128. mounted() {
  129. this.view = new SGraphView("edit_polygon");
  130. this.scene = new SGraphScene();
  131. this.view.scene = this.scene;
  132. },
  133. methods: {
  134. create() {
  135. this.cmdStatus = "create";
  136. this.scene.root.children = [];
  137. this.polylineItem = new EditPolylineItem(null, []);
  138. this.polylineItem.status = SItemStatus.Create;
  139. this.polylineItem.connect("finishCreated", this, this.finishCreated);
  140. this.scene.addItem(this.polylineItem);
  141. this.scene.grabItem = this.polylineItem;
  142. this.view.update();
  143. },
  144. deleteItem() {
  145. this.cmdStatus = "";
  146. this.scene.removeItem(this.polylineItem);
  147. this.polylineItem = null;
  148. this.view.update();
  149. },
  150. edit() {
  151. if (this.polylineItem) {
  152. if (this.polylineItem.status == SItemStatus.Normal) {
  153. this.scene.grabItem = this.polylineItem;
  154. this.polylineItem.status = SItemStatus.Edit;
  155. // this.polylineItem.verAndLeve = false;
  156. this.cmdStatus = "edit";
  157. } else {
  158. this.polylineItem.status = SItemStatus.Normal;
  159. this.scene.grabItem = null;
  160. this.cmdStatus = "";
  161. }
  162. }
  163. },
  164. eqDrawLine() {
  165. this.cmdStatus = "eqDrawLine";
  166. this.scene.root.children = [];
  167. this.polylineItem = new EditPolylineItem(null, []);
  168. this.polylineItem.verAndLeve = true;
  169. this.polylineItem.status = SItemStatus.Create;
  170. this.polylineItem.connect("finishCreated", this, this.finishCreated);
  171. this.polylineItem.moveable = true;
  172. this.scene.addItem(this.polylineItem);
  173. this.scene.grabItem = this.polylineItem;
  174. this.view.update();
  175. },
  176. // 改变线宽属性
  177. changeLineWidth(val) {
  178. if (this.polylineItem) {
  179. this.lineWidth = val;
  180. this.polylineItem.lineWidth = val;
  181. }
  182. },
  183. // 改变颜色
  184. changeColor(val) {
  185. if (this.polylineItem) {
  186. this.lineColor = hexify(val);
  187. this.polylineItem.strokeColor = new SColor(this.lineColor);
  188. }
  189. },
  190. // 改变填充颜色
  191. changeFillColor(val) {
  192. if (this.polylineItem) {
  193. this.fillColor = hexify(val);
  194. this.polylineItem.fillColor = new SColor(this.lineColor);
  195. }
  196. },
  197. //改变线得类型
  198. changeType(val) {
  199. if (this.polylineItem) {
  200. this.polylineItem.lineStyle = SLineStyle[val];
  201. }
  202. },
  203. // 完成创建后的回调
  204. finishCreated() {
  205. this.cmdStatus = "";
  206. }
  207. },
  208. watch: {
  209. polylineItem(val) {
  210. if (val) {
  211. this.lineWidth = val.lineWidth; // 线宽
  212. this.lineColor = val.strokeColor.value; // 线条填充色
  213. this.lineType = this.options[val.lineStyle].value;
  214. } else {
  215. this.lineWidth = 0;
  216. }
  217. }
  218. }
  219. };
  220. </script>
  221. <style scoped lang="less">
  222. .edit-line {
  223. width: 100%;
  224. height: 500px;
  225. .content {
  226. display: flex;
  227. justify-content: flex-start;
  228. .left {
  229. margin-right: 20px;
  230. }
  231. .line-property {
  232. width: 300px;
  233. margin-top: 20px;
  234. .always {
  235. width: 100%;
  236. height: 100%;
  237. }
  238. .always-item {
  239. display: flex;
  240. margin-top: 10px;
  241. justify-content: space-between;
  242. }
  243. }
  244. }
  245. .heightLight {
  246. color: #409eff;
  247. border-color: #c6e2ff;
  248. background-color: #ecf5ff;
  249. }
  250. }
  251. </style>