WebGL是一种3D绘图标准,这种绘图技术标准允许把JavaScript和OpenGL ES 2.0结合在一起,通过增加OpenGL ES 2.0的一个JavaScript绑定,提供硬件3D加速渲染,这样Web开发人员就可以借助系统显卡来在浏览器里更流畅地展示3D场景和模型了,还能创建复杂的导航和数据视觉化。显然,WebGL技术标准免去了开发网页专用渲染插件的麻烦,可被用于创建具有复杂3D结构的网站页面,甚至可以用来设计3D网页游戏等等。

渲染流水线设计如下:应用程序层 -> 硬件抽象层 -> 硬件层

为什么要选择GPU

CPU: 它的优点在于调度、管理、协调能力强,计算能力则位于其次,对同一数据做许多事。

GPU:相当于一个接受CPU调度的“拥有大量计算能力”的员工,对大量数据做同一样事,图形处理,矩阵运算,机器学习

Webgl核心要素

  1. 顶点着色器,片元着色器
  2. 坐标转换
  3. 申请缓存区 像素传递
  4. 光照(光源和反射)
  5. 纹理(坐标转换和像素映射)
  6. 观察者的视图矩阵 透视矩阵与正射矩阵
  7. 图形变换,平移,缩放,旋转
  8. 模型
  9. 游戏引擎Babylon.js,3D渲染引擎three.js

两大着色器

顶点着色器(Vertex shader):描述顶点(像素)特性比如的大小和位置,

片段着色器(Fragment shader):描述顶点点的颜色信息,处理像素点,使其显示在屏幕上

坐标系

webgl坐标系:中心原点在canvas坐标系的中心,右手定则坐标,范围从0到1,纹理坐标系:左下角为原点,范围从0到1,

canvas坐标系:左上角为原点

本地坐标系:模型被设计时的坐标系

世界坐标系:模型被放入到场景中时,场景的坐标系

光照

 

每个物体的光照由两个因素决定:

发出光线的光源的类型,平行光(太阳光);点光源(人造灯)聚光灯

物体表面如何反射光线,漫反射和环境反射

三维图形学术语着色:根据光照条件重建‘物体各表面明暗不一的效果’

视角投影

  1. 正射投影

也称盒状空间投影,物体看上去的大小与所在位置没有关系,适用于建筑模型等

  1. 透视投影

也称金字塔可视投影。近大远小,符合人眼观察

图形变换

缩放:gl_Position.w中的w值代表缩放比,齐次线性方程里的w

数学表达式:

平移:这个一个逐顶点操作,发生在顶点着色器上,用原始坐标的每个分量加上偏移量, 将声明的Tx,Ty,Tz偏移数值赋值给gl_Position,

数学表达式:

旋转:需要对顶点坐标进行三个步骤考虑:

旋转轴:你要指明通过哪个轴进行旋转;

旋转方向:逆时针还是顺时针旋转;

旋转的角度

 

利用数学的两角和公式:

更科学的方式是使用变换矩阵

webgl核心要素的更多相关文章

  1. CODING 敏捷实战系列课第二讲:Scrum 敏捷项目管理核心要素之 3355

    Scrum 是敏捷开发流派中最著名和最落地的一支,全球 70% 以上公司的敏捷转型都是以 Scrum 起步.CODING 特邀敏捷顾问.CST & CTC 认证敏捷教练申健老师将在本课程< ...

  2. unittest自动化测试框架核心要素以及应用

    1. unittest核心要素 unittest介绍 测试框架,不仅仅用于单元测试 python自动的测试包 用法和django.test.TestCase类似 1.1.unitest介绍和核心要素 ...

  3. 独立开发一个云(PaaS)的核心要素, Go, Go, Go!!!

    最近一年的工作,有很大的比重在做云平台的事情,简单来说,就是为公司内用户提供一个PaaS,用户可以在我们的云平台上方便的将单机服务程序扩展为多实例程序,以平台服务化的方式对外提供.在这里简单分享一下. ...

  4. 基于.NetCore3.1系列 —— 日志记录之日志核心要素揭秘

    一.前言 在上一篇中,我们已经了解了内置系统的默认配置和自定义配置的方式,在学习了配置的基础上,我们进一步的对日志在程序中是如何使用的深入了解学习.所以在这一篇中,主要是对日志记录的核心机制进行学习说 ...

  5. unittest核心要素

    1 TestCase 一个TestCase的实例就是一个测试用例.什么是测试用例呢?就是一个完整的测试流程, 包括测试环境的准备(setUp),执行测试代码(run),以及测试后环境的还原(tearD ...

  6. kubernetes核心概念

    摘抄自:  https://www.cnblogs.com/zhenyuyaodidiao/p/6500720.html 1.基础架构 1.1 Master Master节点上面主要由四个模块组成:A ...

  7. Kubernetes核心概念总结

    目录贴:Kubernetes学习系列 1.基础架构 1.1 Master Master节点上面主要由四个模块组成:APIServer.scheduler.controller manager.etcd ...

  8. Java生鲜电商平台-SpringCloud微服务架构中核心要点和实现原理

    Java生鲜电商平台-SpringCloud微服务架构中核心要点和实现原理 说明:Java生鲜电商平台中,我们将进一步理解微服务架构的核心要点和实现原理,为读者的实践提供微服务的设计模式,以期让微服务 ...

  9. 游戏数值——LOL篇 以LOL为起点-说游戏数值设计核心思路

      附     文   文档在今年三月份我动笔写了一小部分,但当时思路凌乱,行文梗阻,于是丢在一边构思了半年,现在又回过头来慢慢写,希望能写好写完吧,初衷是希望即时萌新也能看懂,但是好像并不能行——本 ...

随机推荐

  1. POJ 1743:Musical Theme(后缀数组+二分)

    题目链接 题意 有N个音符的序列来表示一首乐曲,每个音符都是1到88范围内的整数,现在要找一个重复的主题."主题"是整个音符序列的一个子串,它需要满足如下条件: 长度至少为5个音符 ...

  2. ajax 前端发含有列表的数据

    在前端页面也可以给后端发送一个包含列表的数据 html <body> <h3>index页面 </h3> <input type="text&quo ...

  3. Docker笔记(一):什么是Docker

    原文地址: http://blog.jboost.cn/2019/07/13/docker-1.html  1. 前言 接触Docker也有两年多了,断断续续玩过一些应用场景,如安装一些常用工具服务, ...

  4. windows快速创建文本文档的几个方法快捷键和

    1. 在平常使用电脑中要经常用到在左面创建文本文档txt最笨重的方法就是右键但是这样非常的慢,有没有什么快捷键呢 2. 快捷键 快捷键就是Win+R ,键入notepad 然后回车就可以编辑了 是不是 ...

  5. Markdown下,上传图片问题

    最简单的方法: 1,登录qq 2,登录博客园,并打开博客园添加随笔的地方:如图: 3,选择需要截屏的地方,按住ctrl+alt+A截屏,然后在qq的发送栏内贴过去 4,鼠标左键按住不松开,然后拖到这里 ...

  6. 工作经验之石氏thinking

    经常听到N多人说工作经验这个名词:也时常听到人说工作多少年就是多少年工作经验.我听着总觉得有点别扭,感觉他们把这个名词说的太简单了,而且觉得不是工作N年就一定有所谓的工作经验.我觉得归根结底还是在于工 ...

  7. ServiceFabric极简文档-5.1 编程模型选择

    项目中:actor用的服务是无状态服务:ASP.NET Core用的是无状态ASP.NET Core模板. ​

  8. Dapper学习笔记

    听说有个轻量化的orm Dapper,我就去了解下.试着对Sql Server和Mysql进行增删改查,体验不错.它不如EF臃肿,也比一般的封装灵活,比如我们封装了一个映射类.利用反射,在Execut ...

  9. 微信小程序生成随机数

    const charts = ['0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K', ...

  10. 洛谷P3324 [SDOI2015]星际战争 题解

    题目链接: https://www.luogu.org/problemnew/show/P3324 分析: 因为本题的时间点较多,不能枚举,但发现有单调性,于是二分答案,二分使用的时间TTT 每个攻击 ...