//创建场景
var scene = new THREE.Scene();
//透视摄像机(视野角度,长宽比,远剪切面,进剪切面,)
var camera = new THREE.PerspectiveCamera(75,window.innerWidth/window.innerHeight,0.1,1000);
//渲染器
var renderer = new THREE.WebGLRenderer();
//设置渲染器的大小
renderer.setSize(window.innerWidth,window.innerHeight);
//渲染器renderer的domElement元素,表示渲染器中的画布
document.body.appendChild(renderer.domElement);
//创建几何体(长,宽,高)
var geometry = new THREE.CubeGeometry(2,2,2);
//材质增加颜色
var material = new THREE.MeshBasicMaterial({color:0x00ff00});
//网格(几何体,材质)
var cube = new THREE.Mesh(geometry,material);
//场景增加几何体
scene.add(cube);
camera.position.z=5;
function render(){
requestAnimationFrame(render);
cube.rotation.x += 0.1;
cube.rotation.y += 0.1;
//渲染(场景,相机)render( scene, camera, renderTarget, forceClear )
//renderTarget:渲染的目标,默认是渲染到前面定义的render变量中
//forceClear:每次绘制之前都将画布的内容给清除,即使自动清除标志autoClear为false,也会清除
renderer.render(scene, camera);
}
render();

按照功能分解成函数

        var renderer;
function initThree(){
width = document.getElementById('canvas-frame').clientWidth;
height = document.getElementById('canvas-frame').clientHeight;
renderer = new THREE.WebGLRenderer({
antialias:true
});
renderer.setSize(width,height);
document.getElementById('canvas-frame').appendChild(renderer.domElement);
renderer.setClearColor(0xffffff,1.0)
} var camera;
function initCamera(){
camera = new THREE.PerspectiveCamera(45,width/height,1,10000);
camera.position.x=0;
camera.position.y=1000;
camera.position.z=0;
camera.up.x=0;
camera.up.y=0;
camera.up.z=1;
camera.lookAt({
x:0,
y:0,
z:0
})
} var scene;
function initScene(){
scene = new THREE.Scene();
}; var light;
function initLight(){
light = new THREE.DirectionalLight(0xff0000,1.0,0);
light.position.set(100,100,200);
scene.add(light);
} var cube;
function initObject(){
var geometry = new THREE.Geometry();
var material = new THREE.LineBasicMaterial({
vertexColors:THREE.VertexColors
});
var color1= new THREE.Color(0x444444),
color2= new THREE.Color(0xff0000);
var p1 = new THREE.Vector3(-100,0,100);
var p2 = new THREE.Vector3(100,0,-100);
geometry.vertices.push(p1);
geometry.vertices.push(p2);
geometry.colors.push(color1,color2);
var line = new THREE.Line(geometry,material,THREE.LinePieces);
scene.add(line);
} function render(){
renderer.clear();
renderer.render(scene,camera);
requestAnimationFrame(render);
} function threeStart(){
initThree();
initCamera();
initScene();
initLight();
initObject();
render();
}
threeStart();

最新文章

  1. [No0000A6]Visual Studio 2015 中的常用命令的默认键盘快捷键-VS2015 Shortcut
  2. java版简易socket客户端
  3. Adaboost 算法
  4. 重新安装配置ubuntu的引导菜单
  5. unity, polygon collider 2D 添加顶点
  6. 用JSP实现的商城购物车模块
  7. Oracle新建用户、角色,授权,建表空间
  8. JavaScript自学代码--(四)
  9. JS DOM 来控制HTML元素
  10. spring获取properties
  11. Libcurl最初的实现tfp上传和下载功能
  12. python加载sqlite3报错:No module named _sqlite3
  13. .7-Vue源码之AST(3)
  14. 51nod1649- 齐头并进-最短路
  15. java.sql.SQLException之数组越界
  16. bugfree,CDbConnection 无法开启数据库连线: SQLSTATE[HY000] [2003] Can't connect to MySQL server on '192.168.0.99' (4)
  17. 使用Docker安装Jenkins
  18. 重置studio 3T 14天试用
  19. 微信tinker 热修复
  20. javascript ----字符串的使用

热门文章

  1. 基于【 Docker】三 || Docker的基本操作
  2. swiper按钮点击无效及控制器无效问题
  3. 从ABAP Netweaver的SICF到SAP Kyma的Lambda Function
  4. B树Java代码实现以及测试
  5. Linux 01 LiunxvI命令大全
  6. Ubuntu系统---C++之Eclipse编译器 CDT插件安装
  7. flask参数传递
  8. CDN加速地址URL拿不到,显示“无法访问此网站”
  9. Mysql+keepalived
  10. idea在springboot项目中显示Run Dashboard