mirror of
https://gitee.com/ice-gl/icegl-three-vue-tres.git
synced 2025-04-05 06:22:43 +08:00
feat: 开发完成第一版本的 适配qiankun的子应用
This commit is contained in:
parent
f3ff20ed68
commit
76f56be8c9
9
.fes.js
9
.fes.js
@ -4,7 +4,7 @@
|
|||||||
* @Autor: 地虎降天龙
|
* @Autor: 地虎降天龙
|
||||||
* @Date: 2023-10-16 10:53:09
|
* @Date: 2023-10-16 10:53:09
|
||||||
* @LastEditors: 地虎降天龙
|
* @LastEditors: 地虎降天龙
|
||||||
* @LastEditTime: 2025-04-01 15:43:12
|
* @LastEditTime: 2025-04-02 09:30:39
|
||||||
*/
|
*/
|
||||||
// import { resolve } from 'path';
|
// import { resolve } from 'path';
|
||||||
import { join } from 'path'
|
import { join } from 'path'
|
||||||
@ -104,7 +104,12 @@ export default defineBuildConfig({
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
server: {
|
server: {
|
||||||
|
server: {
|
||||||
|
headers: {
|
||||||
|
'Access-Control-Allow-Origin': '*',
|
||||||
|
},
|
||||||
|
},
|
||||||
host: '0.0.0.0',
|
host: '0.0.0.0',
|
||||||
proxy: {
|
proxy: {
|
||||||
'/resource.cos': {
|
'/resource.cos': {
|
||||||
|
BIN
public/plugins/qiankunTvt/preview/events.png
Normal file
BIN
public/plugins/qiankunTvt/preview/events.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 28 KiB |
BIN
public/plugins/qiankunTvt/preview/theBasic.png
Normal file
BIN
public/plugins/qiankunTvt/preview/theBasic.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 34 KiB |
20
src/app.jsx
20
src/app.jsx
@ -4,7 +4,7 @@
|
|||||||
* @Autor: 地虎降天龙
|
* @Autor: 地虎降天龙
|
||||||
* @Date: 2023-10-16 10:53:09
|
* @Date: 2023-10-16 10:53:09
|
||||||
* @LastEditors: 地虎降天龙
|
* @LastEditors: 地虎降天龙
|
||||||
* @LastEditTime: 2025-04-01 10:43:48
|
* @LastEditTime: 2025-04-02 11:00:19
|
||||||
*/
|
*/
|
||||||
import { defineRuntimeConfig, useModel } from '@fesjs/fes'
|
import { defineRuntimeConfig, useModel } from '@fesjs/fes'
|
||||||
import { FMenu } from '@fesjs/fes-design'
|
import { FMenu } from '@fesjs/fes-design'
|
||||||
@ -20,17 +20,24 @@ import { addCollection } from 'iconify-icon'
|
|||||||
import uimIcons from '@iconify/json/json/uim.json'
|
import uimIcons from '@iconify/json/json/uim.json'
|
||||||
import lineMdIcons from '@iconify/json/json/line-md.json'
|
import lineMdIcons from '@iconify/json/json/line-md.json'
|
||||||
import wiIcons from '@iconify/json/json/wi.json'
|
import wiIcons from '@iconify/json/json/wi.json'
|
||||||
|
import { useQiankunTvtStore } from 'PLS/qiankunTvt/stores/index'
|
||||||
|
import { qiankunWindow } from 'vite-plugin-qiankun/dist/helper'
|
||||||
import UserCenter from '@/components/forPreview/userCenter.vue'
|
import UserCenter from '@/components/forPreview/userCenter.vue'
|
||||||
import PageLoading from '@/components/pageLoading.vue'
|
import PageLoading from '@/components/pageLoading.vue'
|
||||||
|
|
||||||
|
|
||||||
addCollection(uimIcons)
|
addCollection(uimIcons)
|
||||||
addCollection(lineMdIcons)
|
addCollection(lineMdIcons)
|
||||||
addCollection(wiIcons)
|
addCollection(wiIcons)
|
||||||
|
|
||||||
|
let qiankunTvtStore = null
|
||||||
export default defineRuntimeConfig({
|
export default defineRuntimeConfig({
|
||||||
beforeRender: {
|
beforeRender: {
|
||||||
loading: <PageLoading />,
|
loading: <PageLoading />,
|
||||||
action () {
|
action () {
|
||||||
|
if (qiankunWindow.__POWERED_BY_QIANKUN__) {
|
||||||
|
qiankunTvtStore = useQiankunTvtStore()
|
||||||
|
}
|
||||||
const { signin, getMenu } = useModel('forPreview')
|
const { signin, getMenu } = useModel('forPreview')
|
||||||
signin()
|
signin()
|
||||||
if ((process.env.FES_APP_PLUGINS === 'true' && process.env.NODE_ENV === 'development') || process.env.FES_APP_ONLINE_API) {
|
if ((process.env.FES_APP_PLUGINS === 'true' && process.env.NODE_ENV === 'development') || process.env.FES_APP_ONLINE_API) {
|
||||||
@ -51,11 +58,13 @@ export function layout (layoutConfig) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
export function onAppCreated ({ app }) {
|
export function onAppCreated ({ app }) {
|
||||||
app.use(FMenu)
|
app.use(FMenu)
|
||||||
app.use(Tres)
|
app.use(Tres)
|
||||||
|
|
||||||
window.$vue = app
|
window.$vue = app
|
||||||
|
|
||||||
// if (process.env.FES_APP_PLUGINS === 'true') {
|
// if (process.env.FES_APP_PLUGINS === 'true') {
|
||||||
console.log(chalk.hex('#1c86e5')(`
|
console.log(chalk.hex('#1c86e5')(`
|
||||||
░▒▓████████▓▒░ ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓████████▓▒░ ░▒▓█▓▒░ ░▒▓███████▓▒░
|
░▒▓████████▓▒░ ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓████████▓▒░ ░▒▓█▓▒░ ░▒▓███████▓▒░
|
||||||
@ -152,14 +161,21 @@ export function modifyRoute (memo) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export const qiankun = {
|
export const qiankun = {
|
||||||
// 应用加载之前
|
// 应用加载之前
|
||||||
async bootstrap (props) {
|
async bootstrap (props) {
|
||||||
console.log('son TvT.js bootstrap', props)
|
console.log('son TvT.js bootstrap', props)
|
||||||
},
|
},
|
||||||
// 应用 render 之前触发
|
// 应用 render 之前触发
|
||||||
async mount (props) {
|
async mount (props) {
|
||||||
|
|
||||||
console.log('son TvT.js mount', props)
|
console.log('son TvT.js mount', props)
|
||||||
|
if (props) {
|
||||||
|
props.onGlobalStateChange((state, prev) => {
|
||||||
|
qiankunTvtStore.setGlobalState(state)
|
||||||
|
})
|
||||||
|
window.qiankunProps = props
|
||||||
|
}
|
||||||
},
|
},
|
||||||
// 当 props 更新时触发
|
// 当 props 更新时触发
|
||||||
async update (props) {
|
async update (props) {
|
||||||
|
38
src/plugins/qiankunTvt/config.js
Normal file
38
src/plugins/qiankunTvt/config.js
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/*
|
||||||
|
* @Description:
|
||||||
|
* @Version: 1.668
|
||||||
|
* @Autor: 地虎降天龙
|
||||||
|
* @Date: 2025-04-01 15:50:33
|
||||||
|
* @LastEditors: 地虎降天龙
|
||||||
|
* @LastEditTime: 2025-04-02 11:25:25
|
||||||
|
*/
|
||||||
|
export default {
|
||||||
|
name: 'qiankunTvt',
|
||||||
|
title: '微前端qiankun',
|
||||||
|
intro: '本案例结合qiankun微前端框架,演示了如何把tvt以子应用引入到自己的主应用框架中,并且实现了qiankun的沙箱隔离机制。qiankun是一个基于single-spa的微前端框架,支持多种主应用和子应用的组合方式。',
|
||||||
|
version: '1.0.0',
|
||||||
|
author: '地虎降天龙',
|
||||||
|
website: 'https://gitee.com/hawk86104',
|
||||||
|
state: 'active',
|
||||||
|
creatTime: '2025-04-01',
|
||||||
|
updateTime: '2025-04-01',
|
||||||
|
require: [],
|
||||||
|
preview: [
|
||||||
|
{
|
||||||
|
src: 'plugins/qiankunTvt/preview/theBasic.png',
|
||||||
|
type: 'img',
|
||||||
|
name: 'theBasic',
|
||||||
|
title: '简单实例',
|
||||||
|
disableFPSGraph: false,
|
||||||
|
disableSrcBtn: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
src: 'plugins/qiankunTvt/preview/events.png',
|
||||||
|
type: 'img',
|
||||||
|
name: 'events',
|
||||||
|
title: '通讯实例',
|
||||||
|
disableFPSGraph: false,
|
||||||
|
disableSrcBtn: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
113
src/plugins/qiankunTvt/pages/events.vue
Normal file
113
src/plugins/qiankunTvt/pages/events.vue
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
<template>
|
||||||
|
<TresCanvas v-bind="state" :style="{ height }">
|
||||||
|
<TresPerspectiveCamera :position="[15, 15, 15]" :fov="45" :near="0.1" :far="1000" :look-at="[0, 0, 0]" />
|
||||||
|
<OrbitControls v-bind="controlsState" />
|
||||||
|
<TresAmbientLight :intensity="0.5" />
|
||||||
|
|
||||||
|
<TresMesh ref="sphereRef" :position="[0, 4, 0]" cast-shadow @pointer-enter="onPointerEnter" @pointer-leave="onPointerLeave">
|
||||||
|
<TresSphereGeometry :args="[2, 32, 32]" />
|
||||||
|
<TresMeshToonMaterial color="#006060" />
|
||||||
|
</TresMesh>
|
||||||
|
|
||||||
|
<TresMesh :rotation="[-Math.PI / 2, 0, 0]" receive-shadow>
|
||||||
|
<TresPlaneGeometry :args="[20, 20, 20, 20]" />
|
||||||
|
<TresMeshToonMaterial />
|
||||||
|
</TresMesh>
|
||||||
|
|
||||||
|
<TresDirectionalLight ref="TDirectionalLight" :position="[10, 8, 4]" :intensity="1" cast-shadow />
|
||||||
|
<TresDirectionalLight :position="[10, 2, 4]" :intensity="1" cast-shadow />
|
||||||
|
|
||||||
|
<TresGridHelper />
|
||||||
|
</TresCanvas>
|
||||||
|
<h1 class="text-center text-white w-full absolute" v-if="!qiankunWindow.__POWERED_BY_QIANKUN__">请通过qiankun主程序访问此页面</h1>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
import { SRGBColorSpace, BasicShadowMap, NoToneMapping } from 'three'
|
||||||
|
import { reactive, ref, onMounted, shallowRef, watchEffect } from 'vue'
|
||||||
|
import { TresCanvas, useRenderLoop } from '@tresjs/core'
|
||||||
|
import { OrbitControls } from '@tresjs/cientos'
|
||||||
|
import { qiankunWindow } from 'vite-plugin-qiankun/dist/helper'
|
||||||
|
import { useQiankunTvtStore } from 'PLS/qiankunTvt/stores/index'
|
||||||
|
|
||||||
|
const state = reactive({
|
||||||
|
clearColor: '#201919',
|
||||||
|
shadows: true,
|
||||||
|
alpha: false,
|
||||||
|
shadowMapType: BasicShadowMap,
|
||||||
|
outputColorSpace: SRGBColorSpace,
|
||||||
|
toneMapping: NoToneMapping,
|
||||||
|
windowSize: !qiankunWindow.__POWERED_BY_QIANKUN__,
|
||||||
|
})
|
||||||
|
const controlsState = reactive({
|
||||||
|
enableDamping: true,
|
||||||
|
dampingFactor: 0.05,
|
||||||
|
enableZoom: true,
|
||||||
|
autoRotate: false,
|
||||||
|
autoRotateSpeed: 2,
|
||||||
|
maxPolarAngle: Math.PI,
|
||||||
|
minPolarAngle: 0,
|
||||||
|
maxAzimuthAngle: Math.PI,
|
||||||
|
minAzimuthAngle: -Math.PI,
|
||||||
|
enablePan: true,
|
||||||
|
keyPanSpeed: 7,
|
||||||
|
maxDistance: 100,
|
||||||
|
minDistance: 0,
|
||||||
|
minZoom: 0,
|
||||||
|
maxZoom: 100,
|
||||||
|
zoomSpeed: 1,
|
||||||
|
enableRotate: true,
|
||||||
|
rotateSpeed: 1,
|
||||||
|
})
|
||||||
|
|
||||||
|
const sphereRef = ref()
|
||||||
|
const TDirectionalLight = shallowRef()
|
||||||
|
|
||||||
|
const { onLoop } = useRenderLoop()
|
||||||
|
const qiankunTvtStore = useQiankunTvtStore() as any
|
||||||
|
let timeplay = 0
|
||||||
|
onLoop(() => {
|
||||||
|
if (!sphereRef.value) return
|
||||||
|
if (qiankunTvtStore.floatMove) {
|
||||||
|
timeplay++
|
||||||
|
sphereRef.value.position.y = 4 + Math.sin(timeplay / 60) * 3
|
||||||
|
}
|
||||||
|
})
|
||||||
|
function onPointerEnter(ev: any) {
|
||||||
|
if (ev) {
|
||||||
|
if (ev.object.material.color.getHexString() !== 'ffff40') {
|
||||||
|
window.qiankunProps?.setGlobalState({ mouseInState: true, curType: 'mouseIn' })
|
||||||
|
ev.object.material.color.set('#ffFF40')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function onPointerLeave(ev: any) {
|
||||||
|
if (ev) {
|
||||||
|
if (ev.object.material.color.getHexString() !== '006060') {
|
||||||
|
window.qiankunProps?.setGlobalState({ mouseInState: false, curType: 'mouseIn' })
|
||||||
|
ev.eventObject.material.color.set('#006060')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
watchEffect(() => {
|
||||||
|
if (TDirectionalLight.value) {
|
||||||
|
TDirectionalLight.value.shadow.mapSize.set(1000, 1000)
|
||||||
|
TDirectionalLight.value.shadow.camera.near = 0.5 // default
|
||||||
|
TDirectionalLight.value.shadow.camera.far = 50000 // default
|
||||||
|
TDirectionalLight.value.shadow.camera.top = 20
|
||||||
|
TDirectionalLight.value.shadow.camera.right = 20
|
||||||
|
TDirectionalLight.value.shadow.camera.left = -20
|
||||||
|
TDirectionalLight.value.shadow.camera.bottom = -20
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
const height = ref('auto')
|
||||||
|
onMounted(() => {
|
||||||
|
sphereRef.value.position.y = 4
|
||||||
|
const parentElement = document.querySelector('.app-main')
|
||||||
|
if (parentElement) {
|
||||||
|
height.value = `${parentElement.clientHeight}px`
|
||||||
|
}
|
||||||
|
})
|
||||||
|
</script>
|
@ -24,6 +24,7 @@
|
|||||||
|
|
||||||
<TresGridHelper />
|
<TresGridHelper />
|
||||||
</TresCanvas>
|
</TresCanvas>
|
||||||
|
<h1 class="text-center text-white w-full absolute" v-if="!qiankunWindow.__POWERED_BY_QIANKUN__">请通过qiankun主程序访问此页面</h1>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
@ -31,7 +32,7 @@ import { SRGBColorSpace, BasicShadowMap, NoToneMapping } from 'three'
|
|||||||
import { reactive, ref, onMounted, shallowRef, watchEffect } from 'vue'
|
import { reactive, ref, onMounted, shallowRef, watchEffect } from 'vue'
|
||||||
import { TresCanvas, useRenderLoop } from '@tresjs/core'
|
import { TresCanvas, useRenderLoop } from '@tresjs/core'
|
||||||
import { OrbitControls } from '@tresjs/cientos'
|
import { OrbitControls } from '@tresjs/cientos'
|
||||||
import { qiankunWindow } from 'vite-plugin-qiankun/dist/helper';
|
import { qiankunWindow } from 'vite-plugin-qiankun/dist/helper'
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
clearColor: '#201919',
|
clearColor: '#201919',
|
||||||
|
23
src/plugins/qiankunTvt/stores/index.js
Normal file
23
src/plugins/qiankunTvt/stores/index.js
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* @Description:
|
||||||
|
* @Version: 1.668
|
||||||
|
* @Autor: 地虎降天龙
|
||||||
|
* @Date: 2025-04-02 10:17:02
|
||||||
|
* @LastEditors: 地虎降天龙
|
||||||
|
* @LastEditTime: 2025-04-02 11:40:45
|
||||||
|
*/
|
||||||
|
import { defineStore } from 'pinia'
|
||||||
|
import { ref } from 'vue'
|
||||||
|
|
||||||
|
export const useQiankunTvtStore = defineStore('qiankunTvtStore', () => {
|
||||||
|
const globalState = ref({})
|
||||||
|
const floatMove = ref(true)
|
||||||
|
|
||||||
|
function setGlobalState(value) {
|
||||||
|
globalState.value = value
|
||||||
|
if (value.curType === 'floatMove') {
|
||||||
|
floatMove.value = !floatMove.value
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return { floatMove, setGlobalState, globalState }
|
||||||
|
})
|
Loading…
x
Reference in New Issue
Block a user