随笔 - 833  文章 - 1  评论 - 106  阅读 - 200万

Cesium建筑自定义光源效果[转]

 

 

 

 

 

复制代码
  const customShader = new Cesium.CustomShader({
    lightingModel: Cesium.LightingModel.UNLIT,
    uniforms: {
      u_cameraDirectionWC: {
        type: Cesium.UniformType.VEC3,
        value: WE.viewer.scene.camera.positionWC,
      },
      u_lightColor1: {
        type: Cesium.UniformType.VEC4,
        value: lightPoint1.color,
      },
      u_lightPos1: {
        type: Cesium.UniformType.VEC3,
        value: lightPoint1.postion,
      },
      u_lightColor2: {
        type: Cesium.UniformType.VEC4,
        value: lightPoint2.color,
      },
      u_lightPos2: {
        type: Cesium.UniformType.VEC3,
        value: lightPoint2.postion,
      },
      u_lightColor3: {
        type: Cesium.UniformType.VEC4,
        value: lightPoint3.color,
      },
      u_lightPos3: {
        type: Cesium.UniformType.VEC3,
        value: lightPoint3.postion,
      },
    },
    fragmentShaderText: `
        vec4 makeLight(vec4 lightColorHdr,vec3 lightPos,
          vec3 positionWC,vec3 positionEC,vec3 normalEC,czm_pbrParameters pbrParameters)
        {
          vec3 color = vec3(0.0);
          float mx1 = 1.0;
          vec3 light1Dir = positionWC - lightPos;
          float distance1 = length(light1Dir);
          if(distance1 < 1000.0){
            vec4 l1 = czm_view * vec4(lightPos, 1.0);
            vec3 lightDirectionEC = l1.xyz - positionEC;
            mx1 = 1.0 - distance1 / 1000.0;
            color = czm_pbrLighting(
              positionEC,
              normalEC,
              lightDirectionEC,
              lightColorHdr.xyz,
              pbrParameters
            ).xyz;
          }
          mx1 = max(color.r,max(color.g,color.b)) * pow(mx1,1.0) * 10.0;
          return vec4(color,mx1);
        }
        void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material)
        {
          material.diffuse = vec3(1.0);
          vec3 positionWC = fsInput.attributes.positionWC;
          vec3 normalEC = fsInput.attributes.normalEC;
          vec3 positionEC = fsInput.attributes.positionEC;

          vec3 lightColorHdr = czm_lightColorHdr;
          vec3 lightDirectionEC = czm_lightDirectionEC;
          lightDirectionEC = (czm_view * vec4(u_cameraDirectionWC,1.0)).xyz - positionEC;

          czm_pbrParameters pbrParameters;
          pbrParameters.diffuseColor = material.diffuse;
          pbrParameters.f0 = vec3(0.5);
          pbrParameters.roughness = 1.0;

          vec3 ligth1Color0 = czm_pbrLighting(
            positionEC,
            normalEC,
            lightDirectionEC,
            lightColorHdr,
            pbrParameters
          );

          vec4 ligth1ColorR = makeLight(u_lightColor1,u_lightPos1,positionWC,positionEC,normalEC,pbrParameters);
          vec4 ligth1ColorG = makeLight(u_lightColor2,u_lightPos2,positionWC,positionEC,normalEC,pbrParameters);
          vec4 ligth1ColorB = makeLight(u_lightColor3,u_lightPos3,positionWC,positionEC,normalEC,pbrParameters);

          vec3 finalColor = mix(ligth1Color0.rgb, ligth1ColorR.rgb, ligth1ColorR.a);
          finalColor = mix(finalColor, ligth1ColorG.rgb, ligth1ColorG.a);
          finalColor = mix(finalColor, ligth1ColorB.rgb, ligth1ColorB.a);
          material.diffuse = finalColor;
        }
        `,
  });
复制代码

原文:https://blog.csdn.net/rpgpp55/article/details/124073343?spm=1001.2101.3001.6650.2&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-2-124073343-blog-108745813.pc_relevant_multi_platform_featuressortv2dupreplace&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-2-124073343-blog-108745813.pc_relevant_multi_platform_featuressortv2dupreplace&utm_relevant_index=5

posted on   3D入魔  阅读(2601)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示