javascript
复制代码
/**
* 创建场景对象Scene
*/
var scene = new THREE.Scene();
// 创建一个纹理贴图加载器
var textureLoader = new THREE.TextureLoader()
// 创建一个组对象,用来插入地球、大气层网格模型
var group = new THREE.Group()
/**
* 地球网格模型
*/
var earthGeometry = new THREE.SphereBufferGeometry(100, 30, 30);
var earthMaterial = new THREE.MeshPhongMaterial({
map: textureLoader.load('Earth.png'),
normalMap: textureLoader.load('EarthNormal.png'),
normalScale: new THREE.Vector2(2.9, 2.9),
specularMap: textureLoader.load('EarthSpec.png'),
transparent: true,
opacity: 0.7,
});
var earthMesh = new THREE.Mesh(earthGeometry, earthMaterial);
// 地球网格模型插入组对象中
group.add(earthMesh);
// 创建一个大气层几何体,注意比地球几何体的半径略大一些
var geometry = new THREE.SphereBufferGeometry(100.1, 30, 30); //球体
var texture = textureLoader.load('./大气.png');
// 设置重复的作用是:能够让一个效果循环
texture.wrapS = THREE.RepeatWrapping;
texture.wrapT = THREE.RepeatWrapping;
// 自定义顶点着色器对象
var material = new THREE.ShaderMaterial({
uniforms: {
// texture对应顶点着色器中uniform声明的texture变量
texture: {
value: texture,
},
time: {
value: 0.0
},
},
// 顶点着色器
vertexShader: document.getElementById('vertexShader').textContent,
// 片元着色器
fragmentShader: document.getElementById('fragmentShader').textContent,
// 开启透明度
transparent: true,
});
// 创建大气层网格模型
var mesh = new THREE.Mesh(geometry, material);
group.add(mesh); //大气层网格模型对象插入组对象中
scene.add(group);
/**
* 光源设置
*/
// 方向光1
var directionalLight = new THREE.DirectionalLight(0xffffff, 0.9);
directionalLight.position.set(400, 200, 300);
scene.add(directionalLight);
// 方向光2
var directionalLight2 = new THREE.DirectionalLight(0xffffff, 0.9);
directionalLight2.position.set(-400, -200, -300);
scene.add(directionalLight2);
//环境光
var ambient = new THREE.AmbientLight(0xffffff, 0.6);
scene.add(ambient);
/**
* 相机设置
*/
var width = window.innerWidth; //窗口宽度
var height = window.innerHeight; //窗口高度
var k = width / height; //窗口宽高比
var s = 150; //三维场景显示范围控制系数,系数越大,显示的范围越大
//创建相机对象
var camera = new THREE.OrthographicCamera(-s * k, s * k, s, -s, 1, 1000);
camera.position.set(0, 100, 200); //设置相机位置
camera.lookAt(scene.position); //设置相机方向(指向的场景对象)
/**
* 创建渲染器对象
*/
var renderer = new THREE.WebGLRenderer({
antialias: true
});
renderer.setSize(width, height); //设置渲染区域尺寸
document.body.appendChild(renderer.domElement); //body元素中插入canvas对象
// 创建一个时钟对象Clock
var clock = new THREE.Clock();
// 渲染函数
function render() {
// 获得两次渲染的时间间隔deltaTime
var deltaTime = clock.getDelta();
// 更新uniforms中时间,这样就可以更新着色器中time变量的值
material.uniforms.time.value += deltaTime;
group.rotateY(-0.005)
renderer.render(scene, camera); //执行渲染操作
requestAnimationFrame(render); //请求再次执行渲染函数render,渲染下一帧
}
render();
//创建控件对象 相机对象camera作为参数 控件可以监听鼠标的变化,改变相机对象的属性
var controls = new THREE.OrbitControls(camera,renderer.domElement);