Commit e390e7e1054c0c8002297a1dd293f09192a168ca
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 | //信息 | ... | ... |
src/utils/external/useSupportWebGL.ts
0 → 100644
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 | +} | ... | ... |