Browse Source

Merge remote-tracking branch 'origin/master'

# Conflicts:
#	src/core/engine/Viewport.ts
master
修宁 7 months ago
parent
commit
7f3807121f
  1. BIN
      src/assets/images/ptr/charger.png
  2. BIN
      src/assets/images/ptr/clx.png
  3. BIN
      src/assets/images/ptr/ptr.png
  4. 4
      src/core/ModelUtils.ts
  5. 20
      src/core/base/IMeta.ts
  6. 34
      src/core/base/PropertyTypes.ts
  7. 5
      src/core/controls/EsDragControls.ts
  8. 13
      src/core/controls/SelectInspect.ts
  9. 7
      src/core/engine/Viewport.ts
  10. 12
      src/core/manager/ModuleManager.ts
  11. 6
      src/core/manager/WorldModel.ts
  12. 112
      src/editor/widgets/property/PropertyPanel.vue
  13. 58
      src/editor/widgets/property/PropertyPanelConstant.ts
  14. 7
      src/editor/widgets/property/PropertyPanelTypes.ts
  15. 0
      src/editor/widgets/property/PropertyPanelUtils.ts
  16. 296
      src/editor/widgets/property/PropertyView.vue
  17. 259
      src/example/example1.js
  18. 5
      src/modules/charger/ChargerEntity.ts
  19. 22
      src/modules/charger/ChargerInteraction.ts
  20. 10
      src/modules/charger/ChargerMeta.ts
  21. 97
      src/modules/charger/ChargerRenderer.ts
  22. 15
      src/modules/charger/index.ts
  23. 5
      src/modules/clx/ClxEntity.ts
  24. 22
      src/modules/clx/ClxInteraction.ts
  25. 4
      src/modules/clx/ClxMeta.ts
  26. 97
      src/modules/clx/ClxRenderer.ts
  27. 15
      src/modules/clx/index.ts
  28. 14
      src/modules/gstore/GstoreMeta.ts
  29. 12
      src/modules/gstore/GstorePropertySetter.ts
  30. 6
      src/modules/gstore/GstoreRenderer.ts
  31. 12
      src/modules/gstore/index.ts
  32. 15
      src/modules/measure/MeasureMeta.ts
  33. 12
      src/modules/measure/MeasurePropertySetter.ts
  34. 12
      src/modules/measure/index.ts
  35. 20
      src/modules/pallet/PalletPropertySetter.ts
  36. 6
      src/modules/pallet/PalletRenderer.ts
  37. 12
      src/modules/pallet/index.ts
  38. 4
      src/modules/ptr/PtrMeta.ts
  39. 20
      src/modules/ptr/PtrPropertySetter.ts
  40. 7
      src/modules/ptr/PtrRenderer.ts
  41. 12
      src/modules/ptr/index.ts
  42. 64
      src/modules/rack/RackPropertySetter.ts
  43. 6
      src/modules/rack/RackRenderer.ts
  44. 12
      src/modules/rack/index.ts
  45. 14
      src/modules/way/WayMeta.ts
  46. 12
      src/modules/way/WayPropertySetter.ts
  47. 12
      src/modules/way/index.ts
  48. 3
      src/pages/DataForm01.vue

BIN
src/assets/images/ptr/charger.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.7 KiB

BIN
src/assets/images/ptr/clx.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

BIN
src/assets/images/ptr/ptr.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.2 KiB

After

Width:  |  Height:  |  Size: 12 KiB

4
src/core/ModelUtils.ts

@ -2,9 +2,7 @@ import * as THREE from 'three'
import type { ItemTypeDefineOption } from '@/model/itemType/ItemTypeDefine.ts'
import { getAllItemTypes, getItemTypeByName } from '@/model/itemType/ItemTypeDefine.ts'
import type Viewport from '@/core/engine/Viewport'
import { computeBoundsTree, disposeBoundsTree } from 'three-mesh-bvh'
import { Vector2 } from 'three/src/math/Vector2'
import type Toolbox from '@/model/itemType/Toolbox.ts'
import EventBus from '@/runtime/EventBus.ts'
import Decimal from 'decimal.js'
@ -174,7 +172,7 @@ export function deletePointByKeyboard() {
viewport.state.selectedObject = undefined
viewport.state.selectedItem = undefined
viewport.state.selectedEntityId = undefined
viewport.state.selectedObjectMeta = undefined
viewport.state.selectedObjectSetter = undefined
}
EventBus.dispatch('entityDeleted', {

20
src/core/base/IMeta.ts

@ -31,23 +31,3 @@ export const BASIC_META_OF_LINE: ItemTypeMeta = []
* "线",
*/
export const BASIC_META_OF_LINE2: ItemTypeMeta = []
/**
* , category, tabName, MetaItem
*/
export type IMeta = MetaItem[]
/**
* PropertyPanelConfig interface
* Defines the structure of property panel configurations.
*/
export interface MetaItem {
field?: string;
editor: string;
editorProps?: any;
label?: string;
readonly?: boolean;
category?: string;
[key: string]: any;
}

34
src/core/base/PropertyTypes.ts

@ -0,0 +1,34 @@
import type { FormField } from "@/components/data-form/DataFormTypes.ts";
interface PropertyFieldSetter extends FormField {
}
interface PropertyFlattenSetter {
/** label宽度 */
labelWidth?: string | number;
/** 表单字段大小 */
size?: "" | "small" | "default" | "large";
/** 设置器集合 */
fields: Array<PropertyFieldSetter>;
}
interface PropertySetterGroup extends PropertyFlattenSetter {
/** 分组标题 */
title: string;
/** 是否展开状态(默认为true) */
expand?: boolean;
}
interface PropertySetter {
/** 最上面平铺的设置器 */
flatten?: PropertyFlattenSetter;
/** 设置器分组集合 */
groups?: Array<PropertySetterGroup>;
}
export type {
PropertyFieldSetter,
PropertyFlattenSetter,
PropertySetterGroup,
PropertySetter,
}

5
src/core/controls/EsDragControls.ts

@ -1,11 +1,8 @@
import * as THREE from 'three'
import { DragControls } from './DragControls.js'
import type Viewport from '@/core/engine/Viewport.ts'
import { getItemTypeByName } from '@/model/itemType/ItemTypeDefine'
import type { ItemTypeDefineOption } from '@/model/itemType/ItemTypeDefine'
import { markRaw } from 'vue'
import EventBus from '@/runtime/EventBus'
import { getInteraction, getMeta } from '@/core/manager/ModuleManager.ts'
import { getInteraction } from '@/core/manager/ModuleManager.ts'
import type BaseInteraction from '@/core/base/BaseInteraction.ts'
// dragControls 绑定函数

13
src/core/controls/SelectInspect.ts

@ -6,8 +6,7 @@ import { LineGeometry } from 'three/examples/jsm/lines/LineGeometry.js'
import { LineMaterial } from 'three/examples/jsm/lines/LineMaterial.js'
import EventBus from '@/runtime/EventBus'
import { markRaw } from 'vue'
import { getMeta } from '@/core/manager/ModuleManager.ts'
import MouseMoveInspect from '@/core/controls/MouseMoveInspect.ts'
import { getSetter } from '@/core/manager/ModuleManager.ts'
import Constract from '@/core/Constract.ts'
let pdFn, pmFn, puFn
@ -346,13 +345,13 @@ export default class SelectInspect implements IControls {
this.viewport.state.selectedObject = markRaw(object)
this.viewport.state.selectedItem = markRaw(item)
this.viewport.state.selectedEntityId = entityId
this.viewport.state.selectedObjectMeta = getMeta(itemTypeName)
this.viewport.state.selectedObjectSetter = getSetter(itemTypeName)
EventBus.dispatch('selectedObjectChanged', {
viewport: markRaw(this.viewport),
selectedObject: this.viewport.state.selectedObject,
selectedItem: this.viewport.state.selectedItem,
selectedEntityId: this.viewport.state.selectedEntityId,
selectedObjectMeta: this.viewport.state.selectedObjectMeta
selectedObjectSetter: this.viewport.state.selectedObjectSetter,
})
}
} else {
@ -360,13 +359,13 @@ export default class SelectInspect implements IControls {
this.viewport.state.selectedObject = null
this.viewport.state.selectedItem = null
this.viewport.state.selectedEntityId = null
this.viewport.state.selectedObjectMeta = null
this.viewport.state.selectedObjectSetter = null
EventBus.dispatch('selectedObjectChanged', {
viewport: markRaw(this.viewport),
selectedObject: null,
selectedItem: null,
selectedEntityId: null,
selectedObjectMeta: null
selectedObjectSetter: null,
})
}
}
@ -402,7 +401,7 @@ export default class SelectInspect implements IControls {
multiSelectedObjects.push(object)
multiSelectedItems.push(item)
multiSelectedEntityIds.push(object.userData.entityId)
multiSelectedObjectMetas.push(getMeta(object.userData.t))
// multiSelectedObjectMetas.push(getMeta(object.userData.t))
}
}
}

7
src/core/engine/Viewport.ts

@ -8,8 +8,8 @@ import { markRaw, reactive, toRaw, watch } from 'vue'
import type IControls from '../controls/IControls'
import { CSS3DRenderer } from 'three/examples/jsm/renderers/CSS3DRenderer'
import { CSS2DRenderer } from 'three/examples/jsm/renderers/CSS2DRenderer'
import { getAllItemTypes, type ItemTypeMeta } from '@/model/itemType/ItemTypeDefine.ts'
import type { ItemTypeDefineOption } from '@/model/itemType/ItemTypeDefine.ts'
import { getAllItemTypes } from '@/model/itemType/ItemTypeDefine.ts'
import SceneHelp from './SceneHelp'
import SelectInspect from '../controls/SelectInspect'
@ -23,6 +23,7 @@ import EventBus from '@/runtime/EventBus.ts'
import Constract from '@/core/Constract.ts'
import type { IMeta } from '@/core/base/IMeta.ts'
import DragControl2 from '@/core/controls/EsDragControl2.ts'
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
/**
*
@ -75,7 +76,7 @@ export default class Viewport {
selectedObject: undefined,
selectedItem: undefined,
selectedEntityId: undefined,
selectedObjectMeta: undefined,
selectedObjectSetter: undefined,
multiSelectedObjects: [],
multiSelectedItems: [],
@ -571,7 +572,7 @@ export interface ViewportState {
selectedObject: THREE.Object3D | undefined
selectedItem: ItemJson | undefined
selectedEntityId: string | undefined
selectedObjectMeta: IMeta | undefined
selectedObjectSetter: PropertySetter | undefined
/**
*

12
src/core/manager/ModuleManager.ts

@ -1,8 +1,8 @@
import * as THREE from 'three'
import BaseRenderer from '@/core/base/BaseRenderer'
import BaseInteraction from '@/core/base/BaseInteraction'
import type { IMeta } from '@/core/base/IMeta'
import BaseEntity from '@/core/base/BaseItemEntity'
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
// Define the ModuleDefineOption interface
export interface ModuleDefineOption {
@ -12,7 +12,7 @@ export interface ModuleDefineOption {
name: string;
renderer: BaseRenderer;
interaction: BaseInteraction;
meta: IMeta;
setter: PropertySetter;
entity: new () => BaseEntity;
}
@ -61,13 +61,9 @@ export function getInteraction<T extends BaseInteraction>(name: string): T {
return module.interaction as T
}
/**
* ,
*
*/
export function getMeta<T extends IMeta>(name: string): T {
export function getSetter(name: string) {
const module = getModuleOption(name)
return module.meta as T
return module.setter;
}
/**

6
src/core/manager/WorldModel.ts

@ -7,6 +7,8 @@ import Gstore from '@/modules/gstore'
import Rack from '@/modules/rack'
import Pallet from "@/modules/pallet"
import Ptr from "@/modules/ptr"
import Clx from "@/modules/clx"
import Charger from "@/modules/charger"
import StateManager from '@/core/manager/StateManager.ts'
export interface WorldModelState {
@ -70,7 +72,9 @@ export default class WorldModel {
Gstore,
Rack,
Pallet,
Ptr
Ptr,
Clx,
Charger
]).then(() => {
console.log('世界模型初始化完成')

112
src/editor/widgets/property/PropertyPanel.vue

@ -0,0 +1,112 @@
<script setup lang="ts">
import { computed, reactive } from "vue";
import { ElCollapse, ElCollapseItem } from "element-plus";
import DataForm from "@/components/data-form/DataForm.vue";
import type { PropertyFlattenSetter, PropertySetterGroup } from "@/core/base/PropertyTypes.ts";
import type { DataFormProps } from "@/components/data-form/DataFormTypes.ts";
import { defDataFormProps } from "@/editor/widgets/property/PropertyPanelConstant.ts";
defineOptions({
name: 'PropertyPanel',
});
// Props
interface PropertyPanelProps {
/** 待编辑数据 */
data?: any;
/** 默认的DataFormProps */
defDataFormProps?: DataFormProps;
/** 最上面平铺的设置器 */
flatten?: PropertyFlattenSetter;
/** 设置器分组集合 */
groups?: Array<PropertySetterGroup>;
}
// props
const props = withDefaults(defineProps<PropertyPanelProps>(), {});
// State
interface PropertyPanelState {
expandGroups: Array<string>;
}
// state
const state = reactive<PropertyPanelState>({
expandGroups: [],
});
// Data
interface PropertyPanelData {
}
//
const data: PropertyPanelData = {};
const flattenFormProps = computed(() => getDefFormProps(props.flatten));
function getDefFormProps(setter?: PropertyFlattenSetter) {
const formProps: DataFormProps = {
...defDataFormProps,
...props.defDataFormProps,
};
fillFormProps(setter);
return formProps;
}
function fillFormProps(formProps: DataFormProps, setter?: PropertyFlattenSetter) {
if (!setter) return;
if (setter.size) formProps.size = setter.size;
if (setter.labelWidth) formProps.labelWidth = setter.labelWidth;
}
function getCollapseItemId(group: PropertySetterGroup, idx: number) {
return `_${idx}_${group.title}`;
}
interface PropertyPanelExpose {
state: PropertyPanelState;
data: PropertyPanelData;
}
const expose: PropertyPanelExpose = {
state,
data,
};
//
defineExpose(expose);
export type {
PropertyPanelProps,
PropertyPanelState,
}
</script>
<template>
<div class="property-panel">
<DataForm
v-if="props.flatten"
class="property-panel-form"
v-bind="flattenFormProps"
:data="props.data"
:formFields="props.flatten.fields"
/>
<ElCollapse v-if="props.groups" v-model="state.expandGroups">
<ElCollapseItem
v-for="(group, idx) in props.groups"
:name="getCollapseItemId(group, idx)"
:title="group.title"
>
<DataForm
v-if="group"
class="property-panel-form"
v-bind="getDefFormProps(group)"
:data="props.data"
:formFields="props.flatten.fields"
/>
</ElCollapseItem>
</ElCollapse>
</div>
</template>
<style scoped>
</style>

58
src/editor/widgets/property/PropertyPanelConstant.ts

@ -0,0 +1,58 @@
import type { DataFormProps } from "@/components/data-form/DataFormTypes.ts";
import type { PropertyFieldSetter } from "@/core/base/PropertyTypes.ts";
const defDataFormProps: DataFormProps = {
columnCount: 1,
layout: "onlyLabelFixed",
labelWidth: "100px",
size: "small",
};
const basicFieldsSetter: Array<PropertyFieldSetter> = [
{
dataPath: 'id', label: '唯一ID', input: 'Input',
inputProps: {
readonly: true,
},
},
{
dataPath: 'name', label: '名称', input: 'Input',
inputProps: {},
},
{
dataPath: 'visible', label: '可见', input: 'Checkbox',
inputProps: {},
},
{
dataPath: 'dt.selectable', label: '可选中', input: 'Checkbox',
inputProps: {},
},
{
dataPath: 'dt.protected', label: '受保护', input: 'Checkbox',
inputProps: {},
},
{
dataPath: 'dt.label', label: '标签', input: 'Input',
inputProps: {},
},
{
dataPath: 'dt.color', label: '颜色', input: 'ColorPicker',
inputProps: {},
},
// {
// dataPath: 'tf', input: 'TransformEditor',
// inputProps: {
// },
// },
// {
// dataPath: 'dt', input: 'InOutCenterEditor',
// inputProps: {
// },
// },
];
export {
defDataFormProps,
basicFieldsSetter,
}

7
src/editor/widgets/property/PropertyPanelTypes.ts

@ -0,0 +1,7 @@
interface PropertyPanelProps {
}
export type {
PropertyPanelProps,
}

0
src/editor/widgets/property/PropertyPanelUtils.ts

296
src/editor/widgets/property/PropertyView.vue

@ -1,188 +1,164 @@
<template>
<div class="title">
<template v-if="!!t">
属性
<el-tag type="primary">{{ t }}</el-tag>
<el-input v-model="searchKeyword" size="small" style="width: 240px" placeholder="Search">
<template #prefix>
<component :is="renderIcon('element Search')"></component>
<div class="title">
<template v-if="!!t">
属性
<el-tag type="primary">{{ t }}</el-tag>
<el-input v-model="searchKeyword" size="small" style="width: 240px" placeholder="Search">
<template #prefix>
<component :is="renderIcon('element Search')"></component>
</template>
</el-input>
<span class="close" @click="closeMe()">
<component :is="renderIcon('element Close')"/>
</span>
</template>
</el-input>
<span class="close" @click="closeMe()">
<component :is="renderIcon('element Close')" />
</span>
</template>
</div>
<div class="calc-right-panel">
<el-empty v-if="!t" description="未选中">
</el-empty>
<el-form v-else
label-position="right"
label-width="60"
class="property-panel-form"
size="default"
@submit.native.prevent>
<template v-for="(itemMeta, idx) in selectedObjectMeta">
<el-divider v-if="itemMeta.editor === '-'" />
<TextInput
v-else-if="itemMeta.editor === 'TextInput'"
:prop="itemMeta"
:viewport="viewport"
/>
<Transform
v-else-if="itemMeta.editor === 'TransformEditor'"
:prop="itemMeta"
:viewport="viewport"
</div>
<div class="calc-right-panel">
<el-empty v-if="!t" description="未选中"/>
<PropertyPanel
v-else-if="propertyPanelProps"
v-bind="propertyPanelProps"
/>
<SwitchItem
v-else-if="itemMeta.editor === 'Switch'"
:prop="itemMeta"
:viewport="viewport"
/>
<ColorItem v-else-if="itemMeta.editor === 'Color'" :prop="itemMeta" :viewport="viewport" />
<UUIDItem v-else-if="itemMeta.editor === 'UUID'" :prop="itemMeta" :viewport="viewport" />
<NumberInput
v-else-if="itemMeta.editor === 'Number'"
:prop="itemMeta"
:viewport="viewport"
/>
<template v-else> 未知编辑器: {{ itemMeta.editor }}</template>
</template>
</el-form>
</div>
<el-empty v-else description="节点未配置设置器"/>
</div>
</template>
<script>
import IWidgets from '../IWidgets.js'
import TextInput from '../../propEditors/TextInput.vue'
import Transform from '../../propEditors/Transform.vue'
import SwitchItem from '../../propEditors/SwitchItem.vue'
import ColorItem from '../../propEditors/ColorItem.vue'
import UUIDItem from '../../propEditors/UUIDItem.vue'
import NumberInput from '../../propEditors/NumberInput.vue'
import EventBus from '../../../runtime/EventBus.js'
import PropertyPanel from "@/editor/widgets/property/PropertyPanel.vue";
export default {
name: 'PropertyView',
components: {
NumberInput,
UUIDItem,
ColorItem,
SwitchItem,
TextInput, Transform
},
mixins: [IWidgets],
data() {
return {
itemTypeMeta: null,
searchKeyword: ''
}
},
computed: {
t() {
return this.selectedItem ? this.selectedItem.t : ''
name: 'PropertyView',
components: {
PropertyPanel,
},
selectedItem() {
return this.state?.selectedItem
mixins: [IWidgets],
data() {
return {
searchKeyword: '',
propertySetter: undefined,
}
},
selectedObject() {
return this.state?.selectedObject
computed: {
t() {
return this.selectedItem ? this.selectedItem.t : ''
},
selectedItem() {
return this.state?.selectedItem
},
// selectedObject() {
// return this.state?.selectedObject
// },
// selectedObjectSetter() {
// return this.state?.selectedObjectSetter
// },
propertyPanelProps() {
const state = this.state;
if (!state) return;
const { selectedObjectSetter, selectedItem } = state;
if (!selectedObjectSetter || !selectedItem) return;
const data = _.find(this.viewport.stateManager.vdata.items, item => item.id === selectedItem.id);
if (!data) return;
return {
key: data.id,
data: data,
flatten: selectedObjectSetter.flatten,
groups: selectedObjectSetter.groups,
};
},
},
selectedObjectMeta() {
return this.state?.selectedObjectMeta
}
},
methods: {
selectedObjectChanged(state) {
const data = state.selectedItem
console.log('selectedObjectChanged data', data)
if (data) {
this.viewport.stateManager.beginStateUpdate()
const item = _.find(this.viewport.stateManager.vdata.items, item => item.id === data.id)
// item.tf[0][0] = item.tf[0][0] / 2;
console.log('selectedObjectChanged item', item)
// _.extend(item, data)
this.viewport.stateManager.endStateUpdate()
}
watch: {
// selectedItem(newV, oldV) {
// console.log("selectedItem", arguments)
// },
// selectedObject(newV, oldV) {
// console.log("selectedObject", arguments)
// },
},
methods: {
selectedObjectChanged(state) {
const data = state.selectedItem
console.log('selectedObjectChanged data', data)
if (data) {
this.viewport.stateManager.beginStateUpdate()
const item = _.find(this.viewport.stateManager.vdata.items, item => item.id === data.id)
// item.tf[0][0] = item.tf[0][0] / 2;
console.log('selectedObjectChanged item', item)
// _.extend(item, data)
this.viewport.stateManager.endStateUpdate()
}
}
},
mounted() {
// EventBus.on('selectedObjectChanged', this.selectedObjectChanged)
},
unmounted() {
// EventBus.off('selectedObjectChanged', this.selectedObjectChanged)
}
},
mounted() {
EventBus.on('selectedObjectChanged', this.selectedObjectChanged)
},
unmounted() {
EventBus.off('selectedObjectChanged', this.selectedObjectChanged)
}
}
</script>
<style lang="less">
.property-panel-form {
margin: 0;
font-size: 14px;
color: #606266;
.el-form-item--default {
margin: 5px 3px 0 0;
.el-form-item__label {
height: 20px;
line-height: 22px;
}
}
margin: 0;
font-size: 14px;
color: #606266;
.gui-toolbar {
color: #333;
background: #ffffff;
border-top: 1px solid #dcdcdc;
margin-top: 5px;
.el-form-item--default {
margin: 5px 3px 0 0;
.el-input-number.is-without-controls .el-input__wrapper {
padding-left: 2px;
padding-right: 2px;
.el-form-item__label {
height: 20px;
line-height: 22px;
}
}
.gui-row {
display: flex;
flex-direction: row;
gap: 3px;
padding: 3px 3px 3px 0;
.gui-item-name {
width: 26px;
align-self: stretch;
display: flex;
align-items: center;
justify-content: center;
.gui-toolbar {
color: #333;
background: #ffffff;
border-top: 1px solid #dcdcdc;
margin-top: 5px;
.el-icon {
font-size: 16px;
.el-input-number.is-without-controls .el-input__wrapper {
padding-left: 2px;
padding-right: 2px;
}
}
.gui-item {
flex: 1;
text-align: center;
font-size: 12px;
.el-input-number {
width: 100%;
.el-input__wrapper {
background-color: #efefef;
box-shadow: none;
}
.gui-row {
display: flex;
flex-direction: row;
gap: 3px;
padding: 3px 3px 3px 0;
.gui-item-name {
width: 26px;
align-self: stretch;
display: flex;
align-items: center;
justify-content: center;
.el-icon {
font-size: 16px;
}
}
.gui-item {
flex: 1;
text-align: center;
font-size: 12px;
.el-input-number {
width: 100%;
.el-input__wrapper {
background-color: #efefef;
box-shadow: none;
}
}
}
}
}
}
}
.el-divider {
margin: 5px 0;
}
.el-divider {
margin: 5px 0;
}
}
</style>

259
src/example/example1.js

@ -7,10 +7,10 @@ export default {
Dashboard: [], // 监控面板
DataTable: [], // 地图自带的数据
Trigger: [ // 触发器
{ name: 'OnOpen', fn: '' }, // 打开
{ name: 'OnReset', fn: '' }, // 仿真重置
{ name: 'OnStart', fn: '' }, // 开始仿真
{ name: 'OnStop', fn: '' } // 停止仿真
{name: 'OnOpen', fn: ''}, // 打开
{name: 'OnReset', fn: ''}, // 仿真重置
{name: 'OnStart', fn: ''}, // 开始仿真
{name: 'OnStop', fn: ''} // 停止仿真
],
gridHelper: { // 网格辅助线
axesEnabled: true, // 是否显示中心轴
@ -93,11 +93,11 @@ export default {
bays: [ // 每列的配置
{
bayWidth: 1.4, // 列的宽度
levelHeight: [ 1.4, 1.4, 1.4 ] // 每层的高度
levelHeight: [1.4, 1.4, 1.4] // 每层的高度
},
{bayWidth: 1.4, levelHeight: [ 1.4, 1.4, 1.4 ]},
{bayWidth: 1.4, levelHeight: [ 1.4, 1.4, 1.4 ]},
{bayWidth: 1.4, levelHeight: [ 1.4, 1.4, 1.4 ]},
{bayWidth: 1.4, levelHeight: [1.4, 1.4, 1.4]},
{bayWidth: 1.4, levelHeight: [1.4, 1.4, 1.4]},
{bayWidth: 1.4, levelHeight: [1.4, 1.4, 1.4]},
]
}
},
@ -106,87 +106,258 @@ export default {
t: 'measure',
v: true,
tf: [[-4, 0.1, 4], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: { in: [], out: [], center: ['P2'] }
dt: {in: [], out: [], center: ['P2']}
}, {
id: 'P2',
t: 'measure',
v: true,
tf: [[5, 0.1, 4], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: { in: [], out: [], center: ['P1', 'P3'] }
dt: {in: [], out: [], center: ['P1', 'P3']}
}, {
id: 'P3',
t: 'measure',
v: true,
tf: [[5, 0.1, 6.25], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: { in: [], out: [], center: ['P2'] }
dt: {in: [], out: [], center: ['P2']}
}, {
id: '39zML1rnSOOQGQYQ2YUMGy',
t: 'way',
v: true,
tf: [[-4, 0.1, 2], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: { in: [], out: [], center: ['6wrGKiVJniwgKkoggOoEy6'] }
dt: {in: [], out: [], center: ['6wrGKiVJniwgKkoggOoEy6']}
}, {
id: '6wrGKiVJniwgKkoggOoEy6',
t: 'way',
v: true,
tf: [[5, 0.1, 2], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: { in: [], out: [], center: ['39zML1rnSOOQGQYQ2YUMGy'] }
dt: {in: [], out: [], center: ['39zML1rnSOOQGQYQ2YUMGy']}
}, {
id: '6UhIIw9QPYh6acwyW8OSGs',
t: 'gstore',
v: true,
tf: [[-1, 0.1, 0.55], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], storeWidth: 1.4, storeDepth: 1.4 }
dt: {in: [], out: [], center: [], storeWidth: 1.4, storeDepth: 1.4}
}, {
id: '1D0WSRPj8JJJwIcmA0UMqG',
t: 'gstore',
v: true,
tf: [[0.75, 0.1, 0.55], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], storeWidth: 1.4, storeDepth: 1.4 }
dt: {in: [], out: [], center: [], storeWidth: 1.4, storeDepth: 1.4}
}, {
id: 'gstore3',
t: 'gstore',
v: true,
tf: [[3, 0.1, 0.55], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], storeWidth: 1.4, storeDepth: 1.4 }
},{
dt: {in: [], out: [], center: [], storeWidth: 1.4, storeDepth: 1.4}
}, {
id: 'pallet1',
t: 'pallet',
v: true,
tf: [[0.75, 0.075, 0.55], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2 }
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}, {
id: 'pallet2',
t: 'pallet',
v: true,
tf: [[3, 0.075, 0.55], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2 }
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}, {
id: 'ptr1',
t: 'ptr',
v: true,
tf: [[0.75, 0.075, 2], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], ptrWidth: 1.5, ptrDepth: 1.5, ptrHeight: 1.98 }
dt: {in: [], out: [], center: [], ptrWidth: 1.5, ptrDepth: 1.5, ptrHeight: 1.98}
}, {
id: 'ptr2',
t: 'ptr',
v: true,
tf: [[3, 0.075, 2], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], ptrWidth: 1.5, ptrDepth: 1.5, ptrHeight: 1.98 }
dt: {in: [], out: [], center: [], ptrWidth: 1.5, ptrDepth: 1.5, ptrHeight: 1.98}
}, {
id: 'pallet3',
t: 'pallet',
v: true,
tf: [[3, 0.175, 1.9], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2 }
tf: [[3, 0.175, 1.88], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}, {
id: 'pallet4',
t: 'pallet',
v: true,
tf: [[0.75, 0.175, 3.5], [0, 0, 0], [1.5, 1.2, 0.1]],
dt: { in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2 }
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}
]
},
{
catalogCode: 'f2', t: 'floor', // 楼层
items: [{
id: 'rack1',
t: 'rack',
v: true,
tf: [[4.196, 0.1, 5.882], [0, 270, 0], [1, 1, 1]],
dt: {
rackDepth: 1,
rackWidth: 5.1,
rackHeight: 4.2,
levelCount: 3,
bayCount: 4,
hideFloor: false,
extendColumns: true,
columnSpacing: 1,
bays: [
{bayWidth: 1.275, levelHeight: [1.4, 1.4, 1.4]},
{bayWidth: 1.275, levelHeight: [1.4, 1.4, 1.4]},
{bayWidth: 1.275, levelHeight: [1.4, 1.4, 1.4]},
{bayWidth: 1.275, levelHeight: [1.4, 1.4, 1.4]}],
center: [],
in: [],
out: []
}
}, {id: '3ExXFSuV9WB2WMY2Quyq6L', t: 'measure', v: true, tf: [[0, 0.1, 0], [90, 0, 0], [0.1, 0.1, 0.1]], dt: {in: [], out: [], center: ['4YZKo6XtvL2migaIUmakAr', '7Ik2sRdDZy8Q6sC00AaqCv']}}, {
id: '3ExXFSuV9WB2WMY2Quyq6L',
t: 'measure',
v: true,
tf: [[0, 0.1, 0], [90, 0, 0], [0.1, 0.1, 0.1]],
dt: {in: [], out: [], center: ['4YZKo6XtvL2migaIUmakAr', '7Ik2sRdDZy8Q6sC00AaqCv']}
}, {id: '4YZKo6XtvL2migaIUmakAr', t: 'measure', v: true, tf: [[8.4, 0.1, 0], [90, 0, 0], [0.1, 0.1, 0.1]], dt: {in: [], out: [], center: ['3ExXFSuV9WB2WMY2Quyq6L', '3cdb6OHkp132soSsgW8McA']}}, {
id: '3cdb6OHkp132soSsgW8McA',
t: 'measure',
v: true,
tf: [[8.4, 0.1, 9], [90, 0, 0], [0.1, 0.1, 0.1]],
dt: {in: [], out: [], center: ['4YZKo6XtvL2migaIUmakAr', '7Ik2sRdDZy8Q6sC00AaqCv']}
}, {id: '7Ik2sRdDZy8Q6sC00AaqCv', t: 'measure', v: true, tf: [[0, 0.1, 9], [90, 0, 0], [0.1, 0.1, 0.1]], dt: {in: [], out: [], center: ['3cdb6OHkp132soSsgW8McA', '3ExXFSuV9WB2WMY2Quyq6L']}}, {
id: '6Vu3dX1V7Si0ISWIiCkoEh',
t: 'gstore',
v: true,
tf: [[1.5, 0.1, 0.63], [0, 0, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], storeWidth: 1.1, storeDepth: 1.3}
}, {id: '592UY0EMScbwIyQqgs8aAs', t: 'gstore', v: true, tf: [[3.9, 0.1, 0.63], [0, 0, 0], [1, 1, 1]], dt: {in: [], out: [], center: [], storeWidth: 1.1, storeDepth: 1.3}}, {
id: '38TYyVWMGLf8OogQMIiSOz',
t: 'gstore',
v: true,
tf: [[7.1, 0.1, 2.865], [0, 90, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], storeWidth: 1.1, storeDepth: 1.3}
}, {id: '1hAaZ1xtvukZowAKeWAcqs', t: 'gstore', v: true, tf: [[7.1, 0.1, 4.35], [0, 90, 0], [1, 1, 1]], dt: {in: [], out: [], center: [], storeWidth: 1.1, storeDepth: 1.3}}, {
id: '28GxDYUqDwZc2WsOgMU2wi',
t: 'gstore',
v: true,
tf: [[7.1, 0.1, 6.75], [0, 90, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], storeWidth: 1.1, storeDepth: 1.3}
}, {id: '2fWOnUmFpvYyCWEqAyU0QC', t: 'way', v: true, tf: [[1.5, 0.1, 2.13], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['09PTEMUnACWY0MUG4qmk0r']}}, {
id: '09PTEMUnACWY0MUG4qmk0r',
t: 'way',
v: true,
tf: [[2.7, 0.1, 2.13], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['2fWOnUmFpvYyCWEqAyU0QC', '2CSDVrpqthaiQuyWUymCwy', '0mVU9FacN1fmCAmQqwWgIZ']}
}, {id: '2CSDVrpqthaiQuyWUymCwy', t: 'way', v: true, tf: [[3.9, 0.1, 2.13], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['09PTEMUnACWY0MUG4qmk0r']}}, {
id: '0mVU9FacN1fmCAmQqwWgIZ',
t: 'way',
v: true,
tf: [[2.7, 0.1, 2.832], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['09PTEMUnACWY0MUG4qmk0r', '7LuzEYQQI7OQcEUekEqWcm']}
}, {id: '7LuzEYQQI7OQcEUekEqWcm', t: 'way', v: true, tf: [[2.7, 0.1, 3.932], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['0mVU9FacN1fmCAmQqwWgIZ', '2RForJhOHXtcw0gq8mYAMh']}}, {
id: '2RForJhOHXtcw0gq8mYAMh',
t: 'way',
v: true,
tf: [[2.7, 0.1, 4.582], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['7LuzEYQQI7OQcEUekEqWcm', '32vDSCKBrgMWycW0ySIgsJ']}
}, {id: '32vDSCKBrgMWycW0ySIgsJ', t: 'way', v: true, tf: [[2.7, 0.1, 5.232], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['2RForJhOHXtcw0gq8mYAMh', '0wcYKcGQialFQCGkAa6aYB']}}, {
id: '0wcYKcGQialFQCGkAa6aYB',
t: 'way',
v: true,
tf: [[2.7, 0.1, 5.882], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['32vDSCKBrgMWycW0ySIgsJ', '55g6mUWBdozg4m2ueUEUsy']}
}, {id: '55g6mUWBdozg4m2ueUEUsy', t: 'way', v: true, tf: [[2.7, 0.1, 6.532], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['0wcYKcGQialFQCGkAa6aYB', '5iKoIUBhnU08EM0IsoyOSW']}}, {
id: '5iKoIUBhnU08EM0IsoyOSW',
t: 'way',
v: true,
tf: [[2.7, 0.1, 7.632], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['55g6mUWBdozg4m2ueUEUsy']}
}, {
id: '3ZP01pHXJRuyeg24oCaaMq',
t: 'way',
v: true,
tf: [[5.65, 0.1, 2.13], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['5onDSGuIKBpUQo6g0EIsuS']}
}, {id: '5onDSGuIKBpUQo6g0EIsuS', t: 'way', v: true, tf: [[5.65, 0.1, 2.865], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['3ZP01pHXJRuyeg24oCaaMq', '41A0CKR8cFW8wKkcSMQ4uk']}}, {
id: '41A0CKR8cFW8wKkcSMQ4uk',
t: 'way',
v: true,
tf: [[5.65, 0.1, 3.932], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['5onDSGuIKBpUQo6g0EIsuS', '4PunEz5C3Xk66EaOgMEuMq']}
}, {id: '4PunEz5C3Xk66EaOgMEuMq', t: 'way', v: true, tf: [[5.65, 0.1, 4.348], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['41A0CKR8cFW8wKkcSMQ4uk', '6oCW8i0dpRtuCEIWIaAcQi']}}, {
id: '6oCW8i0dpRtuCEIWIaAcQi',
t: 'way',
v: true,
tf: [[5.65, 0.1, 5.232], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['4PunEz5C3Xk66EaOgMEuMq', '3C9Z8c6oxQbWcS4uSGkC8b']}
}, {id: '3C9Z8c6oxQbWcS4uSGkC8b', t: 'way', v: true, tf: [[5.65, 0.1, 5.882], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['6oCW8i0dpRtuCEIWIaAcQi', '1jJX8KZLMPSSCwuCOU6AQz']}}, {
id: '1jJX8KZLMPSSCwuCOU6AQz',
t: 'way',
v: true,
tf: [[5.65, 0.1, 6.532], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['3C9Z8c6oxQbWcS4uSGkC8b', '0aJ81sOKqm9FYo60AIQmMG']}
}, {id: '0aJ81sOKqm9FYo60AIQmMG', t: 'way', v: true, tf: [[5.65, 0.1, 6.744], [90, 0, 0], [0.25, 0.25, 0.1]], dt: {in: [], out: [], center: ['1jJX8KZLMPSSCwuCOU6AQz', '2qtxSDVn30EcI2uY4W0CWf']}}, {
id: '2qtxSDVn30EcI2uY4W0CWf',
t: 'way',
v: true,
tf: [[5.65, 0.1, 7.632], [90, 0, 0], [0.25, 0.25, 0.1]],
dt: {in: [], out: [], center: ['0aJ81sOKqm9FYo60AIQmMG']}
}, {
id: 'ptr1',
t: 'ptr',
v: true,
tf: [[5.65, 0.1, 2.865], [0, -90, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], ptrWidth: 1.5, ptrDepth: 1.5, ptrHeight: 1.98}
}, {
id: 'clx1',
t: 'clx',
v: true,
tf: [[1.5, 0.1, 2.13], [0, 0, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], clxWidth: 1.65, clxDepth: 1.65, clxHeight: 3.393}
}, {
id: 'charger1',
t: 'charger',
v: true,
tf: [[2.696, 0.1, 8.75], [0, 0, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], chargerWidth: 0.53, chargerDepth: 0.275, clxHeight: 0.3}
}, {
id: 'charger2',
t: 'charger',
v: true,
tf: [[5.655, 0.1, 8.75], [0, 0, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], chargerWidth: 0.53, chargerDepth: 0.275, clxHeight: 0.3}
}, {
id: 'pallet1122',
t: 'pallet',
v: true,
tf: [[1.5, 0.1, 0.63], [0, 0, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}, {
id: 'pallet1123',
t: 'pallet',
v: true,
tf: [[7.100, 0.1, 4.35], [0, 90, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}, {
id: 'pallet1124',
t: 'pallet',
v: true,
tf: [[4.196, 0.1, 3.95], [0, 90, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}, {
id: 'pallet1125',
t: 'pallet',
v: true,
tf: [[4.196, 0.1, 5.225], [0, 90, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}, {
id: 'pallet1126',
t: 'pallet',
v: true,
tf: [[4.196, 0.1, 7.775], [0, 90, 0], [1, 1, 1]],
dt: {in: [], out: [], center: [], palletWidth: 1, palletDepth: 1.2}
}]
}
],
elevator: [], // 电梯
@ -196,41 +367,41 @@ export default {
{
label: '仓库楼层', // 目录分组名
items: [
{ catalogCode: '-f1', label: '地下室 (-f1)' }, // 目录项
{ catalogCode: 'f1', label: '一楼 (f1)' },
{ catalogCode: 'f2', label: '二楼 (f2)' },
{ catalogCode: 'OUT', label: '外场 (OUT)' },
{ catalogCode: 'fe', label: '楼层电梯 (fe)' }
{catalogCode: '-f1', label: '地下室 (-f1)'}, // 目录项
{catalogCode: 'f1', label: '一楼 (f1)'},
{catalogCode: 'f2', label: '二楼 (f2)'},
{catalogCode: 'OUT', label: '外场 (OUT)'},
{catalogCode: 'fe', label: '楼层电梯 (fe)'}
]
},
{
label: '密集库区域',
items: [
{ catalogCode: 'm1', label: 'M1 (m1)' },
{ catalogCode: 'm2', label: 'M2 (m2)' },
{ catalogCode: 'm3', label: 'M3 (m3)' },
{ catalogCode: 'm4', label: 'M4 (m4)' },
{ catalogCode: 'me', label: '提升机 (me)' }
{catalogCode: 'm1', label: 'M1 (m1)'},
{catalogCode: 'm2', label: 'M2 (m2)'},
{catalogCode: 'm3', label: 'M3 (m3)'},
{catalogCode: 'm4', label: 'M4 (m4)'},
{catalogCode: 'me', label: '提升机 (me)'}
]
},
{
label: '多穿库A',
items: [
{ catalogCode: 'd1', label: 'D1 (d1)' },
{ catalogCode: 'd2', label: 'D2 (d2)' },
{ catalogCode: 'd3', label: 'D3 (d3)' },
{ catalogCode: 'd4', label: 'D4 (d4)' },
{ catalogCode: 'de1', label: '提升机 (de1)' }
{catalogCode: 'd1', label: 'D1 (d1)'},
{catalogCode: 'd2', label: 'D2 (d2)'},
{catalogCode: 'd3', label: 'D3 (d3)'},
{catalogCode: 'd4', label: 'D4 (d4)'},
{catalogCode: 'de1', label: '提升机 (de1)'}
]
},
{
label: '多穿库B',
items: [
{ catalogCode: 'e1', label: 'E1 (e1)' },
{ catalogCode: 'e2', label: 'E2 (e2)' },
{ catalogCode: 'e3', label: 'E3 (e3)' },
{ catalogCode: 'e4', label: 'E4 (e4)' },
{ catalogCode: 'ee1', label: '提升机 (ee1)' }
{catalogCode: 'e1', label: 'E1 (e1)'},
{catalogCode: 'e2', label: 'E2 (e2)'},
{catalogCode: 'e3', label: 'E3 (e3)'},
{catalogCode: 'e4', label: 'E4 (e4)'},
{catalogCode: 'ee1', label: '提升机 (ee1)'}
]
}
]

5
src/modules/charger/ChargerEntity.ts

@ -0,0 +1,5 @@
import BaseEntity from '@/core/base/BaseItemEntity.ts'
export default class ChargerEntity extends BaseEntity {
}

22
src/modules/charger/ChargerInteraction.ts

@ -0,0 +1,22 @@
import BaseInteraction from '@/core/base/BaseInteraction.ts'
import * as THREE from 'three'
export default class ChargerInteraction extends BaseInteraction {
get isSinglePointMode(): boolean {
return true
}
constructor(itemTypeName: string) {
super(itemTypeName)
}
createPointOfItem(item: ItemJson, point: THREE.Vector3): ItemJson {
item = super.createPointOfItem(item, point)
// 创建一个地堆货架
item.dt.palletWidth = 1 // 宽度
item.dt.palletDepth = 1.2 // 深度
return item
}
}

10
src/modules/rack/RackMeta.ts → src/modules/charger/ChargerMeta.ts

@ -8,14 +8,8 @@ export default [
{ field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
{ editor: '-', category: 'basic' },
{ field: 'dt.rackDepth', editor: 'NumberInput', label: '货架深度', category: 'basic' },
{ field: 'dt.levelCount', editor: 'NumberInput', label: '总层数', category: 'basic' },
{ field: 'dt.bayCount', editor: 'NumberInput', label: '总列数', category: 'basic' },
{ field: 'dt.hideFloor', editor: 'NumberInput', label: '隐藏底板', category: 'basic' },
{ field: 'dt.extendColumns', editor: 'NumberInput', label: '扩展挡板', category: 'basic' },
{ field: 'dt.columnSpacing', editor: 'NumberInput', label: '支脚跨越', category: 'basic' },
{ field: 'dt.bays', editor: 'BayEditor', category: 'basic' },
{ field: 'dt.chargerWidth', editor: 'NumberInput', label: '充电桩宽度', category: 'basic' },
{ field: 'dt.chargerDepth', editor: 'NumberInput', label: '充电桩深度', category: 'basic' },
/**
* dt.bays 53
* {

97
src/modules/charger/ChargerRenderer.ts

@ -0,0 +1,97 @@
import * as THREE from 'three'
import BaseRenderer from '@/core/base/BaseRenderer.ts'
import { Line2 } from 'three/examples/jsm/lines/Line2.js'
import { LineGeometry } from 'three/examples/jsm/lines/LineGeometry.js'
import { LineMaterial } from 'three/examples/jsm/lines/LineMaterial.js'
import {decimalSumBy} from "@/core/ModelUtils";
import Constract from '@/core/Constract.ts'
import chargerUrl from '@/assets/images/ptr/charger.png'
/**
*
*/
export default class ChargerRenderer extends BaseRenderer {
static POINT_NAME = 'charger'
pointMaterial: THREE.Material
/**
* ,
*/
readonly defulePositionY: number = Constract.HEIGHT_WAY
readonly defaultScale: THREE.Vector3 = new THREE.Vector3(1, 1, 1)
readonly defaultRotation: THREE.Vector3 = new THREE.Vector3(0, 0, 0)
readonly defaultLineWidth: number = 0.15
constructor(itemTypeName: string) {
super(itemTypeName)
}
/**
* 使 storeWidth/storeDepth, TF无效
*/
override afterCreateOrUpdatePoint(item: ItemJson, option: RendererCudOption, objects: THREE.Object3D[]) {
super.afterCreateOrUpdatePoint(item, option, objects)
const point = objects[0]
// point.position.y = this.defulePositionY
// point.scale.set(_.sumBy(item.dt.bays, b=>b.bayWidth), this.defaultScale.y, item.dt.rackDepth)
point.rotation.set(
THREE.MathUtils.degToRad(item.tf[1][0]),
THREE.MathUtils.degToRad(item.tf[1][1]),
THREE.MathUtils.degToRad(item.tf[1][2])
)
}
createLineBasic(start: ItemJson, end: ItemJson, type: LinkType): THREE.Object3D[] {
throw new Error('not allow store line.')
}
updateLine(start: ItemJson, end: ItemJson, type: LinkType, option?: RendererCudOption) {
throw new Error('not allow store line.')
}
createPoint(item: ItemJson, option?: RendererCudOption): THREE.Object3D[] {
// 创建平面几何体
if (!item.dt.chargerWidth || !item.dt.chargerDepth) {
return []
}
const textureLoader = new THREE.TextureLoader()
const texture = textureLoader.load(chargerUrl)
const group = new THREE.Group()
group.name = ChargerRenderer.POINT_NAME
// 绘制背景矩形框
const planeGeometry = new THREE.PlaneGeometry(item.dt.chargerWidth, item.dt.chargerDepth);
planeGeometry.rotateX(-Math.PI / 2)
const planeMaterial = new THREE.MeshLambertMaterial({
map: texture, // 颜色贴图
transparent: true, // 允许透明纹理
});
const planeMesh = new THREE.Mesh(planeGeometry, planeMaterial);
group.add(planeMesh)
// 设置位置
group.position.set(item.tf[0][0], item.tf[0][1], item.tf[0][2])
const points = [group]
this.fillObjectUserDataFromItem(item, ...points)
this.afterCreateOrUpdatePoint(item, option, points)
this.tempViewport.entityManager.appendObject(item.id, points)
this.appendToScene(...points)
return points
}
dispose() {
super.dispose()
this.pointMaterial?.dispose()
}
createPointBasic(item: ItemJson, option?: RendererCudOption): Object3D[] {
return [];
}
}

15
src/modules/charger/index.ts

@ -0,0 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import ChargerRenderer from './ChargerRenderer.ts'
import ChargerEntity from './ChargerEntity.ts'
import ChargerMeta from './ChargerMeta.ts'
import ChargerInteraction from './ChargerInteraction.ts'
export const ITEM_TYPE_NAME = 'charger'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new ChargerRenderer(ITEM_TYPE_NAME),
interaction: new ChargerInteraction(ITEM_TYPE_NAME),
meta: ChargerMeta,
entity: ChargerEntity
})

5
src/modules/clx/ClxEntity.ts

@ -0,0 +1,5 @@
import BaseEntity from '@/core/base/BaseItemEntity.ts'
export default class ClxEntity extends BaseEntity {
}

22
src/modules/clx/ClxInteraction.ts

@ -0,0 +1,22 @@
import BaseInteraction from '@/core/base/BaseInteraction.ts'
import * as THREE from 'three'
export default class ClxInteraction extends BaseInteraction {
get isSinglePointMode(): boolean {
return true
}
constructor(itemTypeName: string) {
super(itemTypeName)
}
createPointOfItem(item: ItemJson, point: THREE.Vector3): ItemJson {
item = super.createPointOfItem(item, point)
// 创建一个地堆货架
item.dt.palletWidth = 1 // 宽度
item.dt.palletDepth = 1.2 // 深度
return item
}
}

4
src/modules/pallet/PalletMeta.ts → src/modules/clx/ClxMeta.ts

@ -8,8 +8,8 @@ export default [
{ field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
{ editor: '-', category: 'basic' },
{ field: 'dt.palletWidth', editor: 'NumberInput', label: '托盘深度', category: 'basic' },
{ field: 'dt.palletDepth', editor: 'NumberInput', label: '托盘深度', category: 'basic' },
{ field: 'dt.clxWidth', editor: 'NumberInput', label: 'CLX宽度', category: 'basic' },
{ field: 'dt.clxDepth', editor: 'NumberInput', label: 'CLX深度', category: 'basic' },
/**
* dt.bays 53
* {

97
src/modules/clx/ClxRenderer.ts

@ -0,0 +1,97 @@
import * as THREE from 'three'
import BaseRenderer from '@/core/base/BaseRenderer.ts'
import { Line2 } from 'three/examples/jsm/lines/Line2.js'
import { LineGeometry } from 'three/examples/jsm/lines/LineGeometry.js'
import { LineMaterial } from 'three/examples/jsm/lines/LineMaterial.js'
import {decimalSumBy} from "@/core/ModelUtils";
import Constract from '@/core/Constract.ts'
import clxUrl from '@/assets/images/ptr/clx.png'
/**
* clx渲染器
*/
export default class ClxRenderer extends BaseRenderer {
static POINT_NAME = 'clx'
pointMaterial: THREE.Material
/**
* ,
*/
readonly defulePositionY: number = Constract.HEIGHT_WAY
readonly defaultScale: THREE.Vector3 = new THREE.Vector3(1, 1, 1)
readonly defaultRotation: THREE.Vector3 = new THREE.Vector3(0, 0, 0)
readonly defaultLineWidth: number = 0.15
constructor(itemTypeName: string) {
super(itemTypeName)
}
/**
* 使 storeWidth/storeDepth, TF无效
*/
override afterCreateOrUpdatePoint(item: ItemJson, option: RendererCudOption, objects: THREE.Object3D[]) {
super.afterCreateOrUpdatePoint(item, option, objects)
const point = objects[0]
// point.position.y = this.defulePositionY
// point.scale.set(_.sumBy(item.dt.bays, b=>b.bayWidth), this.defaultScale.y, item.dt.rackDepth)
point.rotation.set(
THREE.MathUtils.degToRad(item.tf[1][0]),
THREE.MathUtils.degToRad(item.tf[1][1]),
THREE.MathUtils.degToRad(item.tf[1][2])
)
}
createLineBasic(start: ItemJson, end: ItemJson, type: LinkType): THREE.Object3D[] {
throw new Error('not allow store line.')
}
updateLine(start: ItemJson, end: ItemJson, type: LinkType, option?: RendererCudOption) {
throw new Error('not allow store line.')
}
createPoint(item: ItemJson, option?: RendererCudOption): THREE.Object3D[] {
// 创建平面几何体
if (!item.dt.clxWidth || !item.dt.clxDepth) {
return []
}
const textureLoader = new THREE.TextureLoader()
const texture = textureLoader.load(clxUrl)
const group = new THREE.Group()
group.name = ClxRenderer.POINT_NAME
// 绘制背景矩形框
const planeGeometry = new THREE.PlaneGeometry(item.dt.clxWidth, item.dt.clxDepth);
planeGeometry.rotateX(-Math.PI / 2)
const planeMaterial = new THREE.MeshLambertMaterial({
map: texture, // 颜色贴图
transparent: true, // 允许透明纹理
});
const planeMesh = new THREE.Mesh(planeGeometry, planeMaterial);
group.add(planeMesh)
// 设置位置
group.position.set(item.tf[0][0], item.tf[0][1], item.tf[0][2])
const points = [group]
this.fillObjectUserDataFromItem(item, ...points)
this.afterCreateOrUpdatePoint(item, option, points)
this.tempViewport.entityManager.appendObject(item.id, points)
this.appendToScene(...points)
return points
}
dispose() {
super.dispose()
this.pointMaterial?.dispose()
}
createPointBasic(item: ItemJson, option?: RendererCudOption): Object3D[] {
return [];
}
}

15
src/modules/clx/index.ts

@ -0,0 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import ClxRenderer from './ClxRenderer.ts'
import ClxEntity from './ClxEntity.ts'
import ClxMeta from './ClxMeta.ts'
import ClxInteraction from './ClxInteraction.ts'
export const ITEM_TYPE_NAME = 'clx'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new ClxRenderer(ITEM_TYPE_NAME),
interaction: new ClxInteraction(ITEM_TYPE_NAME),
meta: ClxMeta,
entity: ClxEntity
})

14
src/modules/gstore/GstoreMeta.ts

@ -1,14 +0,0 @@
import type { IMeta } from '@/core/base/IMeta.ts'
export default [
{ field: 'uuid', editor: 'UUID', label: 'uuid', readonly: true, category: 'basic' },
{ field: 'name', editor: 'TextInput', label: '名称', category: 'basic' },
{ field: 'dt.label', editor: 'TextInput', label: '标签', category: 'basic' },
{ editor: 'TransformEditor', category: 'basic' },
{ field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
{ editor: '-', category: 'basic' },
{ field: 'tf', editor: 'InOutCenterEditor', category: 'basic' },
{ field: 'dt.selectable', editor: 'Switch', label: '可选中', category: 'basic' },
{ field: 'dt.protected', editor: 'Switch', label: '受保护', category: 'basic' },
{ field: 'visible', editor: 'Switch', label: '可见', category: 'basic' }
] as IMeta

12
src/modules/gstore/GstorePropertySetter.ts

@ -0,0 +1,12 @@
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
const propertySetter: PropertySetter = {
flatten: {
fields: [
...basicFieldsSetter,
],
},
};
export default propertySetter;

6
src/modules/gstore/GstoreRenderer.ts

@ -35,9 +35,9 @@ export default class GstoreRenderer extends BaseRenderer {
point.position.y = this.defulePositionY
// point.scale.set(item.dt.storeWidth, this.defaultScale.y, item.dt.storeDepth)
point.rotation.set(
THREE.MathUtils.degToRad(this.defaultRotation.x),
THREE.MathUtils.degToRad(this.defaultRotation.y),
THREE.MathUtils.degToRad(this.defaultRotation.z)
THREE.MathUtils.degToRad(item.tf[1][0]),
THREE.MathUtils.degToRad(item.tf[1][1]),
THREE.MathUtils.degToRad(item.tf[1][2])
)
}

12
src/modules/gstore/index.ts

@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import GstoreRenderer from './GstoreRenderer.ts'
import GstoreEntity from './GstoreEntity.ts'
import GstoreMeta from './GstoreMeta.ts'
import GstoreInteraction from './GstoreInteraction.ts'
import propertySetter from "@/modules/gstore/GstorePropertySetter.ts";
export const ITEM_TYPE_NAME = 'gstore'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new GstoreRenderer(ITEM_TYPE_NAME),
interaction: new GstoreInteraction(ITEM_TYPE_NAME),
meta: GstoreMeta,
entity: GstoreEntity
name: ITEM_TYPE_NAME,
renderer: new GstoreRenderer(ITEM_TYPE_NAME),
interaction: new GstoreInteraction(ITEM_TYPE_NAME),
setter: propertySetter,
entity: GstoreEntity,
})

15
src/modules/measure/MeasureMeta.ts

@ -1,15 +0,0 @@
import type { IMeta } from '@/core/base/IMeta.ts'
const MeasureMeta: IMeta = [
{ field: 'uuid', editor: 'UUID', label: 'uuid', readonly: true, category: 'basic' },
{ field: 'name', editor: 'TextInput', label: '名称', category: 'basic' },
{ field: 'dt.label', editor: 'TextInput', label: '标签', category: 'basic' },
{ editor: 'TransformEditor', category: 'basic' },
{ field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
{ editor: '-', category: 'basic' },
{ field: 'tf', editor: 'InOutCenterEditor', category: 'basic' },
{ field: 'dt.selectable', editor: 'Switch', label: '可选中', category: 'basic' },
{ field: 'dt.protected', editor: 'Switch', label: '受保护', category: 'basic' },
{ field: 'visible', editor: 'Switch', label: '可见', category: 'basic' }
]
export default MeasureMeta

12
src/modules/measure/MeasurePropertySetter.ts

@ -0,0 +1,12 @@
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
const propertySetter: PropertySetter = {
flatten: {
fields: [
...basicFieldsSetter,
],
},
};
export default propertySetter;

12
src/modules/measure/index.ts

@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import MeasureRenderer from './MeasureRenderer.ts'
import MeasureEntity from './MeasureEntity.ts'
import MeasureMeta from './MeasureMeta.ts'
import MeasureInteraction from './MeasureInteraction.ts'
import propertySetter from "@/modules/measure/MeasurePropertySetter.ts";
export const ITEM_TYPE_NAME = 'measure'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new MeasureRenderer(ITEM_TYPE_NAME),
interaction: new MeasureInteraction(ITEM_TYPE_NAME),
meta: MeasureMeta,
entity: MeasureEntity
name: ITEM_TYPE_NAME,
renderer: new MeasureRenderer(ITEM_TYPE_NAME),
interaction: new MeasureInteraction(ITEM_TYPE_NAME),
setter: propertySetter,
entity: MeasureEntity,
})

20
src/modules/pallet/PalletPropertySetter.ts

@ -0,0 +1,20 @@
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
const propertySetter: PropertySetter = {
flatten: {
fields: [
...basicFieldsSetter,
{
dataPath: 'dt.palletWidth', label: '托盘宽度', input: 'InputNumber',
inputProps: {},
},
{
dataPath: 'dt.palletDepth', label: '托盘深度', input: 'InputNumber',
inputProps: {},
},
],
},
};
export default propertySetter;

6
src/modules/pallet/PalletRenderer.ts

@ -37,9 +37,9 @@ export default class PalletRenderer extends BaseRenderer {
//point.scale.set(_.sumBy(item.dt.bays, b=>b.bayWidth), this.defaultScale.y, item.dt.rackDepth)
point.rotation.set(
THREE.MathUtils.degToRad(this.defaultRotation.x),
THREE.MathUtils.degToRad(this.defaultRotation.y),
THREE.MathUtils.degToRad(this.defaultRotation.z)
THREE.MathUtils.degToRad(item.tf[1][0]),
THREE.MathUtils.degToRad(item.tf[1][1]),
THREE.MathUtils.degToRad(item.tf[1][2])
)
}

12
src/modules/pallet/index.ts

@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import PalletRenderer from './PalletRenderer.ts'
import PalletEntity from './PalletEntity.ts'
import PalletMeta from './PalletMeta.ts'
import PalletInteraction from './PalletInteraction.ts'
import propertySetter from "@/modules/pallet/PalletPropertySetter.ts";
export const ITEM_TYPE_NAME = 'pallet'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new PalletRenderer(ITEM_TYPE_NAME),
interaction: new PalletInteraction(ITEM_TYPE_NAME),
meta: PalletMeta,
entity: PalletEntity
name: ITEM_TYPE_NAME,
renderer: new PalletRenderer(ITEM_TYPE_NAME),
interaction: new PalletInteraction(ITEM_TYPE_NAME),
setter: propertySetter,
entity: PalletEntity,
})

4
src/modules/ptr/PtrMeta.ts

@ -8,8 +8,8 @@ export default [
{ field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
{ editor: '-', category: 'basic' },
{ field: 'dt.palletWidth', editor: 'NumberInput', label: '托盘深度', category: 'basic' },
{ field: 'dt.palletDepth', editor: 'NumberInput', label: '托盘深度', category: 'basic' },
{ field: 'dt.ptrWidth', editor: 'NumberInput', label: 'PTR宽度', category: 'basic' },
{ field: 'dt.ptrDepth', editor: 'NumberInput', label: 'PTR深度', category: 'basic' },
/**
* dt.bays 53
* {

20
src/modules/ptr/PtrPropertySetter.ts

@ -0,0 +1,20 @@
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
const propertySetter: PropertySetter = {
flatten: {
fields: [
...basicFieldsSetter,
{
dataPath: 'dt.palletWidth', label: '托盘宽度', input: 'InputNumber',
inputProps: {},
},
{
dataPath: 'dt.palletDepth', label: '托盘深度', input: 'InputNumber',
inputProps: {},
},
],
},
};
export default propertySetter;

7
src/modules/ptr/PtrRenderer.ts

@ -37,9 +37,9 @@ export default class PtrRenderer extends BaseRenderer {
// point.position.y = this.defulePositionY
// point.scale.set(_.sumBy(item.dt.bays, b=>b.bayWidth), this.defaultScale.y, item.dt.rackDepth)
point.rotation.set(
THREE.MathUtils.degToRad(this.defaultRotation.x),
THREE.MathUtils.degToRad(this.defaultRotation.y),
THREE.MathUtils.degToRad(this.defaultRotation.z)
THREE.MathUtils.degToRad(item.tf[1][0]),
THREE.MathUtils.degToRad(item.tf[1][1]),
THREE.MathUtils.degToRad(item.tf[1][2])
)
}
@ -68,7 +68,6 @@ export default class PtrRenderer extends BaseRenderer {
// 绘制背景矩形框
const planeGeometry = new THREE.PlaneGeometry(item.dt.ptrWidth, item.dt.ptrDepth);
planeGeometry.rotateX(-Math.PI / 2)
planeGeometry.rotateY(-Math.PI / 2)
const planeMaterial = new THREE.MeshLambertMaterial({
map: texture, // 颜色贴图
transparent: true, // 允许透明纹理

12
src/modules/ptr/index.ts

@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import PtrRenderer from './PtrRenderer.ts'
import PtrEntity from './PtrEntity.ts'
import PtrMeta from './PtrMeta.ts'
import PtrInteraction from './PtrInteraction.ts'
import propertySetter from "@/modules/ptr/PtrPropertySetter.ts";
export const ITEM_TYPE_NAME = 'ptr'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new PtrRenderer(ITEM_TYPE_NAME),
interaction: new PtrInteraction(ITEM_TYPE_NAME),
meta: PtrMeta,
entity: PtrEntity
name: ITEM_TYPE_NAME,
renderer: new PtrRenderer(ITEM_TYPE_NAME),
interaction: new PtrInteraction(ITEM_TYPE_NAME),
setter: propertySetter,
entity: PtrEntity,
})

64
src/modules/rack/RackPropertySetter.ts

@ -0,0 +1,64 @@
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
const propertySetter: PropertySetter = {
flatten: {
fields: [
...basicFieldsSetter,
{
dataPath: 'dt.rackDepth', label: '货架深度', input: 'InputNumber',
inputProps: {},
},
{
dataPath: 'dt.levelCount', label: '总层数', input: 'InputNumber',
inputProps: {},
},
{
dataPath: 'dt.bayCount', label: '总列数', input: 'InputNumber',
inputProps: {},
},
{
dataPath: 'dt.hideFloor', label: '隐藏底板', input: 'InputNumber',
inputProps: {},
},
{
dataPath: 'dt.extendColumns', label: '扩展挡板', input: 'InputNumber',
inputProps: {},
},
{
dataPath: 'dt.columnSpacing', label: '支脚跨越', input: 'InputNumber',
inputProps: {},
},
// {
// dataPath: 'dt.bays', input: 'BayEditor',
// inputProps: {
// },
// },
/**
* dt.bays 53
* {
* dt: {
* rackDepth: 1.1, // 货架深度
* levelCount: 3, // 总层数
* bayCount: 5, // 总列数
* hideFloor: false, // 隐藏底板
* extendColumns: true, // 扩展挡板
* columnSpacing: 1, // 支脚跨越
* bays: [ // 每列的配置
* {
* bayWidth: 1.6, // 列的宽度
* levelHeight: [ 1.4, 1.4, 1.4 ] // 每层的高度
* },
* {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
* {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
* {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
* {bayWidth: 1.6, levelHeight: [ 1.4, 1.4, 1.4 ]},
* ]
* }
* }
*/
],
},
};
export default propertySetter;

6
src/modules/rack/RackRenderer.ts

@ -37,9 +37,9 @@ export default class RackRenderer extends BaseRenderer {
//point.scale.set(_.sumBy(item.dt.bays, b=>b.bayWidth), this.defaultScale.y, item.dt.rackDepth)
point.rotation.set(
THREE.MathUtils.degToRad(this.defaultRotation.x),
THREE.MathUtils.degToRad(this.defaultRotation.y),
THREE.MathUtils.degToRad(this.defaultRotation.z)
THREE.MathUtils.degToRad(item.tf[1][0]),
THREE.MathUtils.degToRad(item.tf[1][1]),
THREE.MathUtils.degToRad(item.tf[1][2])
)
}

12
src/modules/rack/index.ts

@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import RackRenderer from './RackRenderer.ts'
import RackEntity from './RackEntity.ts'
import RackMeta from './RackMeta.ts'
import RackInteraction from './RackInteraction.ts'
import propertySetter from "@/modules/rack/RackPropertySetter.ts";
export const ITEM_TYPE_NAME = 'rack'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new RackRenderer(ITEM_TYPE_NAME),
interaction: new RackInteraction(ITEM_TYPE_NAME),
meta: RackMeta,
entity: RackEntity
name: ITEM_TYPE_NAME,
renderer: new RackRenderer(ITEM_TYPE_NAME),
interaction: new RackInteraction(ITEM_TYPE_NAME),
setter: propertySetter,
entity: RackEntity,
})

14
src/modules/way/WayMeta.ts

@ -1,14 +0,0 @@
import type { IMeta } from '@/core/base/IMeta.ts'
export default [
{ field: 'uuid', editor: 'UUID', label: 'uuid', readonly: true, category: 'basic' },
{ field: 'name', editor: 'TextInput', label: '名称', category: 'basic' },
{ field: 'dt.label', editor: 'TextInput', label: '标签', category: 'basic' },
{ editor: 'TransformEditor', category: 'basic' },
{ field: 'dt.color', editor: 'Color', label: '颜色', category: 'basic' },
{ editor: '-', category: 'basic' },
{ field: 'tf', editor: 'InOutCenterEditor', category: 'basic' },
{ field: 'dt.selectable', editor: 'Switch', label: '可选中', category: 'basic' },
{ field: 'dt.protected', editor: 'Switch', label: '受保护', category: 'basic' },
{ field: 'visible', editor: 'Switch', label: '可见', category: 'basic' }
] as IMeta

12
src/modules/way/WayPropertySetter.ts

@ -0,0 +1,12 @@
import type { PropertySetter } from "@/core/base/PropertyTypes.ts";
import { basicFieldsSetter } from "@/editor/widgets/property/PropertyPanelConstant.ts";
const propertySetter: PropertySetter = {
flatten: {
fields: [
...basicFieldsSetter,
],
},
};
export default propertySetter;

12
src/modules/way/index.ts

@ -1,15 +1,15 @@
import { defineModule } from '@/core/manager/ModuleManager.ts'
import WayRenderer from './WayRenderer.ts'
import WayEntity from './WayEntity.ts'
import WayMeta from './WayMeta.ts'
import WayInteraction from './WayInteraction.ts'
import propertySetter from "@/modules/way/WayPropertySetter.ts";
export const ITEM_TYPE_NAME = 'way'
export default defineModule({
name: ITEM_TYPE_NAME,
renderer: new WayRenderer(ITEM_TYPE_NAME),
interaction: new WayInteraction(ITEM_TYPE_NAME),
meta: WayMeta,
entity: WayEntity
name: ITEM_TYPE_NAME,
renderer: new WayRenderer(ITEM_TYPE_NAME),
interaction: new WayInteraction(ITEM_TYPE_NAME),
setter: propertySetter,
entity: WayEntity,
})

3
src/pages/DataForm01.vue

@ -2,7 +2,8 @@
import { createVNode, getCurrentInstance, reactive, toRaw } from "vue";
import { Format } from "@ease-forge/shared";
import { createBlockComponent } from "@ease-forge/runtime";
import DataForm, { type DataFormProps } from "@/components/data-form/DataForm.vue";
import DataForm from "@/components/data-form/DataForm.vue";
import type { DataFormProps } from "@/components/data-form/DataFormTypes.ts";
window.globalConfig.componentManage.registerComponent("DataForm", DataForm);

Loading…
Cancel
Save