首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >动态更改svg的颜色并在three.js中作为纹理应用

动态更改svg的颜色并在three.js中作为纹理应用
EN

Stack Overflow用户
提问于 2017-08-29 04:55:46
回答 1查看 1.7K关注 0票数 0

我正在尝试用three.js创建一个配置器,但是我需要改变产品的颜色,我想我可以使用svg作为纹理,改变svg的填充属性并很容易地更新纹理,但是我没有很好的效果。

目前我所拥有的是

使用svg作为纹理应用的-A 3D模型,但svg被放置在外部文件(“TextureLoader /texture.svg”)中( three.js也在缩小纹理的大小,但我认为这是一个映射问题)

-The svg是分层的,因此我可以手动更改颜色并应用它。

但是我想让它动态化,你选择一种颜色,它会自动更新作为纹理应用的svg。

有什么想法吗?

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-29 08:04:49

我拿了别人的小提琴来展示解决方案。我添加了一个点击功能,它可以修改SVG并重绘模型上的材质。

请参阅http://jsfiddle.net/L4pepnj7/

在示例中的任意位置单击以更改SVG中圆的颜色。

将SVG转换为encodedURI的操作过于密集,需要在一个常量循环中进行,但您可以在渲染器执行自己的操作时将颜色更改放在单击事件中。我在现有的fiddle中添加了一个名为"clickBody“的函数,用于更改其中一个SVG元素的颜色。

代码语言:javascript
运行
复制
var mesh;
var scene = new THREE.Scene();

var camera = new THREE.PerspectiveCamera(50, 500 / 400, 0.1, 1000);
camera.position.z = 10;

var renderer = new THREE.WebGLRenderer({
    antialias: true
});
renderer.setSize(500, 400);
document.body.appendChild(renderer.domElement);

var svg = document.getElementById("svgContainer").querySelector("svg");
var svgData = (new XMLSerializer()).serializeToString(svg);

var canvas = document.createElement("canvas");
var svgSize = svg.getBoundingClientRect();
canvas.width = svgSize.width;
canvas.height = svgSize.height;
var ctx = canvas.getContext("2d");

var img = document.createElement("img");
var material;
img.setAttribute("src", "data:image/svg+xml;base64," + window.btoa(unescape(encodeURIComponent(svgData))));

img.onload = function() {
    ctx.drawImage(img, 0, 0);
    var texture = new THREE.Texture(canvas);
    texture.needsUpdate = true;
    var geometry = new THREE.SphereGeometry(3, 50, 50, 0, Math.PI * 2, 0, Math.PI * 2);
    material = new THREE.MeshBasicMaterial({
        map: texture
    });
    material.map.minFilter = THREE.LinearFilter;
    mesh = new THREE.Mesh(geometry, material);
    scene.add(mesh);
};



var colors = ["red", "orange", "yellow", "green", "blue"];


var c = 0;

function clickBody() {
    document.getElementById("test").setAttribute("fill", colors[c]);
    var svgData = (new XMLSerializer()).serializeToString(svg);
    img.setAttribute("src", "data:image/svg+xml;base64," + window.btoa(unescape(encodeURIComponent(svgData))));
    img.onload = function() {
        ctx.drawImage(img, 0, 0);
        var texture = new THREE.Texture(canvas);
        material.map = texture;
        material.map.needsUpdate = true;
        renderer.render(scene, camera);
    }
    c = c + 1;
    if (c == colors.length) {
        c = 0;
    }
}
document.body.addEventListener("click", clickBody)

var render = function() {
    requestAnimationFrame(render);
    mesh.rotation.y += 0.01;
    renderer.render(scene, camera);
};


render();
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45927235

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档