console
javascript: (function () {
var script = document.createElement('script');
script.onload = function () {
var stats = new Stats();
document.body.appendChild(stats.dom);
requestAnimationFrame(function loop() {
stats.update();
requestAnimationFrame(loop);
});
};
script.src = 'https://mrdoob.github.io/stats.js/build/stats.min.js';
document.head.appendChild(script);
})();
var map = new AMap.Map('container', {
center: [116.54, 39.79],
zooms: [2, 20],
zoom: 14,
viewMode: '3D',
pitch: 50,
});
var camera;
var renderer;
var scene;
var meshes = [];
let texture;
var customCoords = map.customCoords;
var data = customCoords.lngLatsToCoords([
[116.52, 39.79],
[116.54, 39.78],
[116.56, 39.79],
]);
const testData = customCoords.lngLatsToCoords([
[
116.18657032,
39.82981112
],
[
116.46982646,
39.7899015
],
[
116.56519504,
39.92211609
],
[
116.44064767,
40.05080839
],
[
116.20151513,
39.99412627
],
[
116.18657032,
39.82981112
]
])
function calcDis([x1, y1], [x2, y2]) {
return Math.sqrt(Math.pow(x2-x1, 2) + Math.pow(y2-y1, 2))
}
var gllayer = new AMap.GLCustomLayer({
zIndex: 8,
init: (gl) => {
camera = new THREE.PerspectiveCamera(
60,
window.innerWidth / window.innerHeight,
100,
1 << 30
);
renderer = new THREE.WebGLRenderer({
context: gl,
});
renderer.autoClear = false;
scene = new THREE.Scene();
var aLight = new THREE.AmbientLight(0xffffff, 1);
scene.add(aLight);
const base_64 = ''
texture = new THREE.TextureLoader().load(base_64)
texture.wrapS = THREE.RepeatWrapping;
texture.wrapT = THREE.RepeatWrapping;
texture.minFilter = THREE.LinearFilter;
var mat = new THREE.MeshPhongMaterial({
color: 0xfff0f0,
depthTest: true,
transparent: true,
map: texture,
side: THREE.DoubleSide,
});
const geometry = new THREE.BufferGeometry();
let indices = [];
let vetices = [];
let normals = [];
let colors = [];
let uvs = [];
const vec3List = [];
console.log(testData)
for(let i =0; i< testData.length; i++) {
const [x1, y1] = testData[i]
vec3List.push([x1, y1, 100])
vec3List.push([x1, y1, 2500])
}
const t0 = [0, 0]
const t1 = [1, 0]
const t2 = [1, 1]
const t3 = [0, 1]
for(let i =0; i< vec3List.length - 2; i++) {
const repeatCount = Math.round(calcDis(vec3List[i], vec3List[i+2])/ 2500)
if (i % 2 === 0) {
vetices = [...vetices, ...vec3List[i], ...vec3List[i+2], ...vec3List[i+1] ]
uvs = [
...uvs,
t0[0] * repeatCount, t0[1],
t1[0] * repeatCount, t1[1],
t3[0] * repeatCount, t3[1],
]
const vA = new THREE.Vector3().fromArray(vec3List[i]);
const vB = new THREE.Vector3().fromArray(vec3List[i+2]);
const vC = new THREE.Vector3().fromArray(vec3List[i+1]);
const ab = new THREE.Vector3().subVectors(vB, vA);
const ac = new THREE.Vector3().subVectors(vC, vA);
const normal = new THREE.Vector3().crossVectors(ab, ac).normalize();
normals = [...normals, normal.x, normal.y, normal.z];
normals = [...normals, normal.x, normal.y, normal.z];
normals = [...normals, normal.x, normal.y, normal.z];
} else {
vetices = [...vetices, ...vec3List[i], ...vec3List[i+1], ...vec3List[i+2] ]
uvs = [
...uvs,
t3[0] * repeatCount, t3[1],
t1[0] * repeatCount, t1[1],
t2[0] * repeatCount, t2[1],
]
const vA = new THREE.Vector3().fromArray(vec3List[i]);
const vB = new THREE.Vector3().fromArray(vec3List[i+1]);
const vC = new THREE.Vector3().fromArray(vec3List[i+2]);
const ab = new THREE.Vector3().subVectors(vB, vA);
const ac = new THREE.Vector3().subVectors(vC, vA);
const normal = new THREE.Vector3().crossVectors(ab, ac).normalize();
normals = [...normals, normal.x, normal.y, normal.z];
normals = [...normals, normal.x, normal.y, normal.z];
normals = [...normals, normal.x, normal.y, normal.z];
}
}
geometry.setAttribute( 'position', new THREE.Float32BufferAttribute( vetices, 3 ) );
geometry.setAttribute( 'normal', new THREE.Float32BufferAttribute( normals, 3 ) );
geometry.setAttribute( 'uv', new THREE.Float32BufferAttribute( uvs, 2 ) );
testMesh = new THREE.Mesh( geometry, mat );
scene.add( testMesh );
},
render: () => {
renderer.resetState();
customCoords.setCenter([116.52, 39.79]);
var { near, far, fov, up, lookAt, position } =
customCoords.getCameraParams();
camera.near = near;
camera.far = far;
camera.fov = fov;
camera.position.set(...position);
camera.up.set(...up);
camera.lookAt(...lookAt);
camera.updateProjectionMatrix();
renderer.render(scene, camera);
renderer.resetState();
},
});
map.add(gllayer);
let offset = 0
const speed = 0.01
function animate() {
offset += speed;
if(offset >= 1) {
offset = 0
}
console.log('texture: ', texture)
texture.offset.set(0, offset)
map.render();
requestAnimationFrame(animate);
}
animate();
function onWindowResize() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize(window.innerWidth, window.innerHeight);
}
window.addEventListener('resize', onWindowResize);
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta
name="viewport"
content="initial-scale=1.0, user-scalable=no, width=device-width"
/>
<title>自定义三维图层</title>
<link
rel="stylesheet"
href="https://a.amap.com/jsapi_demos/static/demo-center/css/demo-center.css"
/>
<style>
html,
body,
#container {
width: 100%;
height: 100%;
}
</style>
</head>
<body>
<div id="container"></div>
<script src="https://cdn.jsdelivr.net/npm/three@0.142/build/three.js"></script>
<script src="//webapi.amap.com/maps?v=2.0&key=4ee1bad27d5a07c45f128e904022f5f2"></script>
</body>
</html>