Commit e390e7e1054c0c8002297a1dd293f09192a168ca

Authored by xp.Huang
2 parents f553bc83 fe832ca0

Merge branch 'ft' into 'main_dev'

feat(src/packages/): 小组件小标题新增小标题9和装饰11,12;三维模型新增设置模型位置,旋转位置,灯光配置,label标点配置(支持多个label)

See merge request yunteng/thingskit-view!106
Showing 20 changed files with 884 additions and 55 deletions
... ... @@ -17,7 +17,7 @@ export const option = {
17 17
18 18 export default class Config extends PublicConfigClass implements CreateComponentType {
19 19 public key = Decorates07Config.key
20   - public attr = { ...chartInitConfig, zIndex: 1, w: 230, h: 225 }
  20 + public attr = { ...chartInitConfig, zIndex: 1, w: 200, h: 200 }
21 21 public chartConfig = cloneDeep(Decorates07Config)
22 22 public option = cloneDeep(option)
23 23 }
... ...
... ... @@ -17,7 +17,7 @@ export const option = {
17 17
18 18 export default class Config extends PublicConfigClass implements CreateComponentType {
19 19 public key = Decorates08Config.key
20   - public attr = { ...chartInitConfig, zIndex: 1, w: 390, h: 400 }
  20 + public attr = { ...chartInitConfig, zIndex: 1, w: 200, h: 200 }
21 21 public chartConfig = cloneDeep(Decorates08Config)
22 22 public option = cloneDeep(option)
23 23 }
... ...
  1 +import { PublicConfigClass } from '@/packages/public'
  2 +import { CreateComponentType } from '@/packages/index.d'
  3 +import { Decorates11Config } from './index'
  4 +import cloneDeep from 'lodash/cloneDeep'
  5 +import { chartInitConfig } from '@/settings/designSetting'
  6 +
  7 +export const option = {
  8 + dataset: '',
  9 + attribute: {
  10 + bgColor1:'#00e0db',
  11 + bgColor2:'#66ffff',
  12 + }
  13 +}
  14 +
  15 +export default class Config extends PublicConfigClass implements CreateComponentType {
  16 + public key = Decorates11Config.key
  17 + public attr = { ...chartInitConfig, zIndex: 1, w: 200, h: 200 }
  18 + public chartConfig = cloneDeep(Decorates11Config)
  19 + public option = cloneDeep(option)
  20 +}
... ...
  1 +<template>
  2 + <CollapseItem name="配置" :expanded="true">
  3 + <SettingItemBox :name="`装饰1`">
  4 + <SettingItem name="颜色">
  5 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor1"></n-color-picker>
  6 + </SettingItem>
  7 + <SettingItem>
  8 + <n-button size="small" @click="optionData.attribute.bgColor1 = '#00e0db'"> 恢复默认 </n-button>
  9 + </SettingItem>
  10 + </SettingItemBox>
  11 + <SettingItemBox :name="`装饰2`">
  12 + <SettingItem name="颜色">
  13 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor2"></n-color-picker>
  14 + </SettingItem>
  15 + <SettingItem>
  16 + <n-button size="small" @click="optionData.attribute.bgColor2 = '#66ffff'"> 恢复默认 </n-button>
  17 + </SettingItem>
  18 + </SettingItemBox>
  19 + </CollapseItem>
  20 +</template>
  21 +
  22 +<script setup lang="ts">
  23 +import { PropType } from 'vue'
  24 +import { option } from './config'
  25 +import { CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
  26 +
  27 +defineProps({
  28 + optionData: {
  29 + type: Object as PropType<typeof option>,
  30 + required: true
  31 + }
  32 +})
  33 +</script>
... ...
  1 +import { ChatCategoryEnum, ChatCategoryEnumName } from '../../index.d'
  2 +import { ConfigType, PackagesCategoryEnum, ChartFrameEnum } from '@/packages/index.d'
  3 +import { useWidgetKey } from '@/packages/external/useWidgetKey'
  4 +
  5 +const { key, chartKey, conKey } = useWidgetKey('Decorates11',true)
  6 +
  7 +export const Decorates11Config: ConfigType = {
  8 + key,
  9 + chartKey,
  10 + conKey,
  11 + title: '装饰11',
  12 + category: ChatCategoryEnum.DECORATE,
  13 + categoryName: ChatCategoryEnumName.DECORATE,
  14 + package: PackagesCategoryEnum.DECORATES,
  15 + chartFrame: ChartFrameEnum.COMMON,
  16 + image: 'decorates10.png',
  17 +}
... ...
  1 +<template>
  2 + <div class="go-content-box">
  3 + <svg
  4 + xmlns="http://www.w3.org/2000/svg"
  5 + xmlns:xlink="http://www.w3.org/1999/xlink"
  6 + :width="w"
  7 + :height="h"
  8 + viewBox="0 0 270 270"
  9 + fill="none"
  10 + >
  11 + <g opacity="1" transform="translate(3 3) rotate(0)">
  12 + <g opacity="1" transform="translate(0 0) rotate(0)">
  13 + <g opacity="1" transform="translate(0 0) rotate(0)">
  14 + <g opacity="1" transform="translate(0 0) rotate(0)">
  15 + <path
  16 + id="位图"
  17 + fill-rule="evenodd"
  18 + style="fill: url(#decorates11_pattern0)"
  19 + d="M12 251.62L251.62 251.62L251.62 12L12 12L12 251.62Z"
  20 + />
  21 + <g id="椭圆形" filter="url(#decorates11_filter_5)">
  22 + <path
  23 + id="椭圆形"
  24 + :style="{fill: attribute.bgColor1,opacity: 0.8}"
  25 + d="M261,132c0,-8.794 -0.87367,-17.46 -2.621,-25.998c-1.70267,-8.3188 -4.20833,-16.38833 -7.517,-24.2086c-3.248,-7.6788 -7.21267,-14.98253 -11.894,-21.9112c-4.63733,-6.86373 -9.88933,-13.2286 -15.756,-19.0946c-5.866,-5.86613 -12.23067,-11.11787 -19.094,-15.7552c-6.92867,-4.68133 -14.23233,-8.6462 -21.911,-11.8946c-7.82,-3.30819 -15.88967,-5.81369 -24.209,-7.51648c-8.538,-1.74755 -17.204,-2.62132 -25.998,-2.62132c-8.794,0 -17.46,0.87377 -25.998,2.62131c-8.319,1.7028 -16.38853,4.2083 -24.2086,7.51649c-7.6788,3.2484 -14.98253,7.21327 -21.9112,11.8946c-6.86367,4.63733 -13.22853,9.88907 -19.0946,15.7552c-5.86613,5.86607 -11.11787,12.23093 -15.7552,19.0946c-4.68133,6.92867 -8.6462,14.2324 -11.8946,21.9112c-3.30819,7.82007 -5.81368,15.8896 -7.51648,24.2086c-1.74755,8.538 -2.62132,17.204 -2.62132,25.998c0,8.794 0.87377,17.46 2.62131,25.998c1.70279,8.31933 4.20829,16.389 7.51649,24.209c3.24833,7.67867 7.2132,14.98233 11.8946,21.911c4.63733,6.86333 9.88907,13.228 15.7552,19.094c5.86607,5.866 12.23093,11.118 19.0946,15.756c6.92867,4.68133 14.2324,8.646 21.9112,11.894c7.82027,3.30867 15.8898,5.81433 24.2086,7.517c8.538,1.74733 17.204,2.621 25.998,2.621c8.794,0 17.46,-0.87367 25.998,-2.621c8.31867,-1.70267 16.38833,-4.20833 24.209,-7.517c7.67867,-3.248 14.98233,-7.21267 21.911,-11.894c6.86333,-4.63733 13.228,-9.88933 19.094,-15.756c5.86667,-5.866 11.11867,-12.23067 15.756,-19.094c4.68133,-6.92867 8.646,-14.23233 11.894,-21.911c3.30867,-7.82067 5.81433,-15.89033 7.517,-24.209c1.74733,-8.538 2.621,-17.204 2.621,-25.998zM267,132c0,9.19867 -0.91433,18.26567 -2.743,27.201c-1.78267,8.70867 -4.40567,17.15633 -7.869,25.343c-3.4,8.03733 -7.54967,15.68167 -12.449,22.933c-4.852,7.18133 -10.34667,13.84067 -16.484,19.978c-6.13733,6.13733 -12.79667,11.632 -19.978,16.484c-7.25133,4.89933 -14.89567,9.049 -22.933,12.449c-8.18667,3.46333 -16.63433,6.08633 -25.343,7.869c-8.93533,1.82867 -18.00233,2.743 -27.201,2.743c-9.19867,0 -18.26567,-0.91433 -27.201,-2.743c-8.7088,-1.78267 -17.15657,-4.40567 -25.3433,-7.869c-8.0372,-3.4 -15.6814,-7.54967 -22.9326,-12.449c-7.18147,-4.852 -13.84087,-10.34667 -19.9782,-16.484c-6.13733,-6.13733 -11.63203,-12.79667 -16.4841,-19.978c-4.89927,-7.25133 -9.0489,-14.89567 -12.4489,-22.933c-3.46323,-8.18667 -6.08613,-16.63433 -7.86872,-25.343c-1.82879,-8.93467 -2.74318,-18.00167 -2.74318,-27.201c0,-9.19933 0.9144,-18.26633 2.74319,-27.201c1.7826,-8.70893 4.4055,-17.1567 7.86872,-25.3433c3.39999,-8.0372 7.54962,-15.6814 12.44889,-22.9326c4.85213,-7.18147 10.34683,-13.84087 16.4841,-19.9782c6.13733,-6.13733 12.79673,-11.63203 19.9782,-16.4841c7.25127,-4.89927 14.89547,-9.0489 22.9326,-12.4489c8.1866,-3.46322 16.63437,-6.08613 25.3433,-7.86872c8.93467,-1.82879 18.00167,-2.74318 27.201,-2.74318c9.19933,0 18.26633,0.9144 27.201,2.74319c8.70867,1.78258 17.15633,4.40549 25.343,7.86872c8.03733,3.39999 15.68167,7.54962 22.933,12.44889c7.18133,4.85207 13.84067,10.34677 19.978,16.4841c6.13733,6.13727 11.632,12.79667 16.484,19.9782c4.89933,7.25113 9.049,14.89533 12.449,22.9326c3.46333,8.18673 6.08633,16.6345 7.869,25.3433c1.82867,8.93533 2.743,18.00233 2.743,27.201z"
  26 + />
  27 + </g>
  28 + </g>
  29 + </g>
  30 + </g>
  31 + <g opacity="1" transform="translate(88.3564453125 58.359130859375) rotate(0)">
  32 + <path
  33 + id="矩形"
  34 + fill-rule="evenodd"
  35 + :style="{fill: attribute.bgColor2}"
  36 + opacity="0"
  37 + d="M0 87.26L87.26 87.26L87.26 0L0 0L0 87.26Z"
  38 + />
  39 + </g>
  40 + </g>
  41 + <defs>
  42 + <pattern id="decorates11_pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
  43 + <use
  44 + transform="translate(0 0) scale(0.002702702702702703 0.002702702702702703) rotate(0)"
  45 + xlink:href="#image0"
  46 + />
  47 + </pattern>
  48 + <image
  49 + transform="rotate(0 185 185)"
  50 + id="image0"
  51 + width="370"
  52 + height="370"
  53 + xlink:href=""
  54 + />
  55 + <filter
  56 + id="decorates11_filter_5"
  57 + x="0"
  58 + y="0"
  59 + width="264"
  60 + height="264"
  61 + filterUnits="userSpaceOnUse"
  62 + color-interpolation-filters="sRGB"
  63 + >
  64 + <feFlood flood-opacity="0" result="feFloodId" />
  65 + <feBlend mode="normal" in="SourceGraphic" in2="decorates11_filter_5" result="shape" />
  66 + </filter>
  67 + </defs>
  68 + </svg>
  69 + </div>
  70 +</template>
  71 +<script setup lang="ts">
  72 +import { PropType, toRefs } from 'vue'
  73 +import { CreateComponentType } from '@/packages/index.d'
  74 +
  75 +const props = defineProps({
  76 + chartConfig: {
  77 + type: Object as PropType<CreateComponentType>,
  78 + required: true
  79 + }
  80 +})
  81 +
  82 +const { attribute } = toRefs(props.chartConfig.option)
  83 +
  84 +const { w, h } = toRefs(props.chartConfig.attr)
  85 +</script>
  86 +
  87 +<style lang="scss" scoped>
  88 +.go-content-box {
  89 + width: v-bind('w+"px"');
  90 + height: v-bind('h+"px"');
  91 + display: flex;
  92 + align-items: center;
  93 + justify-content: center;
  94 +}
  95 +</style>
... ...
  1 +import { PublicConfigClass } from '@/packages/public'
  2 +import { CreateComponentType } from '@/packages/index.d'
  3 +import { Decorates12Config } from './index'
  4 +import cloneDeep from 'lodash/cloneDeep'
  5 +import { chartInitConfig } from '@/settings/designSetting'
  6 +
  7 +export const option = {
  8 + dataset: '',
  9 + attribute: {
  10 + bgColor1:'#FF8045',
  11 + bgColor2:'#FFFFFF',
  12 + }
  13 +}
  14 +
  15 +export default class Config extends PublicConfigClass implements CreateComponentType {
  16 + public key = Decorates12Config.key
  17 + public attr = { ...chartInitConfig, zIndex: 1, w: 200, h: 200 }
  18 + public chartConfig = cloneDeep(Decorates12Config)
  19 + public option = cloneDeep(option)
  20 +}
... ...
  1 +<template>
  2 + <CollapseItem name="配置" :expanded="true">
  3 + <SettingItemBox :name="`装饰1`">
  4 + <SettingItem name="颜色">
  5 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor1"></n-color-picker>
  6 + </SettingItem>
  7 + <SettingItem>
  8 + <n-button size="small" @click="optionData.attribute.bgColor1 = '#FF8045'"> 恢复默认 </n-button>
  9 + </SettingItem>
  10 + </SettingItemBox>
  11 + <SettingItemBox :name="`装饰2`">
  12 + <SettingItem name="颜色">
  13 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor2"></n-color-picker>
  14 + </SettingItem>
  15 + <SettingItem>
  16 + <n-button size="small" @click="optionData.attribute.bgColor2 = '#FFFFFF'"> 恢复默认 </n-button>
  17 + </SettingItem>
  18 + </SettingItemBox>
  19 + </CollapseItem>
  20 +</template>
  21 +
  22 +<script setup lang="ts">
  23 +import { PropType } from 'vue'
  24 +import { option } from './config'
  25 +import { CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
  26 +
  27 +defineProps({
  28 + optionData: {
  29 + type: Object as PropType<typeof option>,
  30 + required: true
  31 + }
  32 +})
  33 +</script>
... ...
  1 +import { ChatCategoryEnum, ChatCategoryEnumName } from '../../index.d'
  2 +import { ConfigType, PackagesCategoryEnum, ChartFrameEnum } from '@/packages/index.d'
  3 +import { useWidgetKey } from '@/packages/external/useWidgetKey'
  4 +
  5 +const { key, chartKey, conKey } = useWidgetKey('Decorates12',true)
  6 +
  7 +export const Decorates12Config: ConfigType = {
  8 + key,
  9 + chartKey,
  10 + conKey,
  11 + title: '装饰12',
  12 + category: ChatCategoryEnum.DECORATE,
  13 + categoryName: ChatCategoryEnumName.DECORATE,
  14 + package: PackagesCategoryEnum.DECORATES,
  15 + chartFrame: ChartFrameEnum.COMMON,
  16 + image: 'decorates10.png',
  17 +}
... ...
  1 +<template>
  2 + <div class="go-content-box">
  3 + <svg
  4 + xmlns="http://www.w3.org/2000/svg"
  5 + xmlns:xlink="http://www.w3.org/1999/xlink"
  6 + :width="w"
  7 + :height="h"
  8 + viewBox="0 0 224 376"
  9 + fill="none"
  10 + >
  11 + <g opacity="1" transform="translate(0 0.001220703125) rotate(0)">
  12 + <g opacity="1" transform="translate(0 0) rotate(0)">
  13 + <path
  14 + id="矩形"
  15 + fill-rule="evenodd"
  16 + fill="url(#decorates12_linear_0)"
  17 + opacity="0.46"
  18 + d="M46.9482 38.8088L46.9482 264.179L46.9482 264.179C88.0582 280.529 133.868 280.469 174.938 264.029L178.038 262.789L178.038 38.2088C178.038 17.1688 160.868 0.178779 139.828 0.408779L84.3382 1.00878C63.6182 1.22878 46.9482 18.0888 46.9482 38.8088Z"
  19 + />
  20 + <path
  21 + id="矩形"
  22 + fill-rule="evenodd"
  23 + fill="url(#decorates12_linear_1)"
  24 + opacity="0.46"
  25 + d="M5.23877 39.1888L5.23877 299.189L7.29877 300.619C71.6488 345.299 157.469 343.369 219.749 295.849L219.749 295.849L219.749 38.0988C219.749 17.1088 202.639 0.128779 181.649 0.298779L42.7388 1.38878C21.9788 1.54878 5.23877 18.4288 5.23877 39.1888Z"
  26 + />
  27 + <path
  28 + id="椭圆形"
  29 + style="fill: url(#linear_2); opacity: 100"
  30 + d="M176.132,255.616c0,-0.672 -0.19567,-1.38533 -0.587,-2.14c-0.53133,-1.026 -1.384,-2.08767 -2.558,-3.185c-1.36533,-1.276 -3.085,-2.52067 -5.159,-3.734c-2.202,-1.28867 -4.727,-2.49567 -7.575,-3.621c-2.936,-1.16133 -6.13933,-2.20533 -9.61,-3.132c-3.556,-0.95 -7.31467,-1.75633 -11.276,-2.419c-8.324,-1.39267 -17.059,-2.089 -26.205,-2.089c-9.1442,0 -17.87737,0.69633 -26.1995,2.089c-3.96093,0.66267 -7.7192,1.469 -11.2748,2.419c-3.47027,0.92667 -6.6732,1.97033 -9.6088,3.131c-2.84733,1.126 -5.37187,2.33333 -7.5736,3.622c-2.07413,1.21333 -3.79387,2.458 -5.1592,3.734c-1.174,1.09733 -2.02673,2.159 -2.5582,3.185c-0.39087,0.75467 -0.5863,1.468 -0.5863,2.14c0,0.674 0.1956,1.38867 0.5868,2.144c0.53153,1.02733 1.38423,2.08933 2.5581,3.186c1.36513,1.276 3.08467,2.52067 5.1586,3.734c2.20153,1.288 4.72593,2.495 7.5732,3.621c2.9354,1.16 6.1383,2.20333 9.6087,3.13c3.55547,0.95 7.31373,1.756 11.2748,2.418c8.3216,1.39133 17.055,2.087 26.2002,2.087c9.14733,0 17.88233,-0.69567 26.205,-2.087c3.962,-0.662 7.721,-1.468 11.277,-2.418c3.47067,-0.92667 6.674,-1.97 9.61,-3.13c2.84733,-1.126 5.372,-2.333 7.574,-3.621c2.074,-1.21333 3.79367,-2.458 5.159,-3.734c1.174,-1.09733 2.02667,-2.15933 2.558,-3.186c0.39133,-0.75533 0.587,-1.47 0.587,-2.144zM191.252,255.616c0,3.128 -0.76,6.15967 -2.28,9.095c-1.33067,2.57067 -3.21767,4.998 -5.661,7.282c-2.18733,2.04333 -4.80333,3.956 -7.848,5.738c-2.868,1.678 -6.085,3.22167 -9.651,4.631c-3.478,1.37467 -7.23367,2.60067 -11.267,3.678c-4.02067,1.07333 -8.24867,1.98067 -12.684,2.722c-9.14867,1.52933 -18.715,2.294 -28.699,2.294c-9.98207,0 -19.54663,-0.76467 -28.6937,-2.294c-4.4352,-0.74133 -8.66273,-1.649 -12.6826,-2.723c-4.03327,-1.07667 -7.78853,-2.30233 -11.2658,-3.677c-3.5656,-1.40933 -6.7825,-2.95333 -9.6507,-4.632c-3.04447,-1.78133 -5.66007,-3.69367 -7.8468,-5.737c-2.4438,-2.284 -4.331,-4.71133 -5.6616,-7.282c-1.51947,-2.93533 -2.2792,-5.967 -2.2792,-9.095c0,-3.12667 0.7599,-6.15767 2.2797,-9.093c1.3306,-2.56933 3.21777,-4.99567 5.6615,-7.279c2.1866,-2.04333 4.80203,-3.95567 7.8463,-5.737c2.86813,-1.67867 6.08487,-3.22267 9.6502,-4.632c3.47733,-1.37533 7.23257,-2.60167 11.2657,-3.679c4.02007,-1.074 8.2476,-1.982 12.6826,-2.724c9.14807,-1.53067 18.71287,-2.296 28.6944,-2.296c9.98333,0 19.54967,0.76533 28.699,2.296c4.436,0.742 8.66433,1.65 12.685,2.724c4.03333,1.07733 7.78867,2.30367 11.266,3.679c3.566,1.40933 6.783,2.95333 9.651,4.632c3.04467,1.78133 5.66033,3.69367 7.847,5.737c2.444,2.28333 4.33133,4.70967 5.662,7.279c1.52,2.93533 2.28,5.96633 2.28,9.093z"
  31 + />
  32 + <path
  33 + id="椭圆形"
  34 + style="fill: url(#linear_3); opacity: 100"
  35 + d="M215.49,294.977c0,-1.79467 -0.47533,-3.614 -1.426,-5.458c-1.07467,-2.08467 -2.72567,-4.17233 -4.953,-6.263c-2.398,-2.25067 -5.378,-4.42267 -8.94,-6.516c-3.67533,-2.15933 -7.86867,-4.17433 -12.58,-6.045c-4.79867,-1.90533 -10.02367,-3.616 -15.675,-5.132c-5.75733,-1.54467 -11.83667,-2.85467 -18.238,-3.93c-6.55067,-1.1 -13.31567,-1.93367 -20.295,-2.501c-7.178,-0.58333 -14.46567,-0.875 -21.863,-0.875c-7.396,0 -14.68253,0.29167 -21.8596,0.875c-6.9786,0.56733 -13.74263,1.401 -20.2921,2.501c-6.4008,1.07533 -12.47963,2.38533 -18.2365,3.93c-5.65067,1.516 -10.87547,3.22667 -15.6744,5.132c-4.71073,1.87067 -8.9035,3.88567 -12.5783,6.045c-3.56193,2.09333 -6.54197,4.26533 -8.9401,6.516c-2.22753,2.09067 -3.87861,4.17833 -4.95323,6.263c-0.95051,1.844 -1.42577,3.66333 -1.42577,5.458c0,1.79533 0.47526,3.615 1.42577,5.459c1.07462,2.084 2.7257,4.17133 4.95323,6.262c2.39813,2.25133 5.37817,4.42367 8.9401,6.517c3.6748,2.15933 7.86757,4.17433 12.5783,6.045c4.79893,1.90533 10.02373,3.616 15.6744,5.132c5.75687,1.544 11.8357,2.85367 18.2365,3.929c6.5494,1.1 13.31343,1.93367 20.2921,2.501c7.17707,0.58333 14.4636,0.875 21.8596,0.875c7.39733,0 14.685,-0.29167 21.863,-0.875c6.97933,-0.56733 13.74433,-1.401 20.295,-2.501c6.40133,-1.07533 12.48067,-2.385 18.238,-3.929c5.65133,-1.516 10.87633,-3.22667 15.675,-5.132c4.71133,-1.87067 8.90467,-3.886 12.58,-6.046c3.562,-2.09267 6.542,-4.26467 8.94,-6.516c2.22733,-2.09067 3.87833,-4.178 4.953,-6.262c0.95067,-1.844 1.426,-3.66367 1.426,-5.459zM230.61,294.977c0,4.24067 -1.03567,8.36967 -3.107,12.387c-1.87,3.62733 -4.55167,7.08033 -8.045,10.359c-3.21867,3.02133 -7.09433,5.86367 -11.627,8.527c-4.34267,2.552 -9.22933,4.906 -14.66,7.062c-5.34267,2.12133 -11.122,4.01567 -17.338,5.683c-6.22333,1.67 -12.77367,3.08233 -19.651,4.237c-6.97467,1.172 -14.166,2.059 -21.574,2.661c-7.586,0.616 -15.282,0.924 -23.088,0.924c-7.80507,0 -15.4999,-0.308 -23.0845,-0.924c-7.40747,-0.602 -14.5981,-1.489 -21.5719,-2.661c-6.8768,-1.15467 -13.4267,-2.567 -19.6497,-4.237c-6.21533,-1.66733 -11.9941,-3.56167 -17.3363,-5.683c-5.4304,-2.156 -10.3168,-4.51 -14.6592,-7.062c-4.53237,-2.66333 -8.40797,-5.50567 -11.62682,-8.527c-3.49333,-3.27867 -6.17502,-6.73167 -8.04508,-10.359c-2.071,-4.01733 -3.1065,-8.14633 -3.1065,-12.387c0,-4.24 1.0355,-8.36867 3.1065,-12.386c1.87006,-3.628 4.55175,-7.08133 8.04508,-10.36c3.21885,-3.02067 7.09446,-5.863 11.62682,-8.527c4.3424,-2.552 9.2288,-4.906 14.6592,-7.062c5.34227,-2.12133 11.12103,-4.01567 17.3363,-5.683c6.22307,-1.66933 12.77297,-3.08167 19.6497,-4.237c6.9738,-1.17133 14.16443,-2.058 21.5719,-2.66c7.5846,-0.61667 15.27943,-0.925 23.0845,-0.925c7.806,0 15.502,0.30833 23.088,0.925c7.408,0.602 14.59933,1.48867 21.574,2.66c6.87733,1.15533 13.42767,2.56767 19.651,4.237c6.216,1.66733 11.99533,3.56167 17.338,5.683c5.43067,2.156 10.31733,4.51 14.66,7.062c4.53267,2.664 8.40833,5.50633 11.627,8.527c3.49333,3.27867 6.175,6.732 8.045,10.36c2.07133,4.01733 3.107,8.146 3.107,12.386z"
  36 + />
  37 + </g>
  38 + </g>
  39 + <defs>
  40 + <linearGradient
  41 + id="decorates12_linear_0"
  42 + x1="50%"
  43 + y1="11.74083535829661%"
  44 + x2="51%"
  45 + y2="97.23011363636364%"
  46 + gradientUnits="objectBoundingBox"
  47 + >
  48 + <stop offset="0" :stop-color="attribute.bgColor1" stop-opacity="0" />
  49 + <stop offset="1" :stop-color="attribute.bgColor1" stop-opacity="1" />
  50 + </linearGradient>
  51 + <linearGradient
  52 + id="decorates12_linear_1"
  53 + x1="50%"
  54 + y1="10.347697845478384%"
  55 + x2="51%"
  56 + y2="97.23011363636364%"
  57 + gradientUnits="objectBoundingBox"
  58 + >
  59 + <stop offset="0" :stop-color="attribute.bgColor1" stop-opacity="0" />
  60 + <stop offset="0.5286331641542819" :stop-color="attribute.bgColor1" stop-opacity="0.53" />
  61 + <stop offset="1" :stop-color="attribute.bgColor1" stop-opacity="1" />
  62 + </linearGradient>
  63 + <linearGradient
  64 + id="linear_2"
  65 + x1="50%"
  66 + y1="11.147280092598066%"
  67 + x2="51%"
  68 + y2="39.858217592598066%"
  69 + gradientUnits="objectBoundingBox"
  70 + >
  71 + <stop offset="0" :stop-color="attribute.bgColor1" stop-opacity="1" />
  72 + <stop offset="1" :stop-color="attribute.bgColor1" stop-opacity="1" />
  73 + </linearGradient>
  74 + <linearGradient
  75 + id="linear_3"
  76 + x1="50%"
  77 + y1="12.028811281136091%"
  78 + x2="51%"
  79 + y2="39.57430808169881%"
  80 + gradientUnits="objectBoundingBox"
  81 + >
  82 + <stop offset="0" :stop-color="attribute.bgColor2" stop-opacity="0.15" />
  83 + <stop offset="1" :stop-color="attribute.bgColor1" stop-opacity="1" />
  84 + </linearGradient>
  85 + </defs>
  86 + </svg>
  87 + </div>
  88 +</template>
  89 +<script setup lang="ts">
  90 +import { PropType, toRefs } from 'vue'
  91 +import { CreateComponentType } from '@/packages/index.d'
  92 +
  93 +const props = defineProps({
  94 + chartConfig: {
  95 + type: Object as PropType<CreateComponentType>,
  96 + required: true
  97 + }
  98 +})
  99 +
  100 +const { attribute } = toRefs(props.chartConfig.option)
  101 +
  102 +const { w, h } = toRefs(props.chartConfig.attr)
  103 +</script>
  104 +
  105 +<style lang="scss" scoped>
  106 +.go-content-box {
  107 + width: v-bind('w+"px"');
  108 + height: v-bind('h+"px"');
  109 + display: flex;
  110 + align-items: center;
  111 + justify-content: center;
  112 +}
  113 +</style>
... ...
  1 +import { PublicConfigClass } from '@/packages/public'
  2 +import { CreateComponentType } from '@/packages/index.d'
  3 +import { Subtitle9Config } from './index'
  4 +import cloneDeep from 'lodash/cloneDeep'
  5 +import { chartInitConfig } from '@/settings/designSetting'
  6 +
  7 +export const option = {
  8 + dataset: '我是标题',
  9 + attribute: {
  10 + bgColor1:'#21649C',
  11 + bgColor2:'#060F1E',
  12 + bgColor3:'#2387D9',
  13 + bgColor4:'#000F1B',
  14 + bgColor5:'#2affff',
  15 + bgColor6:'#ffcc33',
  16 + bgColor7:'#000f1b',
  17 + fontSize: 20,
  18 + fontPos: {
  19 + x: 0,
  20 + y: 20
  21 + },
  22 + fontColor: '#2AFFFF'
  23 + }
  24 +}
  25 +
  26 +export default class Config extends PublicConfigClass implements CreateComponentType {
  27 + public key = Subtitle9Config.key
  28 + public attr = { ...chartInitConfig, zIndex: 1, w: 550, h: 60 }
  29 + public chartConfig = cloneDeep(Subtitle9Config)
  30 + public option = cloneDeep(option)
  31 +}
... ...
  1 +<template>
  2 + <CollapseItem name="配置" :expanded="true">
  3 + <SettingItemBox name="标题">
  4 + <SettingItem name="内容">
  5 + <n-input v-model:value="optionData.dataset" />
  6 + </SettingItem>
  7 + <SettingItem name="大小">
  8 + <n-input-number v-model:value="optionData.attribute.fontSize" />
  9 + </SettingItem>
  10 + <SettingItem name="x轴位置">
  11 + <n-input-number v-model:value="optionData.attribute.fontPos.x" />
  12 + </SettingItem>
  13 + <SettingItem name="y轴位置">
  14 + <n-input-number v-model:value="optionData.attribute.fontPos.y" />
  15 + </SettingItem>
  16 + <SettingItem name="颜色">
  17 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.fontColor"></n-color-picker>
  18 + </SettingItem>
  19 + <SettingItem name="颜色">
  20 + <n-button size="small" @click="optionData.attribute.fontColor = '#2AFFFF'"> 恢复默认 </n-button>
  21 + </SettingItem>
  22 + </SettingItemBox>
  23 + <SettingItemBox :name="`左边背景装饰`">
  24 + <SettingItem name="颜色">
  25 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor1"></n-color-picker>
  26 + </SettingItem>
  27 + <SettingItem>
  28 + <n-button size="small" @click="optionData.attribute.bgColor1 = '#21649C'"> 恢复默认 </n-button>
  29 + </SettingItem>
  30 + </SettingItemBox>
  31 + <SettingItemBox :name="`右边背景装饰`">
  32 + <SettingItem name="颜色">
  33 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor2"></n-color-picker>
  34 + </SettingItem>
  35 + <SettingItem>
  36 + <n-button size="small" @click="optionData.attribute.bgColor2 = '#060F1E'"> 恢复默认 </n-button>
  37 + </SettingItem>
  38 + </SettingItemBox>
  39 + <SettingItemBox :name="`左边线装饰`">
  40 + <SettingItem name="颜色">
  41 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor3"></n-color-picker>
  42 + </SettingItem>
  43 + <SettingItem>
  44 + <n-button size="small" @click="optionData.attribute.bgColor3 = '#2387D9'"> 恢复默认 </n-button>
  45 + </SettingItem>
  46 + </SettingItemBox>
  47 + <SettingItemBox :name="`上下边线装饰`">
  48 + <SettingItem name="颜色">
  49 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor4"></n-color-picker>
  50 + </SettingItem>
  51 + <SettingItem>
  52 + <n-button size="small" @click="optionData.attribute.bgColor4 = '#000F1B'"> 恢复默认 </n-button>
  53 + </SettingItem>
  54 + </SettingItemBox>
  55 + <SettingItemBox :name="`右边正方形装饰`">
  56 + <SettingItem name="颜色">
  57 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor5"></n-color-picker>
  58 + </SettingItem>
  59 + <SettingItem>
  60 + <n-button size="small" @click="optionData.attribute.bgColor5 = '#2affff'"> 恢复默认 </n-button>
  61 + </SettingItem>
  62 + </SettingItemBox>
  63 + <SettingItemBox :name="`左边图形装饰`">
  64 + <SettingItem name="颜色">
  65 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor6"></n-color-picker>
  66 + </SettingItem>
  67 + <SettingItem>
  68 + <n-button size="small" @click="optionData.attribute.bgColor5 = '#ffcc33'"> 恢复默认 </n-button>
  69 + </SettingItem>
  70 + </SettingItemBox>
  71 + <SettingItemBox :name="`左边图形边框装饰`">
  72 + <SettingItem name="颜色">
  73 + <n-color-picker size="small" :modes="['hex']" v-model:value="optionData.attribute.bgColor7"></n-color-picker>
  74 + </SettingItem>
  75 + <SettingItem>
  76 + <n-button size="small" @click="optionData.attribute.bgColor5 = '#000f1b'"> 恢复默认 </n-button>
  77 + </SettingItem>
  78 + </SettingItemBox>
  79 + </CollapseItem>
  80 +</template>
  81 +
  82 +<script setup lang="ts">
  83 +import { PropType } from 'vue'
  84 +import { option } from './config'
  85 +import { CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
  86 +
  87 +defineProps({
  88 + optionData: {
  89 + type: Object as PropType<typeof option>,
  90 + required: true
  91 + }
  92 +})
  93 +</script>
... ...
  1 +import { ChatCategoryEnum, ChatCategoryEnumName } from '../../index.d'
  2 +import { ConfigType, PackagesCategoryEnum, ChartFrameEnum } from '@/packages/index.d'
  3 +import { useWidgetKey } from '@/packages/external/useWidgetKey'
  4 +
  5 +const { key, chartKey, conKey } = useWidgetKey('Subtitle9',true)
  6 +
  7 +export const Subtitle9Config: ConfigType = {
  8 + key,
  9 + chartKey,
  10 + conKey,
  11 + title: '小标题9',
  12 + category: ChatCategoryEnum.SUBTITLE,
  13 + categoryName: ChatCategoryEnumName.SUBTITLE,
  14 + package: PackagesCategoryEnum.DECORATES,
  15 + chartFrame: ChartFrameEnum.COMMON,
  16 + image: 'title8.png',
  17 +}
... ...
  1 +<template>
  2 + <div class="go-content-box">
  3 + <svg
  4 + xmlns="http://www.w3.org/2000/svg"
  5 + xmlns:xlink="http://www.w3.org/1999/xlink"
  6 + :width="w"
  7 + :height="h"
  8 + fill="none"
  9 + >
  10 + <defs>
  11 + <linearGradient id="subtitle9_linear_0" x1="0%" y1="50%" x2="100%" y2="50%" gradientUnits="objectBoundingBox">
  12 + <stop offset="0" :stop-color="attribute.bgColor1" stop-opacity="1" />
  13 + <stop offset="1" :stop-color="attribute.bgColor2" stop-opacity="1" />
  14 + </linearGradient>
  15 + <linearGradient id="subtitle9_linear_1" x1="0%" y1="50%" x2="100%" y2="50%" gradientUnits="objectBoundingBox">
  16 + <stop offset="0" :stop-color="attribute.bgColor3" stop-opacity="1" />
  17 + <stop offset="1" :stop-color="attribute.bgColor4" stop-opacity="1" />
  18 + </linearGradient>
  19 + </defs>
  20 + <g opacity="1" transform="translate(0 0) rotate(0 247.5 17.5)">
  21 + <path
  22 + id="矩形 8"
  23 + fill-rule="evenodd"
  24 + fill="url(#subtitle9_linear_0)"
  25 + transform="translate(1.0040567951318458 0) rotate(0 246.99797160243406 17.5)"
  26 + opacity="1"
  27 + :d="`M0,${h} L${w},${h} L${w},0 L0,0 L0,${h}Z`"
  28 + />
  29 + <rect
  30 + id="矩形 8"
  31 + style="stroke: url(#subtitle9_linear_1); stroke-width: 1; stroke-opacity: 100; stroke-dasharray: 0 0"
  32 + transform="translate(1.0040567951318458 0) rotate(0 246.99797160243406 17.5)"
  33 + x="0.5"
  34 + y="0.5"
  35 + rx="0"
  36 + :width="w"
  37 + :height="h-1"
  38 + />
  39 + <path
  40 + id="矩形 10"
  41 + fill-rule="evenodd"
  42 + :style="{fill:attribute.bgColor5}"
  43 + :transform="`translate(${w-3} ${h/2-3.01/2-16/2}) rotate(0 1.5060851926977687 1.75)`"
  44 + opacity="0.5"
  45 + d="M0,3.5L3.01,3.5L3.01,0L0,0L0,3.5Z "
  46 + />
  47 + <path
  48 + id="矩形 10"
  49 + fill-rule="evenodd"
  50 + :style="{fill:attribute.bgColor5}"
  51 + :transform="`translate(${w-3} ${h/2-3.01/2-5/2}) rotate(0 1.5060851926977687 1.75)`"
  52 + opacity="1"
  53 + d="M0,3.5L3.01,3.5L3.01,0L0,0L0,3.5Z "
  54 + />
  55 + <path
  56 + id="矩形 10"
  57 + fill-rule="evenodd"
  58 + :style="{fill:attribute.bgColor5}"
  59 + :transform="`translate(${w-3} ${h/2-3.01/2+7/2}) rotate(0 1.5060851926977687 1.75)`"
  60 + opacity="0.5"
  61 + d="M0,3.5L3.01,3.5L3.01,0L0,0L0,3.5Z "
  62 + />
  63 + <g opacity="1" :transform="`translate(13.052738336713995 ${h/2-26/2}) rotate(0 46.5 15.5)`">
  64 + <text>
  65 + <tspan
  66 + :x="attribute.fontPos.x"
  67 + :y="attribute.fontPos.y"
  68 + :font-size="attribute.fontSize"
  69 + line-height="0"
  70 + :fill="attribute.fontColor"
  71 + opacity="1"
  72 + font-family="YouSheBiaoTiHei"
  73 + letter-spacing="0"
  74 + >
  75 + {{ dataset }}
  76 + </tspan>
  77 + </text>
  78 + </g>
  79 + <path
  80 + id="矩形 9"
  81 + fill-rule="evenodd"
  82 + :style="{fill:attribute.bgColor6}"
  83 + :transform="`translate(0 ${h/2-21/2}) rotate(0 2.5101419878296145 10.5)`"
  84 + opacity="1"
  85 + d="M0,21L1.02,21C3.23,21 5.02,19.21 5.02,17L5.02,4C5.02,1.79 3.23,0 1.02,0L0,0L0,21Z "
  86 + />
  87 + <path
  88 + id="矩形 9"
  89 + :style="{stroke:attribute.bgColor7,strokeWidth: 1,strokeOpacity: 1}"
  90 + :transform="`translate(0 ${h/2-21/2}) rotate(0 2.5101419878296145 10.5)`"
  91 + d="M0,21L1.02,21C3.23,21 5.02,19.21 5.02,17L5.02,4C5.02,1.79 3.23,0 1.02,0L0,0L0,21Z "
  92 + />
  93 + </g>
  94 + </svg>
  95 + </div>
  96 +</template>
  97 +<script setup lang="ts">
  98 +import { PropType, toRefs } from 'vue'
  99 +import { CreateComponentType } from '@/packages/index.d'
  100 +
  101 +const props = defineProps({
  102 + chartConfig: {
  103 + type: Object as PropType<CreateComponentType>,
  104 + required: true
  105 + }
  106 +})
  107 +
  108 +const { dataset, attribute } = toRefs(props.chartConfig.option)
  109 +
  110 +const { w, h } = toRefs(props.chartConfig.attr)
  111 +</script>
  112 +
  113 +<style lang="scss" scoped>
  114 +.go-content-box {
  115 + width: v-bind('w+"px"');
  116 + height: v-bind('h+"px"');
  117 + display: flex;
  118 + align-items: center;
  119 + justify-content: center;
  120 +}
  121 +</style>
... ...
... ... @@ -47,7 +47,7 @@ const emits = defineEmits(['fileStaticUri'])
47 47
48 48 const fileList = ref<UploadFileInfo[]>([])
49 49
50   -const fileSizeMsg = ref(`文件需小于 ${props.fileSizeConst}M;格式为${props.threeSupportFileFormat.join(',')}的文件`)
  50 +const fileSizeMsg = ref(`文件需小于 ${props.fileSizeConst}M;格式为${props.threeSupportFileFormat.join(',')}的文件,支持传多个`)
51 51
52 52 const extname = (filename: string) => {
53 53 if (!filename || typeof filename != 'string') {
... ...
... ... @@ -5,8 +5,7 @@ import cloneDeep from 'lodash/cloneDeep'
5 5 import { chartInitConfig } from '@/settings/designSetting'
6 6
7 7 export const option = {
8   - //vue3dLoader支持数组或字符串,暂且绑定字符串,这个插件可以加载多个模型
9   - dataset: new URL('/src/assets/external/three/test.obj', import.meta.url).href,
  8 + dataset: [new URL('/src/assets/external/three/test.obj', import.meta.url).href],//三维数据源
10 9 backgroundColor: '', //场景背景色
11 10 backgroundAlpha: 0, //场景透明度
12 11 enableDamping: false, //是否启用阻尼
... ... @@ -19,14 +18,77 @@ export const option = {
19 18 */
20 19 outputEncoding: 'liner',
21 20 clearScene: false, //是否清空场景内容
22   - lights: [], //灯光,暂且没实现
  21 + lights: [//灯光为数组,type 为 环境光(AmbientLight) | 方向光(DirectionalLight) | 点光(PointLight) | 半球光(HemisphereLight)
  22 + {
  23 + type: 'AmbientLight',
  24 + label: '环境光(只有颜色)',
  25 + color: 'red',
  26 + position: { x: 100, y: 10, z: 100 }
  27 + },
  28 + {
  29 + type: 'DirectionalLight',
  30 + label: '方向光(可配置颜色,发光位置,光源强度)',
  31 + color: 'green',
  32 + position: { x: 100, y: 10, z: 100 },
  33 + intensity: 0.8
  34 + },
  35 + {
  36 + type: 'PointLight',
  37 + label: '点光(可配置颜色,发光位置,光源强度)',
  38 + color: '#000000',
  39 + position: { x: 200, y: -200, z: 100 },
  40 + intensity: 1
  41 + },
  42 + {
  43 + type: 'HemisphereLight',
  44 + label: '半球光(可配置从天空发出的光线的颜色,从地面发出的光线的颜色,发光位置)',
  45 + position: { x: 200, y: -200, z: 100 },
  46 + skyColor: '#00FF00',
  47 + groundColor: '#000000'
  48 + }
  49 + ],
23 50 mtlPath: [], //.mtl材质路径,比如搭配obj使用
24 51 textureImage: [], //jpg/png 材质路径
25 52 borderConfig: {
26 53 color: 'grey',
27 54 size: 1,
28 55 show: false
29   - }
  56 + },
  57 + position: [//模型位置
  58 + {
  59 + x: 0,
  60 + y: 0,
  61 + z: 0
  62 + }
  63 + ],
  64 + rotation: [//模型旋转
  65 + {
  66 + x: 0,
  67 + y: 0,
  68 + z: 0
  69 + }
  70 + ],
  71 + showFps:false,//是否显示fps
  72 + labels:[ //添加图片/文字标签,暂且支持文字
  73 + {
  74 + image: "",
  75 + text: "",
  76 + textStyle: {
  77 + fontFamily: "Arial",
  78 + fontSize: 18,
  79 + fontWeight: "normal",
  80 + lineHeight: 1,
  81 + color: "#ffffff",
  82 + borderWidth: 8,
  83 + borderRadius: 4,
  84 + borderColor: "rgba(0,0,0,1)",
  85 + backgroundColor: "rgba(0, 0, 0, 1)"
  86 + },
  87 + position: {x:0, y:0, z:0},
  88 + scale:{x:1, y:1, z:0},
  89 + sid: null
  90 + }
  91 + ]
30 92 }
31 93
32 94 export default class Config extends PublicConfigClass implements CreateComponentType {
... ...
... ... @@ -4,42 +4,55 @@
4 4 <setting-item name="颜色">
5 5 <n-color-picker size="small" :show-alpha="false" v-model:value="optionData.borderConfig.color"></n-color-picker>
6 6 </setting-item>
7   - <setting-item name="开启">
  7 + <setting-item name="开启边框">
8 8 <n-switch v-model:value="optionData.borderConfig.show" size="small" />
9 9 </setting-item>
10 10 <setting-item name="大小">
11 11 <n-input-number :min="0" v-model:value="optionData.borderConfig.size" size="small" />
12 12 </setting-item>
13 13 </setting-item-box>
  14 + <setting-item-box name="上传文件">
  15 + <setting-item>
  16 + <FileUpload
  17 + :max="100"
  18 + :fileList="optionData.dataset"
  19 + :threeSupportFileFormat="threeSupportFileFormat"
  20 + :singleFileType="singleFileTypeNotMtl"
  21 + @fileStaticUri="handleFileStaticUri"
  22 + />
  23 + </setting-item>
  24 + </setting-item-box>
14 25 <setting-item-box :alone="true">
15 26 <template #name>
16   - <n-text>提示</n-text>
  27 + <n-text>mtl</n-text>
17 28 <n-tooltip trigger="hover">
18 29 <template #trigger>
19 30 <n-icon size="21" :depth="3">
20 31 <help-outline-icon></help-outline-icon>
21 32 </n-icon>
22 33 </template>
23   - <span class="help-span">{{ threeFileHelpMessgae }}</span>
  34 + <span class="help-span">{{ threeMtlHelpMessgae }}</span>
24 35 </n-tooltip>
25 36 </template>
26 37 <FileUpload
27   - :max="1"
28   - :fileList="[optionData.dataset]"
29   - :threeSupportFileFormat="threeSupportFileFormat"
30   - :singleFileType="singleFileTypeNotMtl"
31   - @fileStaticUri="handleFileStaticUri"
32   - />
33   - </setting-item-box>
34   - <setting-item-box name="mtl材质">
35   - <FileUpload
36 38 :fileList="optionData.mtlPath"
37 39 :max="100"
38 40 :threeSupportFileFormat="supportFileMtl"
39 41 @fileStaticUri="handleFileMtlStaticUri"
40 42 />
41 43 </setting-item-box>
42   - <setting-item-box name="材质贴图">
  44 + <setting-item-box :alone="true">
  45 + <template #name>
  46 + <n-text>贴图</n-text>
  47 + <n-tooltip trigger="hover">
  48 + <template #trigger>
  49 + <n-icon size="21" :depth="3">
  50 + <help-outline-icon></help-outline-icon>
  51 + </n-icon>
  52 + </template>
  53 + <span class="help-span">{{ threeTextureHelpMessgae }}</span>
  54 + </n-tooltip>
  55 + </template>
43 56 <FileUpload
44 57 :fileList="optionData.textureImage"
45 58 :max="100"
... ... @@ -47,6 +60,113 @@
47 60 @fileStaticUri="handleFileTextureImageStaticUri"
48 61 />
49 62 </setting-item-box>
  63 + <setting-item-box name="模型位置">
  64 + <setting-item name="模型位置坐标(x,y,z)">
  65 + <template v-for="(item, index) in optionData.position" :key="index">
  66 + <n-input-number v-model:value="item.x" size="small" />
  67 + <n-input-number v-model:value="item.y" size="small" />
  68 + <n-input-number v-model:value="item.z" size="small" />
  69 + </template>
  70 + </setting-item>
  71 + </setting-item-box>
  72 + <setting-item-box name="模型旋转">
  73 + <setting-item name="模型旋转坐标(x,y,z)">
  74 + <template v-for="(item, index) in optionData.rotation" :key="index">
  75 + <n-input-number v-model:value="item.x" size="small" />
  76 + <n-input-number v-model:value="item.y" size="small" />
  77 + <n-input-number v-model:value="item.z" size="small" />
  78 + </template>
  79 + </setting-item>
  80 + </setting-item-box>
  81 + <setting-item-box name="灯光配置">
  82 + <setting-item v-for="(item, index) in optionData.lights" :name="item.label" :key="index">
  83 + <n-color-picker
  84 + v-if="!includeHemisphereLight.includes(item.type)"
  85 + size="small"
  86 + :show-alpha="false"
  87 + v-model:value="item.color"
  88 + ></n-color-picker>
  89 + <n-color-picker
  90 + v-if="includeHemisphereLight.includes(item.type)"
  91 + size="small"
  92 + :show-alpha="false"
  93 + v-model:value="item.skyColor"
  94 + ></n-color-picker>
  95 + <n-color-picker
  96 + v-if="includeHemisphereLight.includes(item.type)"
  97 + size="small"
  98 + :show-alpha="false"
  99 + v-model:value="item.groundColor"
  100 + ></n-color-picker>
  101 + <template v-if="!includeAmbientLight.includes(item.type)">
  102 + <n-input-number v-model:value="item.position.x" size="small" />
  103 + <n-input-number v-model:value="item.position.y" size="small" />
  104 + <n-input-number v-model:value="item.position.z" size="small" />
  105 + </template>
  106 + <n-input-number
  107 + v-if="includeDirectionalLightAndPointLight.includes(item.type)"
  108 + v-model:value="item.intensity"
  109 + size="small"
  110 + />
  111 + </setting-item>
  112 + </setting-item-box>
  113 + <setting-item-box>
  114 + <SettingItem name="启用fps">
  115 + <n-switch v-model:value="optionData.showFps" size="small" />
  116 + </SettingItem>
  117 + </setting-item-box>
  118 + <setting-item-box name="label配置">
  119 + <setting-item v-for="(item, index) in optionData.labels" :key="index">
  120 + <div>
  121 + <span>文字</span>
  122 + <n-input
  123 + type="text"
  124 + placeholder="请输入"
  125 + size="small"
  126 + clearable
  127 + show-count
  128 + v-model:value="item.text"
  129 + ></n-input>
  130 + </div>
  131 + <div>
  132 + <span>位置</span>
  133 + <n-input-number v-model:value="item.position.x" size="small" />
  134 + <n-input-number v-model:value="item.position.y" size="small" />
  135 + <n-input-number v-model:value="item.position.z" size="small" />
  136 + </div>
  137 + <div>
  138 + <span>缩放</span>
  139 + <n-input-number v-model:value="item.scale.x" size="small" />
  140 + <n-input-number v-model:value="item.scale.y" size="small" />
  141 + <n-input-number v-model:value="item.scale.z" size="small" />
  142 + </div>
  143 + <div>
  144 + <span>文字样式</span>
  145 + <span>颜色</span>
  146 + <n-color-picker size="small" :show-alpha="false" v-model:value="item.textStyle.color"></n-color-picker>
  147 + <span>字体</span>
  148 + <n-input-number v-model:value="item.textStyle.fontSize" size="small" />
  149 + <span>行高</span>
  150 + <n-input-number v-model:value="item.textStyle.lineHeight" size="small" />
  151 + <span>背景颜色</span>
  152 + <n-color-picker
  153 + size="small"
  154 + :show-alpha="false"
  155 + v-model:value="item.textStyle.backgroundColor"
  156 + ></n-color-picker>
  157 + <span>边框颜色</span>
  158 + <n-color-picker size="small" :show-alpha="false" v-model:value="item.textStyle.borderColor"></n-color-picker>
  159 + <span>边框大小</span>
  160 + <n-input-number v-model:value="item.textStyle.borderWidth" size="small" />
  161 + <span>边框圆角</span>
  162 + <n-input-number v-model:value="item.textStyle.borderRadius" size="small" />
  163 + </div>
  164 + <div>
  165 + <n-button v-if="optionData.labels.length > 1" @click="optionData.labels.splice(index, 1)"> - </n-button>
  166 + </div>
  167 + </setting-item>
  168 + <n-button v-if="optionData.labels.length < 4" @click="optionData.labels.push(pushItem)"> + </n-button>
  169 + </setting-item-box>
50 170 <setting-item-box name="属性配置">
51 171 <setting-item name="场景色(需要这种格式HEX #000000,否则失效)">
52 172 <n-color-picker size="small" :show-alpha="false" v-model:value="optionData.backgroundColor"></n-color-picker>
... ... @@ -91,9 +211,36 @@ const props = defineProps({
91 211 }
92 212 })
93 213
  214 +const pushItem = {
  215 + image: '',
  216 + text: '',
  217 + textStyle: {
  218 + fontFamily: 'Arial',
  219 + fontSize: 18,
  220 + fontWeight: 'normal',
  221 + lineHeight: 1,
  222 + color: '#ffffff',
  223 + borderWidth: 8,
  224 + borderRadius: 4,
  225 + borderColor: 'rgba(0,0,0,1)',
  226 + backgroundColor: 'rgba(0, 0, 0, 1)'
  227 + },
  228 + position: { x: 0, y: 0, z: 0 },
  229 + scale: { x: 1, y: 1, z: 0 },
  230 + sid: null
  231 +}
  232 +
  233 +const includeHemisphereLight = ['HemisphereLight']
  234 +
  235 +const includeAmbientLight = ['AmbientLight']
  236 +
  237 +const includeDirectionalLightAndPointLight = ['DirectionalLight', 'PointLight']
  238 +
94 239 const singleFileTypeNotMtl = ref('')
95 240
96   -const threeFileHelpMessgae = ref('如果格式为obj,则上传顺序是,先上传材质贴图(png或jpg)、mtl材质文件,最后是obj')
  241 +const threeMtlHelpMessgae = ref('比如mtl一般和obj搭配使用,fbx搭配jpg等')
  242 +
  243 +const threeTextureHelpMessgae = ref('贴图目前支持jpg/png格式')
97 244
98 245 const threeSupportFileFormat = ['fbx', 'obj', 'gltf', 'stl', 'dae', 'glb', 'ply', 'json']
99 246
... ... @@ -101,17 +248,21 @@ const supportFileMtl = ['mtl']
101 248
102 249 const supportFileTextureImage = ['jpg', 'png']
103 250
104   -const handleChange = (e: boolean) => {
105   - if (e) props.optionData.dataset = ''
106   -}
107   -
108 251 const encodinghList = [
109 252 { label: 'linear', value: 'linear' },
110 253 { label: 'sRGB ', value: 'sRGB ' }
111 254 ]
112 255
  256 +const handleChange = (e: boolean) => {
  257 + if (e) props.optionData.dataset = ['']
  258 +}
  259 +
113 260 const handleFileStaticUri = (value: UploadFileInfo[]) => {
114   - props.optionData.dataset = value[0]?.url as string
  261 + props.optionData.dataset = value.map(item => item?.url)?.filter(Boolean) as any
  262 + if (Array.isArray(props.optionData.dataset) && props.optionData.dataset.length === 0) {
  263 + //filePath数组必须有值
  264 + props.optionData.dataset = ['demo.obj']
  265 + }
115 266 }
116 267
117 268 const handleFileMtlStaticUri = (value: UploadFileInfo[]) => {
... ...
1 1 <template>
2   - <div class="go-content-box" :style="{ border: !borderConfig.show ? 'none' : '' }">
3   - <div v-if="supportWebGL">
  2 + <div class="go-content-box" :style="{ border: !borderConfig.show ? 'none' : ''}">
  3 + <div v-if="useDetectWebGLContext()">
4 4 <vue3dLoader
5 5 ref="vue3dLoaderRef"
6 6 :webGLRendererOptions="webGLRendererOptions"
... ... @@ -18,7 +18,11 @@
18 18 :dampingFactor="dampingFactor"
19 19 @process="onProcess"
20 20 @load="onLoad"
21   - @click="onClick"
  21 + :position="position"
  22 + :rotation="rotation"
  23 + :lights="lights"
  24 + :showFps="showFps"
  25 + :labels="labels"
22 26 />
23 27 <div v-show="show" class="process">
24 28 <span> 拼命加载中... </span>
... ... @@ -29,10 +33,11 @@
29 33 </div>
30 34 </template>
31 35 <script setup lang="ts">
32   -import { PropType, toRefs, ref, onMounted, nextTick, computed, watch } from 'vue'
  36 +import { PropType, toRefs, ref, nextTick, computed, watch } from 'vue'
33 37 import { CreateComponentType } from '@/packages/index.d'
34 38 import { vue3dLoader } from 'vue-3d-loader'
35 39 import { useDesignStore } from '@/store/modules/designStore/designStore'
  40 +import { useDetectWebGLContext } from '@/utils/external/useSupportWebGL'
36 41
37 42 const designStore = useDesignStore()
38 43
... ... @@ -43,7 +48,6 @@ const props = defineProps({
43 48 }
44 49 })
45 50
46   -// 颜色
47 51 const themeColor = computed(() => {
48 52 return designStore.getAppTheme
49 53 })
... ... @@ -74,27 +78,6 @@ const onProcess = (event: any) => {
74 78 process.value = Math.floor((event.loaded / event.total) * 100)
75 79 }
76 80
77   -const onClick = (event: any) => {
78   - console.log(event)
79   -}
80   -
81   -//判断浏览器是否支持WebGL
82   -const supportWebGL = ref(true)
83   -const detectWebGLContext = () => {
84   - let canvas = document.createElement('canvas')
85   - let gl = canvas.getContext('webgl') || canvas.getContext('experimental-webgl')
86   - if (gl && gl instanceof WebGLRenderingContext) {
87   - supportWebGL.value = true
88   - } else {
89   - supportWebGL.value = false
90   - }
91   -}
92   -
93   -onMounted(() => {
94   - detectWebGLContext()
95   - console.log(`实例`, vue3dLoaderRef.value)
96   -})
97   -
98 81 const { w, h } = toRefs(props.chartConfig.attr)
99 82
100 83 const {
... ... @@ -108,12 +91,17 @@ const {
108 91 outputEncoding,
109 92 clearScene,
110 93 dampingFactor,
111   - borderConfig
  94 + borderConfig,
  95 + position,
  96 + rotation,
  97 + lights,
  98 + showFps,
  99 + labels
112 100 } = toRefs(props.chartConfig.option) as any
113 101
114 102 watch(dataset, (newData: string) => {
115 103 //dateset为空则清除场景
116   - if(!newData)clearScene.value=true
  104 + if(!newData) clearScene.value=true
117 105 })
118 106 </script>
119 107
... ... @@ -123,7 +111,6 @@ watch(dataset, (newData: string) => {
123 111 border-width: v-bind('borderConfig.size + "px"');
124 112 border-style: solid;
125 113 border-color: v-bind('borderConfig.color');
126   - // border-color:v-bind('borderConfig.color');
127 114 .process {
128 115 position: absolute;
129 116 top: 50%;
... ...
... ... @@ -34,10 +34,13 @@ import { Subtitle5Config } from '@/packages/components/external/Decorates/Subtit
34 34 import { Subtitle6Config } from '@/packages/components/external/Decorates/Subtitle/Subtitle6'
35 35 import { Subtitle7Config } from '@/packages/components/external/Decorates/Subtitle/Subtitle7'
36 36 import { Subtitle8Config } from '@/packages/components/external/Decorates/Subtitle/Subtitle8'
  37 +import { Subtitle9Config } from '@/packages/components/external/Decorates/Subtitle/Subtitle9'
37 38 import { Decorates07Config } from '@/packages/components/external/Decorates/Decorates/Decorates07'
38 39 import { Decorates08Config } from '@/packages/components/external/Decorates/Decorates/Decorates08'
39 40 import { Decorates09Config } from '@/packages/components/external/Decorates/Decorates/Decorates09'
40 41 import { Decorates10Config } from '@/packages/components/external/Decorates/Decorates/Decorates10'
  42 +import { Decorates11Config } from '@/packages/components/external/Decorates/Decorates/Decorates11'
  43 +import { Decorates12Config } from '@/packages/components/external/Decorates/Decorates/Decorates12'
41 44 import { CameraConfig } from '@/packages/components/external/Informations/Mores/Camera'
42 45 import { SingleCameraConfig } from '@/packages/components/external/Informations/Mores/SingleCamera'
43 46 import { OverrideILoadConfigurationframeConfig } from '@/packages/components/external/Informations/Mores/OverrideILoadConfigurationframe'
... ... @@ -63,10 +66,13 @@ export function useInjectLib(packagesList: EPackagesType) {
63 66 addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Subtitle6Config)//小标题6
64 67 addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Subtitle7Config)//小标题7
65 68 addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Subtitle8Config)//小标题8
  69 + addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Subtitle9Config)//小标题9
66 70 addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Decorates07Config)//新增装饰07
67 71 addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Decorates08Config)//新增装饰08
68 72 addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Decorates09Config)//新增装饰09
69 73 addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Decorates10Config)//新增装饰10
  74 + addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Decorates11Config)//新增装饰11
  75 + addWidgetToCategoryByCategoryName(packagesList, PackagesCategoryEnum.DECORATES, Decorates12Config)//新增装饰12
70 76 //
71 77
72 78 //信息
... ...
  1 +/**
  2 + * 判断浏览器是否支持webgl
  3 + */
  4 +
  5 +export const useDetectWebGLContext = () => {
  6 + const canvas = document.createElement('canvas')
  7 + const gl = canvas.getContext('webgl') || canvas.getContext('experimental-webgl')
  8 + if (gl && gl instanceof WebGLRenderingContext) {
  9 + return true
  10 + } else {
  11 + return false
  12 + }
  13 +}
... ...