123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855 |
- <template>
- <div class="jt-drawing-dialog">
- <el-dialog :modal="false" :destroy-on-close="false" v-model="dialogVisible" :title="title" @close="closeDialog" @open="openDialog" :show-close="false">
- <template #header>
- <div slot="title" class="header-title">
- <span style="line-height:24rem;font-size:16rem;color:#fff;font-family: 'Alimama_ShuHeiTi_Bold'">{{ title }}</span>
- </div>
- </template>
- <template #default>
- <el-scrollbar>
- <div class="content">
- <el-collapse v-model="activeNames">
- <el-collapse-item name="标注样式" v-show="isShowLabelStyle">
- <template #title>
- <el-icon style="padding: 10rem;">
- <Setting />
- </el-icon>标注样式
- </template>
- <div class="jt-drawing-row" style="height: 60rem;">
- <div class="col-left">内容</div>
- <div class="col-main">
- <el-input v-model="label.content" placeholder="输入显示的文字内容" clearable type="textarea" :rows="2" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">字体</div>
- <div class="col-main">
- <el-select v-model="label.font" placeholder="请选择">
- <el-option v-for="item in selectOptionsFont" :key="item.value" :label="item.label" :value="item.value" />
- </el-select>
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">字体大小</div>
- <div class="col-main">
- <el-input-number v-model="label.fontSize" :min="0" :max="100" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">是否加粗</div>
- <div class="col-main">
- <el-switch v-model="label.bolder" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">是否斜体</div>
- <div class="col-main">
- <el-switch v-model="label.italic" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="label.fillColor" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">是否边框</div>
- <div class="col-main">
- <el-switch v-model="label.showOutline" />
- </div>
- </div>
- <div class="jt-drawing-row" v-show="label.showOutline">
- <div class="col-left">边框颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="label.outlineColor" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div>
- <div class="jt-drawing-row" v-show="label.showOutline">
- <div class="col-left">边框宽度</div>
- <div class="col-main">
- <el-input-number v-model="label.outlineWidth" :min="0" :max="100" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">是否背景</div>
- <div class="col-main">
- <el-switch v-model="label.showBackground" />
- </div>
- </div>
- <div class="jt-drawing-row" v-show="label.showBackground">
- <div class="col-left">背景颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="label.backgroundColor" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div>
- <div class="jt-drawing-row" v-show="label.showBackground">
- <div class="col-left">背景内边距</div>
- <div class="col-main">
- <el-input-number v-model="label.backgroundPadding" :min="-100" :max="100" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">横向偏移像素</div>
- <div class="col-main">
- <el-input-number v-model="label.pixelOffsetX" :min="-100" :max="100" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">纵向偏移像素</div>
- <div class="col-main">
- <el-input-number v-model="label.pixelOffsetY" :min="-100" :max="100" />
- </div>
- </div>
- </el-collapse-item>
- <el-collapse-item name="点样式" v-show="isShowPointStyle">
- <template #title>
- <el-icon style="padding: 10rem;">
- <Setting />
- </el-icon>点样式
- </template>
- <div class="jt-drawing-row">
- <div class="col-left">像素大小</div>
- <div class="col-main">
- <el-input-number v-model="point.pixelSize" :min="0" :max="100" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="point.color" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">是否边框</div>
- <div class="col-main">
- <el-switch v-model="point.showOutline" />
- </div>
- </div>
- <div class="jt-drawing-row" v-show="point.showOutline">
- <div class="col-left">边框颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="point.outlineColor" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div>
- <div class="jt-drawing-row" v-show="point.showOutline">
- <div class="col-left">边框宽度</div>
- <div class="col-main">
- <el-input-number v-model="point.outlineWidth" :min="0" :max="100" />
- </div>
- </div>
- </el-collapse-item>
- <el-collapse-item name="图片样式" v-show="isShowBillboardStyle">
- <template #title>
- <el-icon style="padding: 10rem;">
- <Setting />
- </el-icon>图片样式
- </template>
- <div class="jt-drawing-row" style="height: 60rem;">
- <div class="col-left">图标</div>
- <div class="col-main">
- <el-input v-model="billboard.imgUrl" placeholder="输入图标路径" clearable type="textarea" :rows="2" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">大小比例</div>
- <div class="col-main">
- <el-input-number v-model="billboard.scale" :min="1" :max="100" />
- </div>
- </div>
- </el-collapse-item>
- <el-collapse-item name="小模型样式" v-show="isShowModelStyle">
- <template #title>
- <el-icon style="padding: 10rem;">
- <Setting />
- </el-icon>小模型样式
- </template>
- <div class="jt-drawing-row" style="height: 60rem;">
- <div class="col-left">模型路径</div>
- <div class="col-main">
- <el-input v-model="model.url" placeholder="输入模型路径" clearable type="textarea" :rows="2" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">透明度</div>
- <div class="col-main">
- <el-input-number v-model="model.alpha" :step="0.1" :min="0" :max="1" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">最小像素大小</div>
- <div class="col-main">
- <el-input-number v-model="model.minimumPixelSize" :step="1" :min="0" :max="20000" />
- </div>
- </div>
- <div class="jt-drawing-row">
- <div class="col-left">是否边框</div>
- <div class="col-main">
- <el-switch v-model="model.showSilhouette" />
- </div>
- </div>
- <div class="jt-drawing-row" v-show="model.showSilhouette">
- <div class="col-left">边框颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="model.silhouetteColor" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div>
- <div class="jt-drawing-row" v-show="model.showSilhouette">
- <div class="col-left">边框宽度</div>
- <div class="col-main">
- <el-input-number v-model="model.silhouetteSize" :step="1" :min="0" :max="100" />
- </div>
- </div>
- </el-collapse-item>
- </el-collapse>
- </div>
- <div class="el-body-foot">
- <el-button-group>
- <el-button type="primary" :icon="Edit" @click="submit()">修改</el-button>
- <el-button type="primary" style="background-color: rgb(222, 146, 47);" :icon="Delete" @click="remove()">删除</el-button>
- <el-button type="primary" style="background-color: rgb(126, 128, 135);" :icon="Close" @click="close()">关闭</el-button>
- </el-button-group>
- </div>
- </el-scrollbar>
- </template>
- </el-dialog>
- </div>
- </template>
- <script setup>
- /* 引入ref和reactive 其中ref用于简单类型 reactive用于复杂类型 */
- import {
- computed,
- ref,
- reactive,
- toRefs,
- watch,
- getCurrentInstance
- } from 'vue';
- /* 引入element-plus字体包 */
- import zhCn from 'element-plus/dist/locale/zh-cn.mjs';
- import en from 'element-plus/dist/locale/en.mjs';
- /* 引入element-plus组件 */
- import {
- ElDialog,
- ElInput,
- ElSelect,
- ElOption,
- ElSwitch,
- ElButtonGroup,
- ElConfigProvider,
- ElColorPicker,
- ElRadioButton,
- ElButton,
- ElRadioGroup,
- ElInputNumber,
- ElCollapse,
- ElCollapseItem,
- ElIcon
- } from 'element-plus';
- /* 引入element-plus字体 */
- import {
- ArrowLeft,
- ArrowRight,
- Delete,
- Edit,
- Share,
- Close,
- Setting
- } from '@element-plus/icons-vue';
- import {
- param,
- type
- } from 'jquery';
- import DrawPoint from './DrawPoint.js';
- const language = ref('zh-cn');
- const locale = computed(() => (language.value === 'zh-cn' ? zhCn : en));
- const {
- proxy
- } = getCurrentInstance();
- const props = defineProps({
- params: {
- id: {
- type: String,
- default: () => undefined
- },
- text: {
- type: String,
- default: () => ''
- },
- font: {
- type: String,
- default: () => ''
- },
- fontSize: {
- type: Number,
- default: () => 24
- },
- color: {
- type: String,
- default: () => '255,255,0,0.9'
- },
- },
- showDialog: {
- type: Boolean,
- default: () => false
- }
- });
- const emit = defineEmits(['submit', 'update:showDialog', 'update:params', 'remove']);
- /* 默认颜色 */
- const predefineColors = ref([
- '#ff4500',
- '#ff8c00',
- '#ffd700',
- '#90ee90',
- '#00ced1',
- '#1e90ff',
- '#c71585',
- 'rgba(255, 69, 0, 0.68)',
- 'rgb(255, 120, 0)',
- 'hsv(51, 100, 98)',
- 'hsva(120, 40, 94, 0.5)',
- 'hsl(181, 100%, 37%)',
- 'hsla(209, 100%, 56%, 0.73)',
- '#c7158577'
- ]);
- /* 字体下拉列表 */
- const selectOptionsFont = [{
- value: 'Helvetica',
- label: '默认字体',
- }, {
- value: 'Microsoft YaHei',
- label: '微软雅黑',
- },
- {
- value: '宋体',
- label: '宋体',
- },
- {
- value: '楷体',
- label: '楷体',
- },
- {
- value: '隶书',
- label: '隶书',
- },
- {
- value: '黑体',
- label: '黑体',
- },
- ]
- /* 初始赋值 */
- const activeNames = ref(['1']);
- const title = ref('属性编辑');
- const dialogVisible = ref(props.showDialog);
- const isShowLabelStyle = ref(false);
- const isShowPointStyle = ref(false);
- const isShowBillboardStyle = ref(false);
- const isShowModelStyle = ref(false);
- /* 文字 */
- const label = ref({
- content: '',//文字内容
-
- font: '',//文字字体
- fontSize: 0,//文字字体大小
- bolder: false,//文字是否加粗
- italic: false,//文字是否倾斜
- fillColor: '',//文字颜色
-
- showOutline: false,//是否显示描边线
- outlineColor: '',//描边线颜色
- outlineWidth: 0,//描边线宽度
-
- showBackground: false,//是否显示背景
- backgroundColor: '',//背景颜色
- backgroundPadding: 0,//以像素为单位指定水平和垂直背景填充。
-
- pixelOffsetX: 0,//横向偏移像素
- pixelOffsetY: 0//纵向偏移像素
- });
- /* 点 */
- const point = ref({
- color: '',//点颜色
- pixelSize: 10,//点像素大小
- showOutline: false,//是否显示描边线
- outlineColor: '',//描边线颜色
- outlineWidth: 0,//描边线宽度
- });
- /* 广告牌图片 */
- const billboard = ref({
- imgUrl: '',//图片路径
- alpha: 1,//透明度
- scale: 1,//放大比例
- });
-
- /* 模型 */
- const model = ref({
- url: '',//模型路径
- alpha: 1, // 模型透明度
-
- showSilhouette:false,//是否显示模型轮廓
- silhouetteSize:0,//模型轮廓宽度
- silhouetteColor: 'rgba(255,255,255,1)', //模型轮廓颜色
-
- minimumPixelSize: 1, // 模型最小刻度
- maximumScale: 1, // 模型的最大比例尺大小,设置模型最大放大大小
-
- heading: 0.0, // 以弧度为单位的航向分量
- pitch: 0.0, //以弧度为单位的螺距分量
- roll: 0.0, // 以弧度为单位的滚动分量
- });
- /* 初始化根据传递的属性更新 */
- updateParams(props.params);
- /**
- * 根据参数更新内容
- * @param {JSON} params 参数
- */
- function updateParams(params) {
- /* 保存到本地 */
- proxy._params = params;
- _setShowControls(false);
- /* 根据参数的显示不同的内容 */
- if (params.id === DrawPoint.DrawType.Label) {
- title.value = '文字编辑';
- activeNames.value = ['标注样式'];
- isShowLabelStyle.value = true;
- label.value.content = params.label.text;
- label.value.font = params.label.font;
- label.value.fontSize = params.label.fontSize;
- label.value.fillColor = params.label.fillColor;
- label.value.showOutline = params.label.showOutline;
- label.value.outlineColor = params.label.outlineColor;
- label.value.outlineWidth = params.label.outlineWidth;
- label.value.showBackground = params.label.showBackground;
- label.value.backgroundColor = params.label.backgroundColor;
- label.value.backgroundPadding = params.label.backgroundPadding;
- label.value.pixelOffsetX = params.label.pixelOffsetX;
- label.value.pixelOffsetY = params.label.pixelOffsetY;
- } else if (params.id === DrawPoint.DrawType.Point) {
- title.value = '点编辑';
- activeNames.value = ['点样式'];
- isShowPointStyle.value = true;
- point.value.color = params.point.color;
- point.value.pixelSize = params.point.pixelSize;
- point.value.showOutline = params.point.showOutline;
- point.value.outlineColor = params.point.outlineColor;
- point.value.outlineWidth = params.point.outlineWidth;
- } else if (params.id === DrawPoint.DrawType.Point2Label) {
- title.value = '点及文字编辑';
- activeNames.value = ['点样式', '标注样式'];
- isShowPointStyle.value = true;
- isShowLabelStyle.value = true;
- point.value.color = params.point.color;
- point.value.pixelSize = params.point.pixelSize;
- point.value.showOutline = params.point.showOutline;
- point.value.outlineColor = params.point.outlineColor;
- point.value.outlineWidth = params.point.outlineWidth;
- label.value.content = params.label.text;
- label.value.font = params.label.font;
- label.value.fontSize = params.label.fontSize;
- label.value.fillColor = params.label.fillColor;
- label.value.showOutline = params.label.showOutline;
- label.value.outlineColor = params.label.outlineColor;
- label.value.outlineWidth = params.label.outlineWidth;
- label.value.showBackground = params.label.showBackground;
- label.value.backgroundColor = params.label.backgroundColor;
- label.value.backgroundPadding = params.label.backgroundPadding;
- label.value.pixelOffsetX = params.label.pixelOffsetX;
- label.value.pixelOffsetY = params.label.pixelOffsetY;
- } else if (params.id === DrawPoint.DrawType.Billboard) {
- title.value = '广告牌编辑';
- activeNames.value = ['图片样式'];
- isShowBillboardStyle.value = true;
- billboard.value.imgUrl = params.billboard.imgUrl;
- billboard.value.alpha = params.billboard.alpha;
- billboard.value.scale = params.billboard.scale;
- } else if (params.id === DrawPoint.DrawType.Billboard2Label) {
- title.value = '广告牌及文字圆编辑';
- activeNames.value = ['图片样式', '标注样式'];
- isShowBillboardStyle.value = true;
- isShowLabelStyle.value = true;
- billboard.value.imgUrl = params.billboard.imgUrl;
- billboard.value.alpha = params.billboard.alpha;
- billboard.value.scale = params.billboard.scale;
- label.value.content = params.label.text;
- label.value.font = params.label.font;
- label.value.fontSize = params.label.fontSize;
- label.value.fillColor = params.label.fillColor;
- label.value.showOutline = params.label.showOutline;
- label.value.outlineColor = params.label.outlineColor;
- label.value.outlineWidth = params.label.outlineWidth;
- label.value.showBackground = params.label.showBackground;
- label.value.backgroundColor = params.label.backgroundColor;
- label.value.backgroundPadding = params.label.backgroundPadding;
- label.value.pixelOffsetX = params.label.pixelOffsetX;
- label.value.pixelOffsetY = params.label.pixelOffsetY;
- }else if (params.id === DrawPoint.DrawType.Model) {
- title.value = '小模型编辑';
- activeNames.value = ['小模型样式'];
- isShowModelStyle.value = true;
- model.value.url = params.model.url;
- model.value.alpha= params.model.alpha;
- model.value.showSilhouette= params.model.showSilhouette;
- model.value.silhouetteColor= params.model.silhouetteColor;
- model.value.silhouetteSize= params.model.silhouetteSize;
- model.value.minimumPixelSize= params.model.minimumPixelSize;
- model.value.maximumScale= params.model.maximumScale;
- model.value.heading= params.model.heading;
- model.value.pitch= params.model.pitch;
- model.value.roll= params.model.roll;
- }
- }
- /**
- * 显示控件设置
- * @param {Boolean} isShow 是否显示
- */
- function _setShowControls(isShow) {
- isShowLabelStyle.value = isShow;
- isShowPointStyle.value = isShow;
- isShowBillboardStyle.value = isShow;
- isShowModelStyle.value = isShow;
- }
- /**
- * 提交更改
- */
- function submit() {
- let outParam = proxy._params;
- outParam = {
- id: outParam.id,
- label: {
- text: label.value.content,
- font: label.value.font,
- fontSize: label.value.fontSize,
- bolder: label.value.bolder,
- italic: label.value.italic,
- fillColor: label.value.fillColor,
- showOutline: label.value.showOutline,
- outlineWidth: label.value.outlineWidth,
- outlineColor: label.value.outlineColor,
- showBackground: label.value.showBackground,
- backgroundColor: label.value.backgroundColor,
- backgroundPadding: label.value.backgroundPadding,
- pixelOffsetX: label.value.pixelOffsetX,
- pixelOffsetY: label.value.pixelOffsetY,
- },
- point: {
- color: point.value.color,
- pixelSize: point.value.pixelSize,
- showOutline: point.value.showOutline,
- outlineWidth: point.value.outlineWidth,
- outlineColor: point.value.outlineColor,
- },
- billboard: {
- imgUrl: billboard.value.imgUrl,
- alpha: billboard.value.alpha,
- scale: billboard.value.scale,
- },
- model:{
- url: model.value.url,
- alpha: model.value.alpha,
-
- showSilhouette:model.value.showSilhouette,
- silhouetteColor: model.value.silhouetteColor,
- silhouetteSize: model.value.silhouetteSize,
-
- minimumPixelSize: model.value.minimumPixelSize,
- maximumScale: model.value.maximumScale,
-
- heading: model.value.heading,
- pitch: model.value.pitch,
- roll: model.value.roll,
- }
- }
- emit('submit', outParam);
- }
- /**
- * 关闭
- */
- function close() {
- dialogVisible.value = false;
- }
- /**
- * 提交删除
- */
- function remove() {
- emit('remove', {});
- dialogVisible.value = false;
- }
- /**
- * 窗口关闭,修改双向绑定值
- */
- function closeDialog() {
- emit('update:showDialog', false);
- }
- /**
- * 窗口打开
- */
- function openDialog() {
- updateParams(props.params);
- }
- </script>
- <style lang="scss">
- /* 引入element-plus的内部样式 必须在此处引入 否则无效 */
- /* 为了保证引入的样式文件起作用 必须保证文件名称以.ce.vue结束 */
- @import 'element-plus/theme-chalk/index.css';
- //组件内部样式
- .el-button {
- height: 32rem !important;
- padding: 8rem 15rem !important;
- font-size: 14rem !important;
- }
- .el-input__wrapper {
- padding: 1rem 11rem !important;
- }
- .el-input {
- height: 32rem !important;
- font-size: 14rem !important;
- }
- .el-input-number {
- line-height: 30rem !important;
- width: 150rem;
- }
- .el-input-number__decrease,
- .el-input-number__increase {
- top: 1rem !important;
- bottom: 1rem !important;
- width: 32rem !important;
- font-size: 13rem !important;
- background-color: rgb(64 158 255);
- }
- .jt-drawing-row .col-left {
- font-size: 14rem !important;
- }
- .el-color-picker__trigger {
- height: 32rem !important;
- padding: 4rem !important;
- }
- .el-radio-button__inner {
- padding: 8rem 15rem !important;
- font-size: 14rem;
- }
- .el-textarea__inner {
- padding: 5rem 11rem !important;
- font-size: 14rem;
- }
- .el-input__inner {
- height: 32rem !important;
- font-size: 14rem !important;
- }
- //取消边框剪切
- .el-scrollbar {
- // background-color: gainsboro !important;
- color: #fff !important;
- background-color: rgba(5, 45, 115, 1) !important;
- overflow: visible !important;
- }
- /* 墙对话框内容行样式 */
- .jt-drawing-row {
- display: flex;
- flex-direction: row;
- height: 40rem;
- align-items: center;
- /* 行左侧标题样式 */
- .col-left {
- display: flex;
- align-items: center;
- justify-content: right;
- width: 60rem;
- font-family: 'Alimama_ShuHeiTi_Bold';
- font-weight: bold;
- margin-right: 8rem;
- }
- /* 主要内容样式 */
- .col-main {
- flex: 1;
- display: flex;
- flex-direction: row;
- .el-input--suffix {
- background-color: rgba(255, 255, 255, 0);
- }
- .el-input--suffix * {
- background-color: rgba(255, 255, 255, 0);
- color: rgba(255, 255, 255, 1);
- }
- /* 数字组件按钮背景色 */
- .el-input-number__decrease,
- .el-input-number__increase {
- background-color: rgb(64 158 255);
- color: rgb(255, 255, 255);
- }
- }
- }
- /* 墙对话框整体样式 */
- .jt-drawing-dialog {
- pointer-events: none; // ***覆盖层元素增加可穿透点击事件***
- .el-dialog {
- pointer-events: auto; // ***弹窗层元素不可穿透点击事件(不影响弹窗层元素的点击事件)***
- position: absolute !important; //将通知框的position改成absolute,可以在某个div进行显示
- background: rgb(5 45 155 / 70%);
- min-width: 280rem;
- overflow: hidden;
- left: 10rem;
- background: rgb(0 44 126 / 68%);
- height: calc(100% - 175rem);
- width: 180rem;
- top: 125rem;
- margin-top: 0rem;
- /* 对话框标题头样式 */
- .el-dialog__header {
- background: url() no-repeat;
- background-size: 100%;
- margin-right: 0rem;
- padding: 6rem;
- text-align: center;
- }
- /* 对话框关闭按钮的样式 */
- .el-dialog__headerbtn {
- height: 34rem;
- }
- .content {
- height: calc(100% - 120rem);
- width: 92%;
- overflow-y: auto;
- padding: 5rem 0 0 0;
- position: absolute;
- }
- .el-collapse {
- --el-collapse-border-color: rgb(0 44 126 / 0%);
- --el-collapse-header-text-color: #ffffff;
- --el-collapse-header-font-size: 13rem;
- --el-collapse-content-bg-color: rgb(0 44 126 / 0%);
- --el-collapse-content-font-size: 13rem;
- --el-collapse-content-text-color: rgb(216 240 255);
- --el-collapse-header-height: 40rem;
- --el-collapse-header-bg-color: rgb(30 130 255);
- .el-collapse-item__header {
- background-color: rgb(64 158 255);
- border-bottom: 2px solid rgb(22 90 190);
- }
- .el-collapse-item__content {
- padding: 10rem;
- // height: calc(100% - 200rem);
- // overflow-y: auto;
- }
- }
- /* 对话框主体的样式 */
- .el-dialog__body {
- padding: 10rem;
- color: #fff;
- }
- /* 颜色选择器的宽度 */
- .el-color-picker__trigger {
- width: 120rem;
- }
- /* 底部按钮容器样式 */
- .el-body-foot {
- position: absolute;
- bottom: 8rem;
- right: 8rem;
- width: calc(100% - 16rem);
- }
- /* 底部容器内分组容器样式 */
- .el-body-foot .el-button-group {
- display: flex;
- }
- /* 底部容器内按钮样式 */
- .el-body-foot .el-button-group .el-button {
- border: solid 0rem rgb(255, 0, 0);
- flex: 1;
- }
- }
- }
- </style>
|