MagicCube / g3d

Realtime WebGL rendering maps and big data visualizations based on MXFramework and Three.js.
http://magiccube.github.io/g3d/
55 stars 28 forks source link

misbehaviour when adding some threejs objects to map #2

Open am2222 opened 7 years ago

am2222 commented 7 years ago

Hi, I am very intrested into this project. I tried to add some trees to your sample project using this codes

`

        var dataSrc = '';
var geometry = new THREE.Geometry();
    var image = document.createElement('img');
    image.src = dataSrc;
    var sprite = new THREE.Texture(image);
    sprite.needsUpdate = true;
    for (var i = 0; i < 20; i++) {
        var vertex = new THREE.Vector3();
        vertex.x = 2000 * Math.random() - 1000;
        vertex.y = 2000 * Math.random() - 1000;
        vertex.z = 50;
        geometry.vertices.push(vertex);
    }
   var material1 = new THREE.PointCloudMaterial({
        size: 20,
        sizeAttenuation: true,
        map: sprite,
        transparent: true,
        alphaTest: 0.5
    });
    // material.color.setHSL(1.0, 0.3, 0.7);
   var particles = new THREE.PointCloud(geometry, material1);
    particles.scale.set(.1, .1, .1);
    mapView.scene.add(particles);

It works fine but when I try to rotate map the background map shows some misbehaviors and it seems it does not load background tiles anymore. Can you please help me to debug it? thanks

am2222 commented 7 years ago

I have tested and it seems the problem is because of updating threejs to last version, But I have no idea what cause this problem in new threejs

am2222 commented 7 years ago

Update:It seems threejs tries to resize 2d image materials into a power image.based on this link makePowerOfTwo

and this link

textureNeedsPowerOfTwo

says that there has to be two options of texture.minFilter== NearestFilter or texture.minFilter !== LinearFilter

set for material. I tried to add this line material.minFilter = THREE.NearestFilter; here _loadZoomMaterial

but nothing changed. Only some of warnings disappeared, I think the material should change in somewhere else