mirror of
				https://github.com/jiawanlong/Cesium-Examples.git
				synced 2025-11-03 16:54:16 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			209 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			209 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
<!--********************************************************************
 | 
						|
* by jiawanlong
 | 
						|
*********************************************************************-->
 | 
						|
<!DOCTYPE html>
 | 
						|
<html>
 | 
						|
 | 
						|
<head>
 | 
						|
  <meta charset="UTF-8" />
 | 
						|
  <link rel="stylesheet" href="./../../cesium/Cesium1.98/Widgets/widgets.css" />
 | 
						|
  <script type="text/javascript" src="./../../cesium/Cesium1.98/Cesium.js"></script>
 | 
						|
</head>
 | 
						|
 | 
						|
<body style="
 | 
						|
      margin: 0;
 | 
						|
      overflow: hidden;
 | 
						|
      background: #fff;
 | 
						|
      width: 100%;
 | 
						|
      height: 100%;
 | 
						|
      position: absolute;
 | 
						|
      top: 0;
 | 
						|
    ">
 | 
						|
  <div id="map" style="margin: 0 auto; width: 100%; height: 100%"></div>
 | 
						|
 | 
						|
  <script type="text/javascript">
 | 
						|
    Cesium.Ion.defaultAccessToken =
 | 
						|
      "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiI3ZjQ5ZGUzNC1jNWYwLTQ1ZTMtYmNjYS05YTY4ZTVmN2I2MDkiLCJpZCI6MTE3MTM4LCJpYXQiOjE2NzY0NDUyODB9.ZaNSBIfc1sGLhQd_xqhiSsc0yr8oS0wt1hAo9gbke6M";
 | 
						|
    const viewer = new Cesium.Viewer("map", {
 | 
						|
      contextOptions: {
 | 
						|
        requestWebgl1: true,
 | 
						|
      },
 | 
						|
    });
 | 
						|
    viewer.scene.debugShowFramesPerSecond = true;
 | 
						|
 | 
						|
    function map_common_addDatasouce(datasouceName) {
 | 
						|
      let datasouce = viewer.dataSources._dataSources.find(t => {
 | 
						|
        return t && t.name == datasouceName;
 | 
						|
      });
 | 
						|
      if (!datasouce) {
 | 
						|
        datasouce = new Cesium.CustomDataSource(datasouceName);
 | 
						|
        viewer.dataSources.add(datasouce);
 | 
						|
      }
 | 
						|
      return datasouce;
 | 
						|
    }
 | 
						|
    /*
 | 
						|
        动态墙材质
 | 
						|
        color 颜色
 | 
						|
        duration 持续时间 毫秒
 | 
						|
        trailImage 贴图地址
 | 
						|
    */
 | 
						|
    function DynamicWallMaterialProperty(options) {
 | 
						|
      this._definitionChanged = new Cesium.Event();
 | 
						|
      this._color = undefined;
 | 
						|
      this._colorSubscription = undefined;
 | 
						|
      this.color = options.color || Color.BLUE;
 | 
						|
      this.duration = options.duration || 1000;
 | 
						|
      this.trailImage = options.trailImage;
 | 
						|
      this._time = (new Date()).getTime();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 带方向的墙体
 | 
						|
     * @param {*} options.get:true/false
 | 
						|
     * @param {*} options.count:数量 
 | 
						|
     * @param {*} options.freely:vertical/standard
 | 
						|
     * @param {*} options.direction:+/-
 | 
						|
     */
 | 
						|
    function _getDirectionWallShader(options) {
 | 
						|
      if (options && options.get) {
 | 
						|
        var materail = "czm_material czm_getMaterial(czm_materialInput materialInput)\n\
 | 
						|
      {\n\
 | 
						|
          czm_material material = czm_getDefaultMaterial(materialInput);\n\
 | 
						|
          vec2 st = materialInput.st;";
 | 
						|
        if (options.freely == "vertical") { //(由下到上)
 | 
						|
          materail += "vec4 colorImage = texture2D(image, vec2(fract(st.s), fract(float(" + options.count + ")*st.t" + options.direction + " time)));\n\ ";
 | 
						|
        } else { //(逆时针)
 | 
						|
          materail += "vec4 colorImage = texture2D(image, vec2(fract(float(" + options.count + ")*st.s " + options.direction + " time), fract(st.t)));\n\ ";
 | 
						|
        }
 | 
						|
        //泛光
 | 
						|
        materail += "vec4 fragColor;\n\
 | 
						|
          fragColor.rgb = (colorImage.rgb+color.rgb) / 1.0;\n\
 | 
						|
          fragColor = czm_gammaCorrect(fragColor);\n\
 | 
						|
          material.diffuse = colorImage.rgb;\n\
 | 
						|
          material.alpha = colorImage.a;\n\
 | 
						|
          material.emission = fragColor.rgb;\n\
 | 
						|
          return material;\n\
 | 
						|
      }";
 | 
						|
        return materail
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    Object.defineProperties(DynamicWallMaterialProperty.prototype, {
 | 
						|
      isConstant: {
 | 
						|
        get: function () {
 | 
						|
          return false;
 | 
						|
        }
 | 
						|
      },
 | 
						|
      definitionChanged: {
 | 
						|
        get: function () {
 | 
						|
          return this._definitionChanged;
 | 
						|
        }
 | 
						|
      },
 | 
						|
      color: Cesium.createPropertyDescriptor('color')
 | 
						|
    });
 | 
						|
 | 
						|
    var MaterialType = 'wallType' + parseInt(Math.random() * 1000);
 | 
						|
    DynamicWallMaterialProperty.prototype.getType = function (time) {
 | 
						|
      return MaterialType;
 | 
						|
    };
 | 
						|
 | 
						|
    DynamicWallMaterialProperty.prototype.getValue = function (time, result) {
 | 
						|
      if (!Cesium.defined(result)) {
 | 
						|
        result = {};
 | 
						|
      }
 | 
						|
      result.color = Cesium.Property.getValueOrClonedDefault(this._color, time, Cesium.Color.WHITE, result.color);
 | 
						|
      result.image = this.trailImage;
 | 
						|
      if (this.duration) {
 | 
						|
        result.time = (((new Date()).getTime() - this._time) % this.duration) / this.duration;
 | 
						|
      }
 | 
						|
      viewer.scene.requestRender();
 | 
						|
      return result;
 | 
						|
    };
 | 
						|
 | 
						|
    DynamicWallMaterialProperty.prototype.equals = function (other) {
 | 
						|
      return this === other ||
 | 
						|
        (other instanceof DynamicWallMaterialProperty
 | 
						|
          && Cesium.Property.equals(this._color, other._color))
 | 
						|
    };
 | 
						|
 | 
						|
    Cesium.Material._materialCache.addMaterial(MaterialType, {
 | 
						|
      fabric: {
 | 
						|
        type: MaterialType,
 | 
						|
        uniforms: {
 | 
						|
          color: new Cesium.Color(1.0, 0.0, 0.0, 0.8),
 | 
						|
          image: Cesium.Material.DefaultImageId,
 | 
						|
          time: -20
 | 
						|
        },
 | 
						|
        source: _getDirectionWallShader({
 | 
						|
          get: true,
 | 
						|
          count: 23.0,
 | 
						|
          freely: 'standard',
 | 
						|
          direction: '+'
 | 
						|
        })
 | 
						|
      },
 | 
						|
      translucent: function (material) {
 | 
						|
        return true;
 | 
						|
      }
 | 
						|
    });
 | 
						|
    Cesium.DynamicWallMaterialProperty = DynamicWallMaterialProperty;
 | 
						|
 | 
						|
    //加载范围
 | 
						|
    function loadWall() {
 | 
						|
      let data = [
 | 
						|
        [
 | 
						|
          104.0185546875,
 | 
						|
          30.66235300961486
 | 
						|
        ],
 | 
						|
        [
 | 
						|
          104.01589393615723,
 | 
						|
          30.65652022496456
 | 
						|
        ],
 | 
						|
        [
 | 
						|
          104.029541015625,
 | 
						|
          30.65053940942565
 | 
						|
        ],
 | 
						|
        [
 | 
						|
          104.0397548675537,
 | 
						|
          30.65777541087788
 | 
						|
        ],
 | 
						|
        [
 | 
						|
          104.03829574584961,
 | 
						|
          30.66604446357028
 | 
						|
        ],
 | 
						|
        [
 | 
						|
          104.0255069732666,
 | 
						|
          30.667963963897005
 | 
						|
        ],
 | 
						|
        [
 | 
						|
          104.0185546875,
 | 
						|
          30.66235300961486
 | 
						|
        ]
 | 
						|
      ]
 | 
						|
      let coor = Array.prototype.concat.apply(
 | 
						|
        [],
 | 
						|
        data
 | 
						|
      );
 | 
						|
      let datasouce = map_common_addDatasouce('wall');
 | 
						|
 | 
						|
      datasouce.entities.add({
 | 
						|
        wall: {
 | 
						|
          positions: Cesium.Cartesian3.fromDegreesArray(coor),
 | 
						|
          positions: Cesium.Cartesian3.fromDegreesArray(coor),
 | 
						|
          maximumHeights: new Array(data.length).fill(200),
 | 
						|
          minimunHeights: new Array(data.length).fill(0),
 | 
						|
 | 
						|
          // 动态
 | 
						|
          material: new Cesium.DynamicWallMaterialProperty({ trailImage: "./jt.png", color: Cesium.Color.YELLOW, duration: 1500 })
 | 
						|
        },
 | 
						|
      });
 | 
						|
    }
 | 
						|
    loadWall();
 | 
						|
    //设置相机位置及方向  
 | 
						|
    viewer.camera.flyTo({
 | 
						|
      destination: Cesium.Cartesian3.fromDegrees(104.02, 30.655, 5000),
 | 
						|
      duration: 2,
 | 
						|
    });
 | 
						|
  </script>
 | 
						|
</body>
 | 
						|
 | 
						|
</html> |