改变视角
本章你可以学习到
- 什么是 State。
- 在 React 中通过
five.setState
改变观察方向/位置。 - 监听
stateChange
并进行 UI 同步。
React 示例:模式切换
- JavaScript
- TypeScript
import { useEffect, useRef, useState } from 'react'
import { Five, Mode, parseWork } from '@realsee/five'
const workURL = 'https://vr-public.realsee-cdn.cn/release/static/image/release/five/work-sample/07bdc58f413bc5494f05c7cbb5cbdce4/work.json'
export default function FiveState() {
const containerRef = useRef(null)
const fiveRef = useRef(null)
const [mode, setMode] = useState('Panorama')
useEffect(() => {
const five = new Five()
fiveRef.current = five
if (containerRef.current) five.appendTo(containerRef.current)
fetch(workURL).then(r=>r.json()).then(json=>five.load(parseWork(json)))
const onResize = () => five.refresh()
const onState = (s) => setMode(s.mode)
window.addEventListener('resize', onResize, false)
five.on('stateChange', onState)
return () => {
window.removeEventListener('resize', onResize, false)
five.off('stateChange', onState)
five.dispose()
}
}, [])
const switchMode = (m) => fiveRef.current?.setState({ mode: m })
return (
<div style={{ width: '100vw', height: '100vh' }}>
<div ref={containerRef} style={{ width: '100%', height: '100%', overflow: 'hidden' }} />
<div style={{ position: 'fixed', bottom: 16, left: 0, right: 0, display: 'flex', justifyContent: 'center', gap: 8 }}>
<button className={mode==='Panorama'?'btn btn-primary':'btn btn-outline-primary'} onClick={()=>switchMode('Panorama')}>全景漫游</button>
<button className={mode==='Floorplan'?'btn btn-primary':'btn btn-outline-primary'} onClick={()=>switchMode('Floorplan')}>空间总览</button>
</div>
</div>
)
}
import { useEffect, useRef, useState } from 'react'
import { Five, Mode, parseWork } from '@realsee/five'
const workURL = 'https://vr-public.realsee-cdn.cn/release/static/image/release/five/work-sample/07bdc58f413bc5494f05c7cbb5cbdce4/work.json'
export default function FiveState() {
const containerRef = useRef<HTMLDivElement | null>(null)
const fiveRef = useRef<Five | null>(null)
const [mode, setMode] = useState<Mode>('Panorama')
useEffect(() => {
const five = new Five()
fiveRef.current = five
if (containerRef.current) five.appendTo(containerRef.current)
fetch(workURL).then(r=>r.json()).then(json=>five.load(parseWork(json)))
const onResize = () => five.refresh()
const onState = (s: { mode: Mode }) => setMode(s.mode)
window.addEventListener('resize', onResize, false)
five.on('stateChange', onState)
return () => {
window.removeEventListener('resize', onResize, false)
five.off('stateChange', onState)
five.dispose()
}
}, [])
const switchMode = (m: Mode) => fiveRef.current?.setState({ mode: m })
return (
<div style={{ width: '100vw', height: '100vh' }}>
<div ref={containerRef} style={{ width: '100%', height: '100%', overflow: 'hidden' }} />
<div style={{ position: 'fixed', bottom: 16, left: 0, right: 0, display: 'flex', justifyContent: 'center', gap: 8 }}>
<button className={mode==='Panorama'?'btn btn-primary':'btn btn-outline-primary'} onClick={()=>switchMode('Panorama')}>全景漫游</button>
<button className={mode==='Floorplan'?'btn btn-primary':'btn btn-outline-primary'} onClick={()=>switchMode('Floorplan')}>空间总览</button>
</div>
</div>
)
}
在 React 中的关键点:
- 使用
useEffect
订阅stateChange
并在清理函数里off
和dispose
; - 通过本地 UI 状态同步当前
mode
,以便高亮激活的按钮; - 通过
setState
改变视角或模式。