修改地图点样式可以在卫星地图上清晰显示
parent
d986b18ba7
commit
710df1cc6b
|
|
@ -370,10 +370,9 @@ export default class Map3D extends BaseMap {
|
||||||
async getDemo(viewer) {
|
async getDemo(viewer) {
|
||||||
const demo = new Demo3D()
|
const demo = new Demo3D()
|
||||||
this.demo = demo
|
this.demo = demo
|
||||||
|
await demo.getGltf(viewer) //模型
|
||||||
demo.getDem(viewer) //地形图
|
demo.getDem(viewer) //地形图
|
||||||
demo.getWxyx(viewer) //卫星影像
|
demo.getWxyx(viewer) //卫星影像
|
||||||
|
|
||||||
await demo.getGltf(viewer) //模型
|
|
||||||
demo.getQxsy(viewer) //倾斜摄影 先加载模型
|
demo.getQxsy(viewer) //倾斜摄影 先加载模型
|
||||||
// demo.getDem(viewer) //地形图
|
// demo.getDem(viewer) //地形图
|
||||||
// this.demo.getCzml2(viewer) //demo
|
// this.demo.getCzml2(viewer) //demo
|
||||||
|
|
|
||||||
|
|
@ -26,6 +26,7 @@ export default class LayerMgr {
|
||||||
|
|
||||||
// 将模型添加到场景的图元集合中
|
// 将模型添加到场景的图元集合中
|
||||||
viewer.scene.primitives.add(model);
|
viewer.scene.primitives.add(model);
|
||||||
|
await this.sleep(500)
|
||||||
}
|
}
|
||||||
getWater(viewer) {
|
getWater(viewer) {
|
||||||
const positions = [
|
const positions = [
|
||||||
|
|
|
||||||
|
|
@ -143,7 +143,7 @@ function AdcdAllMarker({ data, dispatch, setting, zoom, distSq, layerVisible })
|
||||||
></div>:null
|
></div>:null
|
||||||
}
|
}
|
||||||
<div
|
<div
|
||||||
className="markerLabel"
|
className="markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
color: data.CODE==='422826'?'rgba(230,0,0)':!getLayerVisible.SatelliteImage?'#595959':'#fff',
|
color: data.CODE==='422826'?'rgba(230,0,0)':!getLayerVisible.SatelliteImage?'#595959':'#fff',
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,7 @@ function renderMarker({ level }, { width, highlight }) {
|
||||||
<div style="position:relative">
|
<div style="position:relative">
|
||||||
<svg t="1616148185046" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4230" width="${width}">
|
<svg t="1616148185046" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4230" width="${width}">
|
||||||
</svg>
|
</svg>
|
||||||
<img width="${width}" style="position:absolute;top:0;left:2px" src=""
|
<img width="${width}" style="position:absolute;top:-1px;left:-1px" src=""
|
||||||
alt="" className="panel-icon" />
|
alt="" className="panel-icon" />
|
||||||
</div>
|
</div>
|
||||||
`;
|
`;
|
||||||
|
|
@ -31,7 +31,7 @@ function renderMarker({ level }, { width, highlight }) {
|
||||||
<div style="position:relative">
|
<div style="position:relative">
|
||||||
<svg t="1616148185046" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4230" width="${width}">
|
<svg t="1616148185046" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4230" width="${width}">
|
||||||
</svg>
|
</svg>
|
||||||
<img width="16" style="position:absolute;top:0;left:2px" src=""
|
<img width="16" style="position:absolute;top:-1px;left:-1px" src=""
|
||||||
alt="" className="panel-icon" />
|
alt="" className="panel-icon" />
|
||||||
</div>
|
</div>
|
||||||
`;
|
`;
|
||||||
|
|
@ -177,7 +177,7 @@ function AdcdMarker({ data, dispatch, setting, zoom, distSq, layerVisible }) {
|
||||||
// onClick={showPop}
|
// onClick={showPop}
|
||||||
></div>
|
></div>
|
||||||
<div
|
<div
|
||||||
className="markerLabel"
|
className="markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
display:(zoom > 8 || distSq < dist2 || highlight)?'block':'none',
|
display:(zoom > 8 || distSq < dist2 || highlight)?'block':'none',
|
||||||
|
|
@ -202,9 +202,9 @@ function AdcdMarker({ data, dispatch, setting, zoom, distSq, layerVisible }) {
|
||||||
<div
|
<div
|
||||||
id={`marker_tuxiang_${data.id}`}
|
id={`marker_tuxiang_${data.id}`}
|
||||||
style={{
|
style={{
|
||||||
display:(zoom > 12 || distSq < dist2 || highlight)?'block':'none',
|
display:(zoom > 12 || distSq < dist2*10 || highlight)?'block':'none',
|
||||||
position: 'absolute',
|
position: 'absolute',
|
||||||
bottom: 0,
|
bottom: -10,
|
||||||
left: 0,
|
left: 0,
|
||||||
transformOrigin: 'bottom center',
|
transformOrigin: 'bottom center',
|
||||||
transform: `translateX(-50%)${markerZoom > 1 ? ' scale(' + markerZoom + ')' : ''}`,
|
transform: `translateX(-50%)${markerZoom > 1 ? ' scale(' + markerZoom + ')' : ''}`,
|
||||||
|
|
@ -214,19 +214,19 @@ function AdcdMarker({ data, dispatch, setting, zoom, distSq, layerVisible }) {
|
||||||
// onClick={showPop}
|
// onClick={showPop}
|
||||||
></div>
|
></div>
|
||||||
<div
|
<div
|
||||||
className="markerLabel"
|
className="markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
display:(zoom > 12 || distSq < dist2 || highlight)?'block':'none',
|
display:(zoom > 12 || distSq < dist2*10 || highlight)?'block':'none',
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
padding: 4,
|
padding: 4,
|
||||||
borderRadius: 4,
|
borderRadius: 4,
|
||||||
fontSize: 10,
|
fontSize: 12,
|
||||||
lineHeight: 1,
|
lineHeight: 1,
|
||||||
top: 0,
|
top: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
transform: 'translateX(-50%)',
|
transform: 'translateX(-50%)',
|
||||||
zIndex: 1,//zindexmarker.tuxiangLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
zIndex: 1,//zindexmarker.tuxiangLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
||||||
color: !layerVisible.SatelliteImage?'#0008':'#fff'
|
// color: !layerVisible.SatelliteImage?'#0008':'#fff'
|
||||||
}}>
|
}}>
|
||||||
{data?.NAME}
|
{data?.NAME}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
|
|
@ -150,7 +150,7 @@ function GongShuiMarker({ data, dispatch, setting, zoom, distSq }) {
|
||||||
{
|
{
|
||||||
(zoom > 14 || distSq < dist1 || highlight) && (
|
(zoom > 14 || distSq < dist1 || highlight) && (
|
||||||
<div
|
<div
|
||||||
className="markerLabel2"
|
className="markerLabel2 markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
width:"100px",
|
width:"100px",
|
||||||
|
|
@ -172,18 +172,18 @@ function GongShuiMarker({ data, dispatch, setting, zoom, distSq }) {
|
||||||
{
|
{
|
||||||
(zoom > 10 || distSq < dist2 || highlight) && (
|
(zoom > 10 || distSq < dist2 || highlight) && (
|
||||||
<div
|
<div
|
||||||
className="markerLabel2"
|
className="markerLabel2 markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
padding: "2px 0",
|
padding: "2px 0",
|
||||||
borderRadius: 4,
|
borderRadius: 4,
|
||||||
fontSize: 10,
|
// fontSize: 10,
|
||||||
lineHeight: 1,
|
lineHeight: 1,
|
||||||
top: 0,
|
top: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
transform: 'translateX(-50%)',
|
transform: 'translateX(-50%)',
|
||||||
zIndex: zindexmarker.gongshuiLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
zIndex: zindexmarker.gongshuiLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
||||||
color: !getLayerVisible.SatelliteImage?'#0008':'#fff'
|
// color: !getLayerVisible.SatelliteImage?'#0008':'#fff'
|
||||||
}}>
|
}}>
|
||||||
{data.name}
|
{data.name}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
|
|
@ -174,20 +174,20 @@ const getLayerVisible = useSelector((s) => s.map.layerVisible)
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
(zoom > 12 || distSq < dist2 || highlight) && (
|
(zoom > 15 || distSq < dist2 || highlight) && (
|
||||||
<div
|
<div
|
||||||
className="markerLabel"
|
className="markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
padding: 4,
|
padding: 4,
|
||||||
borderRadius: 4,
|
borderRadius: 4,
|
||||||
fontSize: 10,
|
// fontSize: 10,
|
||||||
lineHeight: 1,
|
lineHeight: 1,
|
||||||
bottom: -14 * markerZoom,
|
bottom: -14 * markerZoom,
|
||||||
left: 0,
|
left: 0,
|
||||||
transform: 'translateX(-50%)',
|
transform: 'translateX(-50%)',
|
||||||
zIndex: zindexmarker.tuxiangLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
zIndex: zindexmarker.tuxiangLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
||||||
color: !getLayerVisible.SatelliteImage?'#0008':'#fff',
|
// color: !getLayerVisible.SatelliteImage?'#0008':'#fff',
|
||||||
// textShadow: '2px 2px 4px #000000',
|
// textShadow: '2px 2px 4px #000000',
|
||||||
minWidth: "20px",
|
minWidth: "20px",
|
||||||
textAlign: "center"
|
textAlign: "center"
|
||||||
|
|
|
||||||
|
|
@ -16,17 +16,17 @@ function renderMarker({ drp }, { width, highlight }) {
|
||||||
}else if(drp<0.1){
|
}else if(drp<0.1){
|
||||||
color1 = '#ffffff'
|
color1 = '#ffffff'
|
||||||
}else if(drp>=0.1 && drp<10){
|
}else if(drp>=0.1 && drp<10){
|
||||||
color1 = 'rgb(167, 240, 143)';
|
color1 = 'rgb(189, 239, 154)';
|
||||||
}else if(drp>=10 && drp<25){
|
}else if(drp>=10 && drp<25){
|
||||||
color1 = 'rgb(64, 215, 255)';
|
color1 = 'rgb(89, 182, 101)';
|
||||||
}else if(drp>=25 && drp<50){
|
}else if(drp>=25 && drp<50){
|
||||||
color1 = 'rgb(32, 143, 238)';
|
color1 = 'rgb(110, 193, 251)';
|
||||||
}else if(drp>=50 && drp<100){
|
}else if(drp>=50 && drp<100){
|
||||||
color1 = 'rgb(85, 86, 255)';
|
color1 = 'rgb(29, 27, 199)';
|
||||||
}else if(drp>=100 && drp<250){
|
}else if(drp>=100 && drp<250){
|
||||||
color1 = 'rgb(191, 90, 252)';
|
color1 = 'rgb(235, 32, 245)';
|
||||||
}else{
|
}else{
|
||||||
color1 = 'rgb(246, 66, 66)';
|
color1 = 'rgb(118, 30, 80)';
|
||||||
}
|
}
|
||||||
// color1 = "#1E1ACA";
|
// color1 = "#1E1ACA";
|
||||||
|
|
||||||
|
|
@ -184,19 +184,20 @@ function RealDrpMarker({ data, dispatch, setting, zoom, distSq }) {
|
||||||
{
|
{
|
||||||
(zoom > 14 || distSq < dist2 || highlight) && (
|
(zoom > 14 || distSq < dist2 || highlight) && (
|
||||||
<div
|
<div
|
||||||
className="markerLabel"
|
className="markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
padding: 4,
|
padding: 4,
|
||||||
borderRadius: 4,
|
borderRadius: 4,
|
||||||
fontSize: 10,
|
// fontSize: 10,
|
||||||
lineHeight: 1,
|
lineHeight: 1,
|
||||||
top: 0,
|
top: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
transform: 'translateX(-50%)',
|
transform: 'translateX(-50%)',
|
||||||
zIndex: zindexmarker.drpLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0), color: '#fff'
|
zIndex: zindexmarker.drpLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
||||||
|
// color: '#fff'
|
||||||
}}>
|
}}>
|
||||||
<div style={{textAlign:"center",color:'rgba(0,0,0,0.5)'}}>{data.name}</div>
|
<div style={{textAlign:"center"}}>{data.name}</div>
|
||||||
{/* <div style={{textAlign:"center"}}>{data.h24 || '-'}m</div> */}
|
{/* <div style={{textAlign:"center"}}>{data.h24 || '-'}m</div> */}
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
|
|
|
||||||
|
|
@ -252,18 +252,18 @@ function ShuikuMarker({ data, dispatch, setting, zoom, distSq }) {
|
||||||
{
|
{
|
||||||
(zoom > 10 || distSq < dist2 || highlight) && (
|
(zoom > 10 || distSq < dist2 || highlight) && (
|
||||||
<div
|
<div
|
||||||
className="markerLabel2"
|
className="markerLabel2 markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
padding: 4,
|
padding: 4,
|
||||||
borderRadius: 4,
|
borderRadius: 4,
|
||||||
fontSize: 10,
|
// fontSize: 10,
|
||||||
lineHeight: 1,
|
lineHeight: 1,
|
||||||
top: 0,
|
top: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
transform: 'translateX(-50%)',
|
transform: 'translateX(-50%)',
|
||||||
zIndex: zindexmarker.shuikuLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
zIndex: zindexmarker.shuikuLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
||||||
color: !getLayerVisible.SatelliteImage?'#0008':'#fff'
|
// color: !getLayerVisible.SatelliteImage?'#0008':'#fff'
|
||||||
}}>
|
}}>
|
||||||
{data.name}
|
{data.name}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
|
|
@ -144,18 +144,18 @@ function TuRangMarker({ data, dispatch, setting, zoom, distSq }) {
|
||||||
{
|
{
|
||||||
(zoom > 10 || distSq < dist2 || highlight) && (
|
(zoom > 10 || distSq < dist2 || highlight) && (
|
||||||
<div
|
<div
|
||||||
className="markerLabel2"
|
className="markerLabel2 markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
padding: 4,
|
padding: 4,
|
||||||
borderRadius: 4,
|
borderRadius: 4,
|
||||||
fontSize: 10,
|
// fontSize: 10,
|
||||||
lineHeight: 1,
|
lineHeight: 1,
|
||||||
top: -10,
|
top: -10,
|
||||||
left: 0,
|
left: 0,
|
||||||
transform: 'translateX(-50%)',
|
transform: 'translateX(-50%)',
|
||||||
zIndex: zindexmarker.shuikuLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
zIndex: zindexmarker.shuikuLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
||||||
color: '#0008',//!getLayerVisible.SatelliteImage?'#0008':'#fff'
|
// color: '#0008',//!getLayerVisible.SatelliteImage?'#0008':'#fff'
|
||||||
}}>
|
}}>
|
||||||
{data.stnm}
|
{data.stnm}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
|
|
@ -174,20 +174,20 @@ function YHJMHMarker({ data, dispatch, setting, zoom, distSq }) {
|
||||||
)
|
)
|
||||||
} */}
|
} */}
|
||||||
{
|
{
|
||||||
(zoom > 16 || distSq < dist2 || highlight) && (
|
(zoom > 17 || distSq < dist2*0.2 || highlight) && (
|
||||||
<div
|
<div
|
||||||
className="markerLabel2"
|
className="markerLabel2 markerLabelNew"
|
||||||
style={{
|
style={{
|
||||||
// backgroundColor: '#0008',
|
// backgroundColor: '#0008',
|
||||||
padding: 4,
|
padding: 4,
|
||||||
borderRadius: 4,
|
borderRadius: 4,
|
||||||
fontSize: 10,
|
// fontSize: 10,
|
||||||
lineHeight: 1,
|
lineHeight: 1,
|
||||||
top: 0,
|
top: 0,
|
||||||
left: 0,
|
left: 0,
|
||||||
transform: 'translateX(-50%)',
|
transform: 'translateX(-50%)',
|
||||||
zIndex: zindexmarker.zLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
zIndex: zindexmarker.zLabel + zindexOffset + (highlight ? zindexmarker.hilightPlus : 0),
|
||||||
color: !getLayerVisible.SatelliteImage?'#0008':'#fff'
|
// color: !getLayerVisible.SatelliteImage?'#0008':'#fff'
|
||||||
}}>
|
}}>
|
||||||
{data.name}
|
{data.name}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
|
|
@ -77,6 +77,27 @@
|
||||||
// white-space: nowrap;
|
// white-space: nowrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.markerLabelNew {
|
||||||
|
color: rgba(0, 0, 0, 0.8);
|
||||||
|
padding: 0 4px;
|
||||||
|
font-size: 12px;
|
||||||
|
font-weight: 450;
|
||||||
|
border-radius: 4px;
|
||||||
|
position: absolute;
|
||||||
|
pointer-events: none;
|
||||||
|
//background-color: rgba(255, 255, 255, 0.3);
|
||||||
|
word-break: keep-all;
|
||||||
|
text-shadow:
|
||||||
|
-0.8px -0.8px 0.3px white,
|
||||||
|
0 -0.8px 0.3px white,
|
||||||
|
0.8px -0.8px 0.3px white,
|
||||||
|
0.8px 0 0.3px white,
|
||||||
|
0.8px 0.8px 0.3px white,
|
||||||
|
0 0.8px 0.3px white,
|
||||||
|
-0.8px 0.8px 0.3px white,
|
||||||
|
-0.8px 0 0.3px white;
|
||||||
|
}
|
||||||
|
|
||||||
.dp-popup {
|
.dp-popup {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue