THREE.js的SVG路径(坐标)

时间:2016-10-12 07:38:33

标签: javascript css svg three.js

我已从ThreeJs Example获取了用于生成此City Model的确切代码。

我从Google地图生成了一个城市边界SVG路径,并希望使用上面的代码生成相同类型的3D对象。我的SVG路径代码在

之下
"M -378463.90230276587 -216828.5204525995 L -378463.90230276587 -216828.5204525995 L -378468.4733200769 -216800.78018946826 L -378457.36255405867 -216726.32967956597 L -378453.2523036701 -216708.13985810167 L -378446.23084408935 -216645.84207578097 L -378446.40886767313 -216640.48042431887 L -378440.04714254953 -216593.4246023558 L -378428.4180137435 -216539.991347306 L -378408.5945640994 -216510.42896043573 L -378385.51956605876 -216467.31060126523 L -378379.14213297196 -216451.9325052259 L -378359.4495830217 -216424.30743382534 L -378348.87288775464 -216401.72985462152 L -378333.6361633847 -216381.90640497737 L -378337.86684149154 -216373.22513727797 L -378341.7990682963 -216369.96835289372 L -378342.2388912678 -216365.88428244408 L -378331.6883759395 -216327.93384318874 L -378324.9287157465 -216311.89601269213 L -378325.3318868038 -216300.2721198738 L -378321.78712309286 -216297.53893426526 L -378317.28940961056 -216296.21946535073 L -378303.3616821797 -216270.99771233014 L -378293.1933939575 -216243.98001550927 L -378293.88454434136 -216242.82286221522 L -378290.4863882877 -216243.61349636634 L -378276.29162548116 -216233.02632912374 L -378253.8973058489 -216247.0954282241 L -378224.3558629296 -216248.45678504065 L -378204.8989324284 -216228.3558280454 L -378170.660808492 -216241.304425766 L -378170.3675931776 -216235.0578923731 L -378170.22622150823 -216232.0943233032 L -378169.26279976114 -216211.52212740996 L -378152.6542465991 -216208.78370581358 L -378105.9858877301 -216201.0815678245 L -378090.63397162955 -216173.3308327178 L -378065.06664341706 -216168.73363546806 L -378045.64636483014 -216185.9233832709 L -378059.37512472627 -216241.5662251538 L -378059.1971011426 -216244.0742632889 L -378057.3906853668 -216269.52639977072 L -378057.05034616264 -216274.34874449397 L -378054.1391369704 -216315.39365251316 L -378045.7615565607 -216328.4836219031 L -377993.89386184997 -216365.8895184318 L -377991.3072838986 -216367.75353007295 L -377955.1789683823 -216371.94232027777 L -377921.14504796837 -216364.08833864375 L -377920.3229978907 -216362.99925319053 L -377915.61584489804 -216367.39224691782 L -377913.6942373916 -216371.958028241 L -377932.8213006642 -216381.0267590344 L -377936.1670968403 -216393.19519457928 L -377929.9310354229 -216427.5799261728 L -377939.4710051143 -216469.85529131463 L -377948.89578307513 -216477.70927294862 L -377959.25780284416 -216480.447694545 L -377976.6465181818 -216485.03965580696 L -377979.7881108354 -216489.22844601178 L -377976.1229194062 -216505.46000805535 L -377983.93501313817 -216532.14783764756 L -377982.971591391 -216552.4215822387 L -378001.82638330036 -216597.61862854837 L -378000.06709141436 -216607.12194632547 L -378003.0044805454 -216615.18013148196 L -377994.6426080991 -216627.98212154533 L -377998.3287434793 -216637.62681099182 L -378000.4283745695 -216641.8679610742 L -378139.4071975765 -216833.3689772615 L -378144.8997487325 -216840.72030407088 L -378258.3531314292 -216996.0772967787 L -378439.5811396393 -216981.68356643748 L -378444.60768788506 -216944.65466102716 L -378449.5399883511 -216925.05112286875 L -378452.2784099475 -216906.3272306534 L -378452.4773774823 -216884.08475466596 L -378456.9332030626 -216867.26676199373 L -378459.5302529896 -216845.6735484881 L -378462.4571701452 -216837.2540801764 L -378463.90230276587 -216828.5204525995 "

如果我将SVG路径从示例替换为上面提到的,它甚至都不显示。对Three.jsSVG都是全新的,我不确定我做错了什么。

到目前为止,我的猜测是我的示例中的SVG坐标非常大,无法在视口中看到。为此,我尝试使用transform = translate(-378460px, -216828px)方法。但没有运气。有什么建议 ?非常感谢帮助。

2 个答案:

答案 0 :(得分:0)

SVG坐标系是(x,y)是右边的x单位,y单位是。

(x,y,z)的Three.js坐标系是右边的x单位,y是向上的,z是远离你的单位。

你需要进行某种转换。

如果我正在为我的Three.js做二维模型的SVG表示,我正在使用x& z轴作为我的SVG x,y轴,我将使我的SVG模式有一个transform =“translate(width / w,height / 2)scale(1,-1)”

这是将(0,0)移动到svg的中间并使x,y移动到与three.js模型相同的方向

答案 1 :(得分:0)

你没有看到你的身材,因为它远离你的相机视野。我在Threejs示例的代码中做了一些更改。

1)添加了一个行,该行为包含从SVG路径获取的拉伸几何体的网格添加名称。使用您的SVG路径代码,我们将只获得一个名为" mesh00"的网格。 (在mesh.name = "mesh" + i + j;函数中,行为var svgObj = scene.getObjectByName("mesh00",true);

2)当我知道这个人物的名字时,我可以找到它

svgObj.geometry.center();

3)并以此为中心

OrbitControls

当然,由您决定如何使您的相机可以看到您的数字。例如,您可以将相机移动到图形或(像我一样)将图形移到相机前面。在示例中,相机位置非常靠近,因此我将其移得更远。

jsfiddle示例

PS。我应用了cudaError来让观看更加舒适。