预览链接 https://threehub.cn/#/codeMirror?navigation=ThreeJS&classify=expand&id=combineEcharts
import * as THREE from 'three'
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js'
import { CSS3DRenderer, CSS3DObject } from 'three/examples/jsm/renderers/CSS3DRenderer.js'
import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader.js'
import * as echarts from 'echarts'
const DOM = document.getElementById('box')
const scene = new THREE.Scene()
const camera = new THREE.PerspectiveCamera(75, DOM.clientWidth / DOM.clientHeight, 0.1, 10000)
camera.position.set(50, 90, 300)
const renderer = new THREE.WebGLRenderer({ antialias: true, alpha: true, logarithmicDepthBuffer: true })
renderer.setSize(DOM.clientWidth, DOM.clientHeight)
DOM.appendChild(renderer.domElement)
scene.add(new THREE.AmbientLight(0xffffff, 3))
new OrbitControls(camera, renderer.domElement)
const css3DRender = setCss3DRenderer(DOM)
new GLTFLoader().load(`https://file.threehub.cn/` + "files/model/Fox.glb", gltf => scene.add(gltf.scene))
animate()
function animate() {
requestAnimationFrame(animate)
renderer.render(scene, camera)
css3DRender.render(scene, camera)
}
window.onresize = () => {
renderer.setSize(box.clientWidth, box.clientHeight)
camera.aspect = box.clientWidth / box.clientHeight
camera.updateProjectionMatrix()
css3DRender.resize()
}
/* css3d 渲染 */
function setCss3DRenderer(DOM) {
const css3DRender = new CSS3DRenderer()
css3DRender.resize = () => {
css3DRender.setSize(DOM.clientWidth, DOM.clientHeight)
css3DRender.domElement.style.zIndex = 0
css3DRender.domElement.style.position = 'relative'
css3DRender.domElement.style.top = -DOM.clientHeight + 'px'
css3DRender.domElement.style.height = DOM.clientHeight + 'px'
css3DRender.domElement.style.width = DOM.clientWidth + 'px'
css3DRender.domElement.style.pointerEvents = 'none'
}
css3DRender.resize()
DOM.appendChild(css3DRender.domElement)
return css3DRender
}
/* 图表 ---------------------------------------------------------------------- */
const container = document.createElement("div")
container.style.width = "300px"
container.style.height = "200px"
const myChart = echarts.init(container)
myChart.setOption({
graphic: {
elements: [
{
type: 'text',
left: 'center',
top: 'center',
style: {
text: 'Echarts',
fontSize: 80,
fontWeight: 'bold',
lineDash: [0, 200],
lineDashOffset: 0,
fill: 'transparent',
stroke: '#fff',
lineWidth: 1
},
keyframeAnimation: {
duration: 3000,
loop: true,
keyframes: [
{
percent: 0.7,
style: {
fill: 'transparent',
lineDashOffset: 200,
lineDash: [200, 0]
}
},
{
// Stop for a while.
percent: 0.8,
style: {
fill: 'transparent'
}
},
{
percent: 1,
style: {
fill: 'black'
}
}
]
}
}
]
}
})
const css3DObject = new CSS3DObject(container)
css3DObject.position.set(0, 130, 0)
scene.add(css3DObject)
const container2 = document.createElement("div")
container2.style.width = "300px"
container2.style.height = "300px"
const myChart2 = echarts.init(container2)
myChart2.setOption({
xAxis: {
type: 'category',
boundaryGap: false,
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
yAxis: {
type: 'value'
},
series: [
{
data: [820, 932, 901, 934, 1290, 1330, 1320],
type: 'line',
areaStyle: {}
}
]
})
const css3DObject2 = new CSS3DObject(container2)
css3DObject2.position.set(0, -80, 0)
scene.add(css3DObject2)
/**
* title: Combine Echarts
* author: Elegant https://z2586300277.github.io/
* refer:https://echarts.apache.org/
*/