CrEditProperty_Point.ce.vue 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855
  1. <template>
  2. <div class="jt-drawing-dialog">
  3. <el-dialog :modal="false" :destroy-on-close="false" v-model="dialogVisible" :title="title" @close="closeDialog" @open="openDialog" :show-close="false">
  4. <template #header>
  5. <div slot="title" class="header-title">
  6. <span style="line-height:24rem;font-size:16rem;color:#fff;font-family: 'Alimama_ShuHeiTi_Bold'">{{ title }}</span>
  7. </div>
  8. </template>
  9. <template #default>
  10. <el-scrollbar>
  11. <div class="content">
  12. <el-collapse v-model="activeNames">
  13. <el-collapse-item name="标注样式" v-show="isShowLabelStyle">
  14. <template #title>
  15. <el-icon style="padding: 10rem;">
  16. <Setting />
  17. </el-icon>标注样式
  18. </template>
  19. <div class="jt-drawing-row" style="height: 60rem;">
  20. <div class="col-left">内容</div>
  21. <div class="col-main">
  22. <el-input v-model="label.content" placeholder="输入显示的文字内容" clearable type="textarea" :rows="2" />
  23. </div>
  24. </div>
  25. <div class="jt-drawing-row">
  26. <div class="col-left">字体</div>
  27. <div class="col-main">
  28. <el-select v-model="label.font" placeholder="请选择">
  29. <el-option v-for="item in selectOptionsFont" :key="item.value" :label="item.label" :value="item.value" />
  30. </el-select>
  31. </div>
  32. </div>
  33. <div class="jt-drawing-row">
  34. <div class="col-left">字体大小</div>
  35. <div class="col-main">
  36. <el-input-number v-model="label.fontSize" :min="0" :max="100" />
  37. </div>
  38. </div>
  39. <div class="jt-drawing-row">
  40. <div class="col-left">是否加粗</div>
  41. <div class="col-main">
  42. <el-switch v-model="label.bolder" />
  43. </div>
  44. </div>
  45. <div class="jt-drawing-row">
  46. <div class="col-left">是否斜体</div>
  47. <div class="col-main">
  48. <el-switch v-model="label.italic" />
  49. </div>
  50. </div>
  51. <div class="jt-drawing-row">
  52. <div class="col-left">颜色</div>
  53. <div class="col-main">
  54. <el-config-provider :locale="locale">
  55. <el-color-picker v-model="label.fillColor" show-alpha :predefine="predefineColors" label="12" />
  56. </el-config-provider>
  57. </div>
  58. </div>
  59. <div class="jt-drawing-row">
  60. <div class="col-left">是否边框</div>
  61. <div class="col-main">
  62. <el-switch v-model="label.showOutline" />
  63. </div>
  64. </div>
  65. <div class="jt-drawing-row" v-show="label.showOutline">
  66. <div class="col-left">边框颜色</div>
  67. <div class="col-main">
  68. <el-config-provider :locale="locale">
  69. <el-color-picker v-model="label.outlineColor" show-alpha :predefine="predefineColors" label="12" />
  70. </el-config-provider>
  71. </div>
  72. </div>
  73. <div class="jt-drawing-row" v-show="label.showOutline">
  74. <div class="col-left">边框宽度</div>
  75. <div class="col-main">
  76. <el-input-number v-model="label.outlineWidth" :min="0" :max="100" />
  77. </div>
  78. </div>
  79. <div class="jt-drawing-row">
  80. <div class="col-left">是否背景</div>
  81. <div class="col-main">
  82. <el-switch v-model="label.showBackground" />
  83. </div>
  84. </div>
  85. <div class="jt-drawing-row" v-show="label.showBackground">
  86. <div class="col-left">背景颜色</div>
  87. <div class="col-main">
  88. <el-config-provider :locale="locale">
  89. <el-color-picker v-model="label.backgroundColor" show-alpha :predefine="predefineColors" label="12" />
  90. </el-config-provider>
  91. </div>
  92. </div>
  93. <div class="jt-drawing-row" v-show="label.showBackground">
  94. <div class="col-left">背景内边距</div>
  95. <div class="col-main">
  96. <el-input-number v-model="label.backgroundPadding" :min="-100" :max="100" />
  97. </div>
  98. </div>
  99. <div class="jt-drawing-row">
  100. <div class="col-left">横向偏移像素</div>
  101. <div class="col-main">
  102. <el-input-number v-model="label.pixelOffsetX" :min="-100" :max="100" />
  103. </div>
  104. </div>
  105. <div class="jt-drawing-row">
  106. <div class="col-left">纵向偏移像素</div>
  107. <div class="col-main">
  108. <el-input-number v-model="label.pixelOffsetY" :min="-100" :max="100" />
  109. </div>
  110. </div>
  111. </el-collapse-item>
  112. <el-collapse-item name="点样式" v-show="isShowPointStyle">
  113. <template #title>
  114. <el-icon style="padding: 10rem;">
  115. <Setting />
  116. </el-icon>点样式
  117. </template>
  118. <div class="jt-drawing-row">
  119. <div class="col-left">像素大小</div>
  120. <div class="col-main">
  121. <el-input-number v-model="point.pixelSize" :min="0" :max="100" />
  122. </div>
  123. </div>
  124. <div class="jt-drawing-row">
  125. <div class="col-left">颜色</div>
  126. <div class="col-main">
  127. <el-config-provider :locale="locale">
  128. <el-color-picker v-model="point.color" show-alpha :predefine="predefineColors" label="12" />
  129. </el-config-provider>
  130. </div>
  131. </div>
  132. <div class="jt-drawing-row">
  133. <div class="col-left">是否边框</div>
  134. <div class="col-main">
  135. <el-switch v-model="point.showOutline" />
  136. </div>
  137. </div>
  138. <div class="jt-drawing-row" v-show="point.showOutline">
  139. <div class="col-left">边框颜色</div>
  140. <div class="col-main">
  141. <el-config-provider :locale="locale">
  142. <el-color-picker v-model="point.outlineColor" show-alpha :predefine="predefineColors" label="12" />
  143. </el-config-provider>
  144. </div>
  145. </div>
  146. <div class="jt-drawing-row" v-show="point.showOutline">
  147. <div class="col-left">边框宽度</div>
  148. <div class="col-main">
  149. <el-input-number v-model="point.outlineWidth" :min="0" :max="100" />
  150. </div>
  151. </div>
  152. </el-collapse-item>
  153. <el-collapse-item name="图片样式" v-show="isShowBillboardStyle">
  154. <template #title>
  155. <el-icon style="padding: 10rem;">
  156. <Setting />
  157. </el-icon>图片样式
  158. </template>
  159. <div class="jt-drawing-row" style="height: 60rem;">
  160. <div class="col-left">图标</div>
  161. <div class="col-main">
  162. <el-input v-model="billboard.imgUrl" placeholder="输入图标路径" clearable type="textarea" :rows="2" />
  163. </div>
  164. </div>
  165. <div class="jt-drawing-row">
  166. <div class="col-left">大小比例</div>
  167. <div class="col-main">
  168. <el-input-number v-model="billboard.scale" :min="1" :max="100" />
  169. </div>
  170. </div>
  171. </el-collapse-item>
  172. <el-collapse-item name="小模型样式" v-show="isShowModelStyle">
  173. <template #title>
  174. <el-icon style="padding: 10rem;">
  175. <Setting />
  176. </el-icon>小模型样式
  177. </template>
  178. <div class="jt-drawing-row" style="height: 60rem;">
  179. <div class="col-left">模型路径</div>
  180. <div class="col-main">
  181. <el-input v-model="model.url" placeholder="输入模型路径" clearable type="textarea" :rows="2" />
  182. </div>
  183. </div>
  184. <div class="jt-drawing-row">
  185. <div class="col-left">透明度</div>
  186. <div class="col-main">
  187. <el-input-number v-model="model.alpha" :step="0.1" :min="0" :max="1" />
  188. </div>
  189. </div>
  190. <div class="jt-drawing-row">
  191. <div class="col-left">最小像素大小</div>
  192. <div class="col-main">
  193. <el-input-number v-model="model.minimumPixelSize" :step="1" :min="0" :max="20000" />
  194. </div>
  195. </div>
  196. <div class="jt-drawing-row">
  197. <div class="col-left">是否边框</div>
  198. <div class="col-main">
  199. <el-switch v-model="model.showSilhouette" />
  200. </div>
  201. </div>
  202. <div class="jt-drawing-row" v-show="model.showSilhouette">
  203. <div class="col-left">边框颜色</div>
  204. <div class="col-main">
  205. <el-config-provider :locale="locale">
  206. <el-color-picker v-model="model.silhouetteColor" show-alpha :predefine="predefineColors" label="12" />
  207. </el-config-provider>
  208. </div>
  209. </div>
  210. <div class="jt-drawing-row" v-show="model.showSilhouette">
  211. <div class="col-left">边框宽度</div>
  212. <div class="col-main">
  213. <el-input-number v-model="model.silhouetteSize" :step="1" :min="0" :max="100" />
  214. </div>
  215. </div>
  216. </el-collapse-item>
  217. </el-collapse>
  218. </div>
  219. <div class="el-body-foot">
  220. <el-button-group>
  221. <el-button type="primary" :icon="Edit" @click="submit()">修改</el-button>
  222. <el-button type="primary" style="background-color: rgb(222, 146, 47);" :icon="Delete" @click="remove()">删除</el-button>
  223. <el-button type="primary" style="background-color: rgb(126, 128, 135);" :icon="Close" @click="close()">关闭</el-button>
  224. </el-button-group>
  225. </div>
  226. </el-scrollbar>
  227. </template>
  228. </el-dialog>
  229. </div>
  230. </template>
  231. <script setup>
  232. /* 引入ref和reactive 其中ref用于简单类型 reactive用于复杂类型 */
  233. import {
  234. computed,
  235. ref,
  236. reactive,
  237. toRefs,
  238. watch,
  239. getCurrentInstance
  240. } from 'vue';
  241. /* 引入element-plus字体包 */
  242. import zhCn from 'element-plus/dist/locale/zh-cn.mjs';
  243. import en from 'element-plus/dist/locale/en.mjs';
  244. /* 引入element-plus组件 */
  245. import {
  246. ElDialog,
  247. ElInput,
  248. ElSelect,
  249. ElOption,
  250. ElSwitch,
  251. ElButtonGroup,
  252. ElConfigProvider,
  253. ElColorPicker,
  254. ElRadioButton,
  255. ElButton,
  256. ElRadioGroup,
  257. ElInputNumber,
  258. ElCollapse,
  259. ElCollapseItem,
  260. ElIcon
  261. } from 'element-plus';
  262. /* 引入element-plus字体 */
  263. import {
  264. ArrowLeft,
  265. ArrowRight,
  266. Delete,
  267. Edit,
  268. Share,
  269. Close,
  270. Setting
  271. } from '@element-plus/icons-vue';
  272. import {
  273. param,
  274. type
  275. } from 'jquery';
  276. import DrawPoint from './DrawPoint.js';
  277. const language = ref('zh-cn');
  278. const locale = computed(() => (language.value === 'zh-cn' ? zhCn : en));
  279. const {
  280. proxy
  281. } = getCurrentInstance();
  282. const props = defineProps({
  283. params: {
  284. id: {
  285. type: String,
  286. default: () => undefined
  287. },
  288. text: {
  289. type: String,
  290. default: () => ''
  291. },
  292. font: {
  293. type: String,
  294. default: () => ''
  295. },
  296. fontSize: {
  297. type: Number,
  298. default: () => 24
  299. },
  300. color: {
  301. type: String,
  302. default: () => '255,255,0,0.9'
  303. },
  304. },
  305. showDialog: {
  306. type: Boolean,
  307. default: () => false
  308. }
  309. });
  310. const emit = defineEmits(['submit', 'update:showDialog', 'update:params', 'remove']);
  311. /* 默认颜色 */
  312. const predefineColors = ref([
  313. '#ff4500',
  314. '#ff8c00',
  315. '#ffd700',
  316. '#90ee90',
  317. '#00ced1',
  318. '#1e90ff',
  319. '#c71585',
  320. 'rgba(255, 69, 0, 0.68)',
  321. 'rgb(255, 120, 0)',
  322. 'hsv(51, 100, 98)',
  323. 'hsva(120, 40, 94, 0.5)',
  324. 'hsl(181, 100%, 37%)',
  325. 'hsla(209, 100%, 56%, 0.73)',
  326. '#c7158577'
  327. ]);
  328. /* 字体下拉列表 */
  329. const selectOptionsFont = [{
  330. value: 'Helvetica',
  331. label: '默认字体',
  332. }, {
  333. value: 'Microsoft YaHei',
  334. label: '微软雅黑',
  335. },
  336. {
  337. value: '宋体',
  338. label: '宋体',
  339. },
  340. {
  341. value: '楷体',
  342. label: '楷体',
  343. },
  344. {
  345. value: '隶书',
  346. label: '隶书',
  347. },
  348. {
  349. value: '黑体',
  350. label: '黑体',
  351. },
  352. ]
  353. /* 初始赋值 */
  354. const activeNames = ref(['1']);
  355. const title = ref('属性编辑');
  356. const dialogVisible = ref(props.showDialog);
  357. const isShowLabelStyle = ref(false);
  358. const isShowPointStyle = ref(false);
  359. const isShowBillboardStyle = ref(false);
  360. const isShowModelStyle = ref(false);
  361. /* 文字 */
  362. const label = ref({
  363. content: '',//文字内容
  364. font: '',//文字字体
  365. fontSize: 0,//文字字体大小
  366. bolder: false,//文字是否加粗
  367. italic: false,//文字是否倾斜
  368. fillColor: '',//文字颜色
  369. showOutline: false,//是否显示描边线
  370. outlineColor: '',//描边线颜色
  371. outlineWidth: 0,//描边线宽度
  372. showBackground: false,//是否显示背景
  373. backgroundColor: '',//背景颜色
  374. backgroundPadding: 0,//以像素为单位指定水平和垂直背景填充。
  375. pixelOffsetX: 0,//横向偏移像素
  376. pixelOffsetY: 0//纵向偏移像素
  377. });
  378. /* 点 */
  379. const point = ref({
  380. color: '',//点颜色
  381. pixelSize: 10,//点像素大小
  382. showOutline: false,//是否显示描边线
  383. outlineColor: '',//描边线颜色
  384. outlineWidth: 0,//描边线宽度
  385. });
  386. /* 广告牌图片 */
  387. const billboard = ref({
  388. imgUrl: '',//图片路径
  389. alpha: 1,//透明度
  390. scale: 1,//放大比例
  391. });
  392. /* 模型 */
  393. const model = ref({
  394. url: '',//模型路径
  395. alpha: 1, // 模型透明度
  396. showSilhouette:false,//是否显示模型轮廓
  397. silhouetteSize:0,//模型轮廓宽度
  398. silhouetteColor: 'rgba(255,255,255,1)', //模型轮廓颜色
  399. minimumPixelSize: 1, // 模型最小刻度
  400. maximumScale: 1, // 模型的最大比例尺大小,设置模型最大放大大小
  401. heading: 0.0, // 以弧度为单位的航向分量
  402. pitch: 0.0, //以弧度为单位的螺距分量
  403. roll: 0.0, // 以弧度为单位的滚动分量
  404. });
  405. /* 初始化根据传递的属性更新 */
  406. updateParams(props.params);
  407. /**
  408. * 根据参数更新内容
  409. * @param {JSON} params 参数
  410. */
  411. function updateParams(params) {
  412. /* 保存到本地 */
  413. proxy._params = params;
  414. _setShowControls(false);
  415. /* 根据参数的显示不同的内容 */
  416. if (params.id === DrawPoint.DrawType.Label) {
  417. title.value = '文字编辑';
  418. activeNames.value = ['标注样式'];
  419. isShowLabelStyle.value = true;
  420. label.value.content = params.label.text;
  421. label.value.font = params.label.font;
  422. label.value.fontSize = params.label.fontSize;
  423. label.value.fillColor = params.label.fillColor;
  424. label.value.showOutline = params.label.showOutline;
  425. label.value.outlineColor = params.label.outlineColor;
  426. label.value.outlineWidth = params.label.outlineWidth;
  427. label.value.showBackground = params.label.showBackground;
  428. label.value.backgroundColor = params.label.backgroundColor;
  429. label.value.backgroundPadding = params.label.backgroundPadding;
  430. label.value.pixelOffsetX = params.label.pixelOffsetX;
  431. label.value.pixelOffsetY = params.label.pixelOffsetY;
  432. } else if (params.id === DrawPoint.DrawType.Point) {
  433. title.value = '点编辑';
  434. activeNames.value = ['点样式'];
  435. isShowPointStyle.value = true;
  436. point.value.color = params.point.color;
  437. point.value.pixelSize = params.point.pixelSize;
  438. point.value.showOutline = params.point.showOutline;
  439. point.value.outlineColor = params.point.outlineColor;
  440. point.value.outlineWidth = params.point.outlineWidth;
  441. } else if (params.id === DrawPoint.DrawType.Point2Label) {
  442. title.value = '点及文字编辑';
  443. activeNames.value = ['点样式', '标注样式'];
  444. isShowPointStyle.value = true;
  445. isShowLabelStyle.value = true;
  446. point.value.color = params.point.color;
  447. point.value.pixelSize = params.point.pixelSize;
  448. point.value.showOutline = params.point.showOutline;
  449. point.value.outlineColor = params.point.outlineColor;
  450. point.value.outlineWidth = params.point.outlineWidth;
  451. label.value.content = params.label.text;
  452. label.value.font = params.label.font;
  453. label.value.fontSize = params.label.fontSize;
  454. label.value.fillColor = params.label.fillColor;
  455. label.value.showOutline = params.label.showOutline;
  456. label.value.outlineColor = params.label.outlineColor;
  457. label.value.outlineWidth = params.label.outlineWidth;
  458. label.value.showBackground = params.label.showBackground;
  459. label.value.backgroundColor = params.label.backgroundColor;
  460. label.value.backgroundPadding = params.label.backgroundPadding;
  461. label.value.pixelOffsetX = params.label.pixelOffsetX;
  462. label.value.pixelOffsetY = params.label.pixelOffsetY;
  463. } else if (params.id === DrawPoint.DrawType.Billboard) {
  464. title.value = '广告牌编辑';
  465. activeNames.value = ['图片样式'];
  466. isShowBillboardStyle.value = true;
  467. billboard.value.imgUrl = params.billboard.imgUrl;
  468. billboard.value.alpha = params.billboard.alpha;
  469. billboard.value.scale = params.billboard.scale;
  470. } else if (params.id === DrawPoint.DrawType.Billboard2Label) {
  471. title.value = '广告牌及文字圆编辑';
  472. activeNames.value = ['图片样式', '标注样式'];
  473. isShowBillboardStyle.value = true;
  474. isShowLabelStyle.value = true;
  475. billboard.value.imgUrl = params.billboard.imgUrl;
  476. billboard.value.alpha = params.billboard.alpha;
  477. billboard.value.scale = params.billboard.scale;
  478. label.value.content = params.label.text;
  479. label.value.font = params.label.font;
  480. label.value.fontSize = params.label.fontSize;
  481. label.value.fillColor = params.label.fillColor;
  482. label.value.showOutline = params.label.showOutline;
  483. label.value.outlineColor = params.label.outlineColor;
  484. label.value.outlineWidth = params.label.outlineWidth;
  485. label.value.showBackground = params.label.showBackground;
  486. label.value.backgroundColor = params.label.backgroundColor;
  487. label.value.backgroundPadding = params.label.backgroundPadding;
  488. label.value.pixelOffsetX = params.label.pixelOffsetX;
  489. label.value.pixelOffsetY = params.label.pixelOffsetY;
  490. }else if (params.id === DrawPoint.DrawType.Model) {
  491. title.value = '小模型编辑';
  492. activeNames.value = ['小模型样式'];
  493. isShowModelStyle.value = true;
  494. model.value.url = params.model.url;
  495. model.value.alpha= params.model.alpha;
  496. model.value.showSilhouette= params.model.showSilhouette;
  497. model.value.silhouetteColor= params.model.silhouetteColor;
  498. model.value.silhouetteSize= params.model.silhouetteSize;
  499. model.value.minimumPixelSize= params.model.minimumPixelSize;
  500. model.value.maximumScale= params.model.maximumScale;
  501. model.value.heading= params.model.heading;
  502. model.value.pitch= params.model.pitch;
  503. model.value.roll= params.model.roll;
  504. }
  505. }
  506. /**
  507. * 显示控件设置
  508. * @param {Boolean} isShow 是否显示
  509. */
  510. function _setShowControls(isShow) {
  511. isShowLabelStyle.value = isShow;
  512. isShowPointStyle.value = isShow;
  513. isShowBillboardStyle.value = isShow;
  514. isShowModelStyle.value = isShow;
  515. }
  516. /**
  517. * 提交更改
  518. */
  519. function submit() {
  520. let outParam = proxy._params;
  521. outParam = {
  522. id: outParam.id,
  523. label: {
  524. text: label.value.content,
  525. font: label.value.font,
  526. fontSize: label.value.fontSize,
  527. bolder: label.value.bolder,
  528. italic: label.value.italic,
  529. fillColor: label.value.fillColor,
  530. showOutline: label.value.showOutline,
  531. outlineWidth: label.value.outlineWidth,
  532. outlineColor: label.value.outlineColor,
  533. showBackground: label.value.showBackground,
  534. backgroundColor: label.value.backgroundColor,
  535. backgroundPadding: label.value.backgroundPadding,
  536. pixelOffsetX: label.value.pixelOffsetX,
  537. pixelOffsetY: label.value.pixelOffsetY,
  538. },
  539. point: {
  540. color: point.value.color,
  541. pixelSize: point.value.pixelSize,
  542. showOutline: point.value.showOutline,
  543. outlineWidth: point.value.outlineWidth,
  544. outlineColor: point.value.outlineColor,
  545. },
  546. billboard: {
  547. imgUrl: billboard.value.imgUrl,
  548. alpha: billboard.value.alpha,
  549. scale: billboard.value.scale,
  550. },
  551. model:{
  552. url: model.value.url,
  553. alpha: model.value.alpha,
  554. showSilhouette:model.value.showSilhouette,
  555. silhouetteColor: model.value.silhouetteColor,
  556. silhouetteSize: model.value.silhouetteSize,
  557. minimumPixelSize: model.value.minimumPixelSize,
  558. maximumScale: model.value.maximumScale,
  559. heading: model.value.heading,
  560. pitch: model.value.pitch,
  561. roll: model.value.roll,
  562. }
  563. }
  564. emit('submit', outParam);
  565. }
  566. /**
  567. * 关闭
  568. */
  569. function close() {
  570. dialogVisible.value = false;
  571. }
  572. /**
  573. * 提交删除
  574. */
  575. function remove() {
  576. emit('remove', {});
  577. dialogVisible.value = false;
  578. }
  579. /**
  580. * 窗口关闭,修改双向绑定值
  581. */
  582. function closeDialog() {
  583. emit('update:showDialog', false);
  584. }
  585. /**
  586. * 窗口打开
  587. */
  588. function openDialog() {
  589. updateParams(props.params);
  590. }
  591. </script>
  592. <style lang="scss">
  593. /* 引入element-plus的内部样式 必须在此处引入 否则无效 */
  594. /* 为了保证引入的样式文件起作用 必须保证文件名称以.ce.vue结束 */
  595. @import 'element-plus/theme-chalk/index.css';
  596. //组件内部样式
  597. .el-button {
  598. height: 32rem !important;
  599. padding: 8rem 15rem !important;
  600. font-size: 14rem !important;
  601. }
  602. .el-input__wrapper {
  603. padding: 1rem 11rem !important;
  604. }
  605. .el-input {
  606. height: 32rem !important;
  607. font-size: 14rem !important;
  608. }
  609. .el-input-number {
  610. line-height: 30rem !important;
  611. width: 150rem;
  612. }
  613. .el-input-number__decrease,
  614. .el-input-number__increase {
  615. top: 1rem !important;
  616. bottom: 1rem !important;
  617. width: 32rem !important;
  618. font-size: 13rem !important;
  619. background-color: rgb(64 158 255);
  620. }
  621. .jt-drawing-row .col-left {
  622. font-size: 14rem !important;
  623. }
  624. .el-color-picker__trigger {
  625. height: 32rem !important;
  626. padding: 4rem !important;
  627. }
  628. .el-radio-button__inner {
  629. padding: 8rem 15rem !important;
  630. font-size: 14rem;
  631. }
  632. .el-textarea__inner {
  633. padding: 5rem 11rem !important;
  634. font-size: 14rem;
  635. }
  636. .el-input__inner {
  637. height: 32rem !important;
  638. font-size: 14rem !important;
  639. }
  640. //取消边框剪切
  641. .el-scrollbar {
  642. // background-color: gainsboro !important;
  643. color: #fff !important;
  644. background-color: rgba(5, 45, 115, 1) !important;
  645. overflow: visible !important;
  646. }
  647. /* 墙对话框内容行样式 */
  648. .jt-drawing-row {
  649. display: flex;
  650. flex-direction: row;
  651. height: 40rem;
  652. align-items: center;
  653. /* 行左侧标题样式 */
  654. .col-left {
  655. display: flex;
  656. align-items: center;
  657. justify-content: right;
  658. width: 60rem;
  659. font-family: 'Alimama_ShuHeiTi_Bold';
  660. font-weight: bold;
  661. margin-right: 8rem;
  662. }
  663. /* 主要内容样式 */
  664. .col-main {
  665. flex: 1;
  666. display: flex;
  667. flex-direction: row;
  668. .el-input--suffix {
  669. background-color: rgba(255, 255, 255, 0);
  670. }
  671. .el-input--suffix * {
  672. background-color: rgba(255, 255, 255, 0);
  673. color: rgba(255, 255, 255, 1);
  674. }
  675. /* 数字组件按钮背景色 */
  676. .el-input-number__decrease,
  677. .el-input-number__increase {
  678. background-color: rgb(64 158 255);
  679. color: rgb(255, 255, 255);
  680. }
  681. }
  682. }
  683. /* 墙对话框整体样式 */
  684. .jt-drawing-dialog {
  685. pointer-events: none; // ***覆盖层元素增加可穿透点击事件***
  686. .el-dialog {
  687. pointer-events: auto; // ***弹窗层元素不可穿透点击事件(不影响弹窗层元素的点击事件)***
  688. position: absolute !important; //将通知框的position改成absolute,可以在某个div进行显示
  689. background: rgb(5 45 155 / 70%);
  690. min-width: 280rem;
  691. overflow: hidden;
  692. left: 10rem;
  693. background: rgb(0 44 126 / 68%);
  694. height: calc(100% - 175rem);
  695. width: 180rem;
  696. top: 125rem;
  697. margin-top: 0rem;
  698. /* 对话框标题头样式 */
  699. .el-dialog__header {
  700. background: url() no-repeat;
  701. background-size: 100%;
  702. margin-right: 0rem;
  703. padding: 6rem;
  704. text-align: center;
  705. }
  706. /* 对话框关闭按钮的样式 */
  707. .el-dialog__headerbtn {
  708. height: 34rem;
  709. }
  710. .content {
  711. height: calc(100% - 120rem);
  712. width: 92%;
  713. overflow-y: auto;
  714. padding: 5rem 0 0 0;
  715. position: absolute;
  716. }
  717. .el-collapse {
  718. --el-collapse-border-color: rgb(0 44 126 / 0%);
  719. --el-collapse-header-text-color: #ffffff;
  720. --el-collapse-header-font-size: 13rem;
  721. --el-collapse-content-bg-color: rgb(0 44 126 / 0%);
  722. --el-collapse-content-font-size: 13rem;
  723. --el-collapse-content-text-color: rgb(216 240 255);
  724. --el-collapse-header-height: 40rem;
  725. --el-collapse-header-bg-color: rgb(30 130 255);
  726. .el-collapse-item__header {
  727. background-color: rgb(64 158 255);
  728. border-bottom: 2px solid rgb(22 90 190);
  729. }
  730. .el-collapse-item__content {
  731. padding: 10rem;
  732. // height: calc(100% - 200rem);
  733. // overflow-y: auto;
  734. }
  735. }
  736. /* 对话框主体的样式 */
  737. .el-dialog__body {
  738. padding: 10rem;
  739. color: #fff;
  740. }
  741. /* 颜色选择器的宽度 */
  742. .el-color-picker__trigger {
  743. width: 120rem;
  744. }
  745. /* 底部按钮容器样式 */
  746. .el-body-foot {
  747. position: absolute;
  748. bottom: 8rem;
  749. right: 8rem;
  750. width: calc(100% - 16rem);
  751. }
  752. /* 底部容器内分组容器样式 */
  753. .el-body-foot .el-button-group {
  754. display: flex;
  755. }
  756. /* 底部容器内按钮样式 */
  757. .el-body-foot .el-button-group .el-button {
  758. border: solid 0rem rgb(255, 0, 0);
  759. flex: 1;
  760. }
  761. }
  762. }
  763. </style>