three.js学习5_渲染器
THREE.WebGLRenderer
WebGL Render 用WebGL渲染出你精心制作的场景
介绍
在之前的介绍中, 已经介绍过场景, 相机, 光源, 有了这些后, 就可以形成一个可观的三维展示效果, 但是, 若想让它展示在网页上, 就需要渲染器渲染到网页上
那WebGL又是啥, 这里借用百度的一段解释
WebGL(全写Web Graphics Library)是一种3D绘图协议,这种绘图技术标准允许把JavaScript和OpenGL ES 2.0结合在一起,通过增加OpenGL ES 2.0的一个JavaScript绑定,WebGL可以为HTML5 Canvas提供硬件3D加速渲染,这样Web开发人员就可以借助系统显卡来在浏览器里更流畅地展示3D场景和模型了,还能创建复杂的导航和数据视觉化。显然,WebGL技术标准免去了开发网页专用渲染插件的麻烦,可被用于创建具有复杂3D结构的网站页面,甚至可以用来设计3D网页游戏等等
在本文中, 主要描述WebGLRenderer的一些属性方法, 后续再写各大元素整合的博文.
构造函数的使用
参数 | 含义 | 默认值 |
---|---|---|
canvas | 一个供渲染器绘制其输出的canvas它和下面的domElement属性对应。 如果没有传这个参数,会创建一个新canvas | 无 |
context | 可用于将渲染器附加到已有的渲染环境(RenderingContext)中 | null |
precision | 着色器精度. 可以是 "highp", "mediump" 或者 "lowp". 如果设备支持,默认为"highp" . 点击here 查看"应该避免的事" | highp |
alpha | canvas是否包含alpha (透明度) | false |
premultipliedAlpha | renderer是否假设颜色有 premultiplied alpha | true |
antialias | 是否执行抗锯齿(效果更好, 开销更大) | false |
stencil | 绘图缓存是否有一个至少8位的模板缓存(stencil buffer)) | true |
preserveDrawingBuffer | 是否保留缓直到手动清除或被覆盖 | false |
powerPreference | 提示用户代理怎样的配置更适用于当前WebGL环境。 可能是"high-performance", "low-power" 或 "default" | default |
failIfMajorPerformanceCaveat | 检测到低性能时渲染器创建是否失败。 | false |
depth | 绘图缓存是否有一个至少6位的深度缓存(depth buffer) | true |
logarithmicDepthBuffer | 是否使用对数深度缓存。如果要在单个场景中处理巨大的比例差异,就有必要使用 | false |
其中, 大部分是平时用不上的, 很多我也还没具体使用过, 经常使用的有alpha和antialias, alpha可以让3维图透明, antialias可以让3维图变得更加清晰, 同时会让渲染器的压力加大.
属性
属性名: 类型 | 含义 | 默认值 |
---|---|---|
autoClear : Boolean | 定义渲染器是否在渲染每一帧之前自动清除其输出 | |
autoClearColor : Boolean | 如果autoClear为true, 定义renderer是否清除颜色缓存 | true |
autoClearDepth : Boolean | 如果autoClear是true, 定义renderer是否清除深度缓存 | true |
autoClearStencil : Boolean | 如果autoClear是true, 定义renderer是否清除模板缓存 | true |
debug.checkShaderErrors : Boolean | 如果checkShaderErrors为true,定义是否检查材质着色器程序 编译和链接过程中的错误。 禁用此检查生产以获得性能增益可能很有用。 强烈建议在开发期间保持启用这些检查。 如果着色器没有编译和链接 - 它将无法工作,并且相关材料将不会呈现 | true |
capabilities : Object | 一个包含当前渲染环境(RenderingContext)的功能细节的对象。 | |
clippingPlanes : Array | 用户自定义的剪裁平面,在世界空间中被指定为THREE.Plane对象。 这些平面全局使用。空间中与该平面点积为负的点将被切掉 | [] |
domElement : DOMElement | 一个canvas,渲染器在其上绘制输出。渲染器的构造函数会自动创建(如果没有传入canvas参数);你需要做的仅仅是像下面这样将它加页面里去: | |
extensions : Object | extensions.get方法的包装, 用于检查是否支持各种WebGL扩展 | |
gammaFactor : Float | 2 | |
outputEncoding : number | 定义渲染器的输出编码。如果渲染目标已经被设置使用。setrendertarget然后渲染目标。纹理。编码将被使用 | THREE. LinearEncoding |
info : Object | 一个对象,包含有关图形板内存和渲染过程的一系列统计信息。这些信息可用于调试或仅仅满足下好奇心 | |
localClippingEnabled : Boolean | 定义渲染器是否考虑对象级剪切平面 | false |
maxMorphTargets : Integer | 一个着色器中允许的最大MorphTargets数,切记标准材质只允许8个MorphTargets。 | 8 |
maxMorphNormals : Integer | 色器中允许的最大MorphNormal数。 切记标准材质只允许4个MorphNormal。 | 4 |
physicallyCorrectLights : Boolean | 是否使用物理上正确的光照模式 | false |
properties : Object | 渲染器内部使用,以跟踪各种子对象属性。 | |
renderLists : WebGLRenderLists | 在内部用于处理场景渲染对象的排序 | |
shadowMap : WebGLShadowMap | 如果使用,它包含阴影贴图的引用。 | |
shadowMap.enabled : Boolean | 如果设置开启,允许在场景中使用阴影贴图 | false |
shadowMap.autoUpdate : Boolean | 启用场景中的阴影自动更新 | true |
shadowMap.needsUpdate : Boolean | 当被设为true, 场景中的阴影贴图会在下次render调用时刷新(如果你已经禁用了阴影贴图的自动更新(shadowMap.autoUpdate = false), 那么想要在下一次渲染时更新阴影的话就需要将此值设为true) | false |
shadowMap.type : Integer | 定义阴影贴图类型 (未过滤, 关闭部分过滤, 关闭部分双线性过滤) | |
sortObjects : Boolean | 定义渲染器是否应对对象进行排序 | true |
state : Object | 包含设置WebGLRenderer.context状态的各种属性的函数 | |
toneMapping : Constant | NoToneMapping | |
toneMappingExposure : Number | 色调映射的曝光级别 | 1 |
xr : WebXRManager | 提供对渲染器的WebXR相关接口的访问。 |
capabilities : Object
一个包含当前渲染环境(RenderingContext)的功能细节的对象。
- floatFragmentTextures: 环境是否支持OES_texture_float扩展。 根据WebGLStats, 截至2016年2月,超过95%的支持WebGL的设备支持此功能
- floatVertexTextures: 如果floatFragmentTextures和vertexTextures都是true, 则此值为true
- getMaxAnisotropy(): 返回最大可用各向异性。
- getMaxPrecision(): 返回顶点着色器和片元着色器的最大可用精度。
- isWebGL2: true if the context in use is a WebGL2RenderingContext object.
- logarithmicDepthBuffer: 如果logarithmicDepthBuffer在构造器中被设为true且 环境支持EXT_frag_depth扩展,则此值为true 根据WebGLStats, 截至2016年2月, 约66%的支持WebGL的设备支持此功能
- maxAttributes: gl.MAX_VERTEX_ATTRIBS的值
- maxCubemapSize: gl.MAX_CUBE_MAP_TEXTURE_SIZE 的值,着色器可使用的立方体贴图纹理的最大宽度高度
- maxFragmentUniforms: gl.MAX_FRAGMENT_UNIFORM_VECTORS的值,片元着色器可使用的全局变量(uniforms)数量
- maxTextureSize: gl.MAX_TEXTURE_SIZE的值,着色器可使用纹理的最大宽度高度
- maxTextures: *gl.MAX_TEXTURE_IMAGE_UNITS的值,着色器可使用的纹理数量
- maxVaryings: gl.MAX_VARYING_VECTORS的值,着色器可使用矢量的数量
- maxVertexTextures: gl.MAX_VERTEX_TEXTURE_IMAGE_UNITS的值,顶点着色器可使用的纹理数量。
- maxVertexUniforms: gl.MAX_VERTEX_UNIFORM_VECTORS的值,顶点着色器可使用的全局变量(uniforms)数量
- precision: 渲染器当前使用的着色器的精度
- vertexTextures: 如果 .maxVertexTextures : Integer大于0,此值为true (即可以使用顶点纹理)
info : Object
一个对象,包含有关图形板内存和渲染过程的一系列统计信息。这些信息可用于调试或仅仅满足下好奇心。改对象包含以下字段:
- memory:
- geometries
- textures
- render:
- calls
- triangles
- points
- lines
- frame
- programs
默认情况下,每次调用渲染时这些数据都会重置。 但当时用一个或多个镜像时,最好使用自定义模式重置它们:renderer.info.autoReset = false; renderer.info.reset();
常见代码
renderer = new THREE.WebGLRenderer({
antialias: true,
});
renderer.setPixelRatio( window.devicePixelRatio );
renderer.setSize( window.innerWidth, window.innerHeight );
document.body.appendChild( renderer.domElement );
three.js学习5_渲染器的更多相关文章
- 「Django」rest_framework学习系列-渲染器
渲染器:作用于页面,JSONRenderer只是JSON格式,BrowsableAPIRenderer有页面,.AdminRenderer页面以admin形式呈现(需要在请求地址后缀添加?fromat ...
- jQuery插件jqplot的详细配置说明和渲染器
jQuery插件jqplot的详细配置说明和渲染器 (2012-08-23 08:57:42) 转载▼ 标签: jqplot 详细配置 渲染器 it 分类: 技术类 jQuery.jqplot插件的官 ...
- CSharpGL(34)以从零编写一个KleinBottle渲染器为例学习如何使用CSharpGL
CSharpGL(34)以从零编写一个KleinBottle渲染器为例学习如何使用CSharpGL +BIT祝威+悄悄在此留下版了个权的信息说: 开始 本文用step by step的方式,讲述如何使 ...
- 【three.js详解之二】渲染器篇
[three.js详解之二]渲染器篇 本篇文章将详细讲解three.js中渲染器(renderer)的设置方法. three.js文档中渲染器的分支如下: Renderers CanvasRend ...
- three.js引擎基础知识—摄像机、场景及渲染器
一.three.js采用右手坐标系: x轴正方向向右,y轴正方向向上,z轴由屏幕从里向外,如下图右: 二.3D编程三要素:场景.渲染器.摄像机 1.场景:创建的物品和模型都需放入场景中 threejs ...
- three.js 第二篇:场景 相机 渲染器 物体之间的关系
w我用画画来形容他们之间的关系 场景就是纸张 相机就是我们的眼睛 物体就是在我们脑海中构思的那个画面 渲染器就是绘画这个动作 场景(Scene): 初始化:var scene = new THREE. ...
- 【十天自制软渲染器】DAY 01:图形学学习建议与环境搭建
推荐直接阅读博客原文,更新更及时,阅读体验更佳 「十天自制软渲染器」这个标题我承认标题党了.在对图形学一无所知的情况下想十天自制一个软渲染器,就好似一节课没上过却试图一个晚上看完<30 天精通 ...
- Restful API学习Day5 - DRF之限制 分页 解析器和渲染器
参考文档: Django REST framework基础:认证.权限.限制 Django REST framework基础:分页 Django REST framework基础:解析器和渲染器 一. ...
- Three.js学习笔记 – “我和小伙伴都惊呆了”的特效和Three.js初探
什么是Three.js three.js是JavaScript编写的WebGL第三方库.提供了非常多的3D显示功能.Three.js 是一款运行在浏览器中的 3D 引擎,你可以用它创建各种三维场景,包 ...
随机推荐
- 巧用HashMap一行代码统计单词出现次数
简介 JDK是在一直在迭代更新的,很多我们熟悉的类也悄悄的添加了一些新的方法特性.比如我们最常用的HashMap. 今天给大家讲一下HashMap在JDK8中添加的两个新方法compute和merge ...
- 【亲测】手把手教你如何破解pycharm(附安装包和破解文件)
此教程支持最新的2019.3版本的Pycharm,并兼容之前的版本. 一.准备工作: 1.下载Pycharm 有条件的可以自行去官网下载,这里我提供了我下载的版本,已上传到百度网盘,链接在下方. 2. ...
- Java-学习日记(100 == 100为true,1000 == 1000却为false?)
Integer底层设计 100 == 100为true,1000 == 1000却为false? 之前也写过String的==与equals的注意点,这次写下Integer的底层设计,不妨先运行下下面 ...
- Unity内生成深度贴图
https://qiita.com/bokkuri_orz/items/08cbaeae6a34fed7f903 https://www.cnblogs.com/sifenkesi/p/4721649 ...
- 初级知识点二——C#值传递
C#中有值传递和引用传递,这个东西一直有点儿绕,今天花点儿时间来把这个事情搞清楚. 传递值类型的参数 值类型的变量,是直接包含其数据的.实际上,在向方法传递一个值类型变量,其实就意味着向方法传递了一个 ...
- 程序员你的maven多模块项目如何对外输出为一个构件?
上图为常见的台式机,程序员,你看了有啥启发? 台式机生产线 我的maven代码工程 xxx 显示器 xxx-web 主机 xxx-app 键盘 xxx-domian 鼠标 xxx-infrastrat ...
- 转载:SQL优化的主旨
如果把查询看作是一个任务,那么它由一系列子任务组成,每个子任务都会消耗一定的时间. 如果要优化查询,实际上要优化其子任务, 要么消除其中一些子任务, 要么减少子任务的执行次数, 要么让子任务执行得更快 ...
- 20190923-04Linux用户管理命令 000 012
useradd 添加新用户 1.基本语法 useradd 用户名 (功能描述:添加新用户) useradd -g 组名 用户名 (功能描述:添加新用户到某个组) 2.案例实操 (1)添加一个用户 [ ...
- [oracle/sql]关于清除重复,not in方案和not exists方案的对比
有这样一张表: CREATE TABLE tb_sc ( id NUMBER not null primary key, studentid int not null, courseid int no ...
- 数据库增量备份,恢复innobackex
Xtrabackup 一款强大的在线热备工具 备份过程中不锁表,适合生产坏境 Xtrabackup:C程序,支持innodb/xtradb Innobackupex:innodb/mysiam #rp ...