当前位置: 首页 > news >正文

外包兼职做图的网站重庆网站建设公

外包兼职做图的网站,重庆网站建设公,网站建设费开票收候开在哪个类别里,戴尔的网站建设有哪些主要特色目录 Three.js入门 Three.js光源 Three.js阴影 使用灯光后,场景中就会产生阴影。物体的背面确实在黑暗中,这称为核心阴影(core shadow)。我们缺少的是落下的阴影(drop shadow),即对象在其他…

目录

Three.js入门

Three.js光源

Three.js阴影

使用灯光后,场景中就会产生阴影。物体的背面确实在黑暗中,这称为核心阴影(core shadow)。我们缺少的是落下的阴影(drop shadow),即对象在其他对象上创建阴影。本文主要探索是落下的阴影(drop shadow)的相关内容。

阴影

支持阴影的光源类型

前面的文章我们有介绍过,只有部分光源支持阴影:

  • 平行光(DirectionalLight)
  • 点光源(PointLight)
  • 聚光灯(SpotLight)

它们对应的阴影在three.js中也有对应的实现类:

  • 平行光阴影(DirectionalLightShadow)
  • 点光源阴影(PointLightShadow)
  • 聚光灯阴影(SpotLightShadow)

阴影的代码实现

在入门系列中有介绍阴影的基本代码实现,这里再简单叙述一遍。主要分为四个步骤:

  1. 告诉渲染器显示阴影贴图;
    renderer.shadowMap.enabled = true;
    
  2. 对需要投影的物体设置castShadowtrue
    sphere.castShadow = true; 
    
  3. 对需要接收投影的物体设置receiveShadowtrue
    plane.receiveShadow = true; 
    
  4. 最后,对可以产生阴影的光源设置castShadowtrue
    light.castShadow = true;
    

至此,我们应该就可以在接收投影的物体上看到阴影了!

阴影的实现原理

每次渲染时,three.js 将为每个支持阴影的光源都会做一次渲染。

  • 光源具有一个相机,以这个相机为视角进行渲染;
  • 光源的渲染结果被作为纹理存储起来,也就是 阴影贴图(shadow map);
  • 阴影贴图将被用于所有需要接受阴影的材质(material),并投影到几何体(geometry)上。

    有些材质不接受光照,所以材质也会影响阴影的显示。

在这里插入图片描述

阴影的优化和调整

阴影贴图大小
directionalLight.shadow.mapSize.width = 1024;
directionalLight.shadow.mapSize.height = 1024;
  • 阴影贴图越大约清晰,但是越消耗资源;
  • 512和1024大小对比图,就可以看出来对比效果是1024更清晰(运行效果更明显)。
    在这里插入图片描述
相机设置
幅度

我们先来看一个阴影不完整的现象:

不完整

正交相机OrthographicCamera

平行光源用的是正交相机进行渲染:

export class DirectionalLight extends Light<DirectionalLightShadow> {shadow: DirectionalLightShadow;
}export class DirectionalLightShadow extends LightShadow<OrthographicCamera> {camera: OrthographicCamera;
}
  1. 用相机辅助线看一下光线的阴影的相机视角:
const cameraHelper = new THREE.CameraHelper(directionalLight.shadow.camera);
scene.add(cameraHelper);

在这里插入图片描述
球体超过了阴影的相机视角的上边缘。

  1. 扩大相机的上边缘
directionalLight.shadow.camera.top = 8; // 这个值不是固定的,视场景不同

在这里插入图片描述

far

和相机的渲染一致,设置相机的far,可以控制是否显示阴影。

directionalLight.shadow.camera.far = 100;

在这里插入图片描述

Blur 模糊

我们可以使用 radius 属性控制阴影模糊:

directionalLight.shadow.radius = 20

在这里插入图片描述

阴影的边缘会有模糊的效果。

阴影的类型

Three.js中,ShadowMapType枚举定义了几种阴影映射的类型:

  • BasicShadowMap:基本阴影映射类型,使用简单的阴影投影算法生成阴影。这是默认的阴影映射类型。

性能优秀但是质量不好(默认)

  • PCFShadowMap:使用 Percentage-Closer Filtering (PCF)技术生成阴影,以获得更平滑的阴影边缘效果。

性能稍差但是拥有光滑的边缘

  • PCFSoftShadowMap:使用软阴影技术生成阴影,通过多次采样和模糊处理来产生更柔和的阴影效果。

性能稍差但是拥有更 soft 的边缘

  • VSMShadowMap:使用Variance Shadow Mapping (VSM)技术生成阴影,以获得更高质量的阴影效果和更柔和的阴影边缘。

性能稍差,更多限制,有着意想不到的效果

代码实现:

renderer.shadowMap.type = THREE.BasicShadowMap;

我项目中使用,倒是看不出来有啥大的区别。

http://www.yayakq.cn/news/804134/

相关文章:

  • 山东网站推广营销设计益阳seo快速排名
  • 昆山网站公司哪家好公司网络维护具体做什么
  • 关键词搜索站长工具室内设计自学教材
  • 毕设做网站 方面的论文网站霸词怎么做
  • 陕西营销型手机网站安卓app制作教程
  • 拥有域名后怎么建设网站iis管理器添加网站
  • 使用微信做网站第三方登录关键词歌词简谱
  • 标准网站建设报价备案查询平台官网
  • 韩国教育网站模板网站建设套餐内容
  • 网站开发的环境公众号开发者是什么
  • 网站做跳转会有什么影响宁波网站建设推广平台
  • 企业模板网站建设优势分析注册免费
  • 网站建设花钱少企业建设门户网站的需求
  • 做网站用什么语言制作最安全?怎样做网站店铺
  • 网站总体结构开网店咨询
  • 根据百度地图做网站深圳网站建设推广优化
  • 深圳网站建设服务哪个便宜点手机一键生成户型图
  • 做网站怎么接广告赚钱吗网站开发公司架构
  • 山西建设厅网站网站的统计代码
  • php音乐网站设计免费html网站模板
  • 自己做网站买软文推广代理
  • 上海做网站公司qinmoo信誉好的扬中网站建设
  • 大理 网站建设赵公口网站建设
  • 绍兴建设开发有限公司网站首页南京市建设工程造价信息网
  • 建俄语网站兰州网站制作联系方式
  • 电商网站联盟平台如何建设好医院网站
  • 一键建站平台厦门市市场开发建设服务中心网站
  • 古典风格网站模板苏州做公司邮箱企业网站
  • 廊坊网站建设招聘怎么制作网页链接在微信上发
  • 免费注册个人网站不花钱做农产品的网站