Browse Source

(*)一体化大屏增加自适应

master
peng.peng 1 year ago
parent
commit
035c85f02c
  1. 2
      super-screen/client/src/app.js
  2. 50
      super-screen/client/src/components/full-screen-container.js
  3. 4
      super-screen/client/src/components/index.js
  4. 9
      super-screen/client/src/components/style.less
  5. 4
      super-screen/client/src/sections/community-safty/containers/homePage.js
  6. 2
      super-screen/client/src/sections/fire-control/components/left-middle.js
  7. 2
      super-screen/client/src/sections/fire-control/components/right-middle.js
  8. 8
      super-screen/client/src/sections/fire-control/containers/gis.js
  9. 5
      super-screen/client/src/sections/fire-control/containers/homePage.js
  10. 4
      super-screen/client/src/sections/water-prevention/components/left-bottom.js
  11. 14
      super-screen/client/src/sections/water-prevention/containers/gis.js
  12. 4
      super-screen/client/src/sections/water-prevention/containers/homePage.js

2
super-screen/client/src/app.js

@ -21,7 +21,7 @@ const App = props => {
homePage, homePage,
Auth, Auth,
waterprevention, waterprevention,
communitysafty, // communitysafty,
firecontrol firecontrol
]} ]}
/> />

50
super-screen/client/src/components/full-screen-container.js

@ -0,0 +1,50 @@
import React, { useLayoutEffect, forwardRef, useEffect } from 'react';
import { useAutoResize } from '@jiaminghi/data-view-react';
import './style.less'
const FullScreenContainer = forwardRef(({
children, className, style, designWidth = 1920, designHeight = 1080, onlyAutoSize = false, divRef,
}, ref) => {
const { domRef } = useAutoResize(ref);
useEffect(() => {
const innerWidth = document.body.clientWidth;
const innerHeight = document.body.clientHeight;
const w = document.body.clientWidth / designWidth;
const h = document.body.clientHeight / designHeight;
const scale = w < h ? w : h;
const divRect = divRef?.current?.getBoundingClientRect();
if (onlyAutoSize) {
Object.assign(domRef.current.style, {
width: `${divRect?.width || 0}px`,
height: `${divRect?.height || 0}px`,
// width: '100vw',
// height: '100vh',
position: 'fixed',
zIndex: 999,
top: `${divRect?.top || 0}px`,
left: `${divRect?.left || 0}px`,
});
} else {
const isSuperScreen = innerWidth > 3000 && innerHeight >= 976 && innerHeight <= 1080 ? true : false
Object.assign(domRef.current.style, {
width: isSuperScreen ? '100vw' : `${designWidth}px`,
height: isSuperScreen ? '100vh' : `${designHeight}px`,
});
domRef.current.style.transform = `scale(${scale}) translate(-50%, -50%)`;
}
});
return (
<div
className={onlyAutoSize ? 'dv-screen-container' : 'dv-full-screen-container'}
style={style}
ref={domRef}
>
{children}
</div>
);
});
export default FullScreenContainer;

4
super-screen/client/src/components/index.js

@ -10,6 +10,7 @@ import UploadLocal from './UploadLocal';
import Box from './public/table-card'; import Box from './public/table-card';
import CarouselList from './public/carousel-list'; import CarouselList from './public/carousel-list';
import NoData from './public/noData' import NoData from './public/noData'
import FullScreenContainer from './full-screen-container'
export { export {
Upload, Upload,
Uploads, Uploads,
@ -19,5 +20,6 @@ export {
UploadLocal, UploadLocal,
Box, Box,
CarouselList, CarouselList,
NoData NoData,
FullScreenContainer
}; };

9
super-screen/client/src/components/style.less

@ -0,0 +1,9 @@
.dv-full-screen-container {
position: fixed;
top: 50%;
left: 50%;
overflow: hidden;
transform-origin: left top;
// padding: 14px 8px 28px 8px;
transition: 0.3s;
}

4
super-screen/client/src/sections/community-safty/containers/homePage.js

@ -9,6 +9,7 @@ import RightMiddle from '../components/special-person'
import RightBottom from '../components/traffic-ranking' import RightBottom from '../components/traffic-ranking'
import Gis from './gis'; import Gis from './gis';
import Weather from '../../water-prevention/components/weather'; import Weather from '../../water-prevention/components/weather';
import { FullScreenContainer } from '$components'
import './style.less' import './style.less'
function homePage(props) { function homePage(props) {
@ -17,6 +18,7 @@ function homePage(props) {
const cardHeight = document.body.clientHeight * 0.896 * 0.32 const cardHeight = document.body.clientHeight * 0.896 * 0.32
const cardContentHeight = cardHeight - 42 - 13 const cardContentHeight = cardHeight - 42 - 13
return <> return <>
<FullScreenContainer>
<div className='homepage'> <div className='homepage'>
<div className='_title'> <div className='_title'>
<div className='_title_text'> <div className='_title_text'>
@ -58,6 +60,8 @@ function homePage(props) {
</div> </div>
</div> </div>
</FullScreenContainer>
</> </>

2
super-screen/client/src/sections/fire-control/components/left-middle.js

@ -134,7 +134,7 @@ function PopulationDynamics() {
option={options} option={options}
notMerge notMerge
lazyUpdate lazyUpdate
style={{ height: '100%' }} style={{ height: 231, width: 423 }}
/> />
</Box> </Box>
} }

2
super-screen/client/src/sections/fire-control/components/right-middle.js

@ -156,7 +156,7 @@ function PopulationDynamics() {
option={option} option={option}
notMerge notMerge
lazyUpdate lazyUpdate
style={{ height: '100%' }} style={{ height: 231, width: 423 }}
/> />
</Box> </Box>
} }

8
super-screen/client/src/sections/fire-control/containers/gis.js

@ -4,7 +4,7 @@ import { render } from 'react-dom';
import { Row, Col, Modal, Form, Input, Select } from 'antd'; import { Row, Col, Modal, Form, Input, Select } from 'antd';
import { heatmapData } from '../constant/index' import { heatmapData } from '../constant/index'
import './gis.less' import './gis.less'
const MAPDOMID = 'fs-amap-container'; const MAPDOMID = 'fs-amap-container-fire';
const LOCATION_MAP_ID = 'location_map_id'; const LOCATION_MAP_ID = 'location_map_id';
let map = null; let map = null;
let heatmap = null; let heatmap = null;
@ -66,7 +66,8 @@ function Map(props) {
setTimeout(() => { setTimeout(() => {
setDelay(false) setDelay(false)
}, 1000); }, 1000);
map && renderAlarms()
loca && renderHeapLayer()
}); });
map.on('click', (e) => { map.on('click', (e) => {
@ -93,8 +94,7 @@ function Map(props) {
// 初始化GIS 组件销毁清空定时器 // 初始化GIS 组件销毁清空定时器
useEffect(() => { useEffect(() => {
loadMap(); loadMap();
map && renderAlarms()
loca && renderHeapLayer()
}, []); }, []);
useEffect(() => { useEffect(() => {

5
super-screen/client/src/sections/fire-control/containers/homePage.js

@ -12,6 +12,8 @@ import RightBottom from '../components/right-bottom'
import Gis from './gis'; import Gis from './gis';
import './style.less' import './style.less'
import Weather from '../../water-prevention/components/weather'; import Weather from '../../water-prevention/components/weather';
import { FullScreenContainer } from '$components'
function homePage(props) { function homePage(props) {
const { dispatch } = props; const { dispatch } = props;
const childStyle = { height: '32%', color: '#fff', marginBottom: 17 } const childStyle = { height: '32%', color: '#fff', marginBottom: 17 }
@ -20,6 +22,7 @@ function homePage(props) {
const [tab, setTab] = useState('overview') const [tab, setTab] = useState('overview')
const [emengencyTab, setEmengencyTab] = useState('yjjg'); const [emengencyTab, setEmengencyTab] = useState('yjjg');
return <> return <>
<FullScreenContainer>
<div className='homepage'> <div className='homepage'>
<div className='_title'> <div className='_title'>
<div className='_title_text'> <div className='_title_text'>
@ -83,6 +86,8 @@ function homePage(props) {
</div> </div>
</div > </div >
</FullScreenContainer>
</> </>

4
super-screen/client/src/sections/water-prevention/components/left-bottom.js

@ -42,8 +42,8 @@ function LeftBottom(props) {
<RingChart <RingChart
data={data} data={data}
colors={colors} colors={colors}
width="100%" width={220}
height="100%" height={220}
image={ image={
{ {
url: '/assets/images/ring_bg.png', url: '/assets/images/ring_bg.png',

14
super-screen/client/src/sections/water-prevention/containers/gis.js

@ -51,6 +51,8 @@ function Map(props) {
map.on('complete', () => { map.on('complete', () => {
setTimeout(() => { setTimeout(() => {
setDelay(false) setDelay(false)
map && renderMarkers()
map && renderAlarms()
}, 1500); }, 1500);
}); });
@ -71,12 +73,12 @@ function Map(props) {
}) })
loca = new Loca.Container({ map: map }) loca = new Loca.Container({ map: map })
{ map && renderMarkers() } // { map && renderMarkers() }
{ map && renderAlarms() } // { map && renderAlarms() }
setTimeout(() => { // setTimeout(() => {
renderLayer() // renderLayer()
createText() // createText()
}, 1000); // }, 1000);
}; };
const createText = () => { const createText = () => {

4
super-screen/client/src/sections/water-prevention/containers/homePage.js

@ -14,6 +14,7 @@ import Weather from '../components/weather'
import Gis from './gis'; import Gis from './gis';
import moment from 'moment'; import moment from 'moment';
import './style.less' import './style.less'
import { FullScreenContainer } from '$components'
function homePage(props) { function homePage(props) {
const { dispatch, actions } = props; const { dispatch, actions } = props;
@ -162,6 +163,7 @@ function homePage(props) {
} }
return <> return <>
<FullScreenContainer>
<div className='homepage'> <div className='homepage'>
<div className='_title'> <div className='_title'>
<div className='water_title_text'> <div className='water_title_text'>
@ -205,6 +207,8 @@ function homePage(props) {
</div> </div>
</div> </div>
</div > </div >
</FullScreenContainer>
</> </>
} }

Loading…
Cancel
Save