5
A
回答
9
剛剛爲Cinema4D寫了另一個python腳本。
你可以找到disturb media blog和wiki的細節。
僅供參考,我在這裏列出源太:
'''
author : "George Profenza"
url : ("disturb", "disturbmedia.com/blog","My blog, http://tomaterial.blogspot.com")
Export meshes the three.js 3D Engine by mr.doob's et al.
More details on the engine here:
https://github.com/mrdoob/three.js
Currently supports UVs. If the model doesn't display correctly
you might need to reverse some normals/do some cleanup.
Also, if you use Selection Tags and basic ColorMaterials,
the colours will be picked up as face colors. Call autoColor() on the
model you use for this.
The mesh transformations(position, rotation, scale) are saved
and you can get them using: getPosition(), getRotation() and getScale()
each returning a THREE.Vector3
In short
var myGeom = new myC4DGeom();
var myModel = new THREE.Mesh(myGeom, new THREE.MeshFaceMaterial());
//set transforms
model.position = myGeom.getPosition()
model.rotation = myGeom.getRotation()
model.scale = myGeom.getScale()
//set selection tags colours
myGeom.autoColor()
More details on this exporter and more js examples here:
https://github.com/orgicus/three.js
Have fun!
This script requires Cinema 4D R11.5 minimum and the Py4D Plugin:
http://www.py4d.com/get-py4d/
'''
import c4d
from c4d import documents,UVWTag,storage
from c4d.utils import *
from c4d import symbols as sy, plugins, utils, bitmaps, gui
import math
import re
# utils
clean = lambda varStr: re.sub('\W|^(?=\d)','_', varStr)
# from Active State's Python recipies: http://code.activestate.com/recipes/266466-html-colors-tofrom-rgb-tuples/
def RGBToHTMLColor(rgb_tuple):
return '0x%02x%02x%02x' % rgb_tuple
def Export():
if not op: return
if op.GetType() != 5100:
print 'Selected Object is not an editable mesh'
return
unit = 0.001#for scale
fps = doc.GetFps()
bd = doc.GetRenderBaseDraw()
scr = bd.GetFrameScreen()
rd = doc.GetActiveRenderData()
name = op.GetName()
classname = clean(name)
c4dPath = c4d.storage.GeGetC4DPath(sy.C4D_PATH_LIBRARY)
jsFile = open(c4dPath+'/scripts/Three.js','r')
js = jsFile.read()
htmlFile = open(c4dPath+'/scripts/template.html','r')
html = htmlFile.read()
html = html.replace('%s',classname)
code = 'var %s = function() {\n\n\tvar scope = this;\n\n\tTHREE.Geometry.call(this);\n\n' % classname
def GetMesh(code):
# goto 0
doc.SetTime(c4d.BaseTime(0, fps))
c4d.DrawViews(c4d.DA_ONLY_ACTIVE_VIEW|c4d.DA_NO_THREAD|c4d.DA_NO_REDUCTION|c4d.DA_STATICBREAK)
c4d.GeSyncMessage(c4d.EVMSG_TIMECHANGED)
doc.SetTime(doc.GetTime())
c4d.EventAdd(c4d.EVENT_ANIMATE)
SendModelingCommand(command = MCOMMAND_REVERSENORMALS, list = [op], mode = MODIFY_ALL, bc = c4d.BaseContainer(), doc = doc)
verts = op.GetPointAll()
for v in verts:
code += '\tv(%.6f, %.6f, %.6f);\n' % (v.x, -v.y, v.z)
code += '\n'
ncount = 0
uvcount = 0
faces = op.GetAllPolygons()
normals = op.CreatePhongNormals()
ndirection = 1
hasUV = False
for tag in op.GetTags():
if tag.GetName() == "UVW":
uvw = tag
hasUV = True
for f in faces:
if(f.d == f.c):
if(normals):
code += '\tf3(%d, %d, %d, %.6f, %.6f, %.6f);\n' % (f.a, f.b, f.c, normals[ncount].x*ndirection, normals[ncount].y*ndirection, normals[ncount].z*ndirection)
else:
code += '\tf3(%d, %d, %d);\n' % (f.a, f.b, f.c)
else:
if(normals):
code += '\tf4(%d, %d, %d, %d, %.6f, %.6f, %.6f);\n' % (f.a, f.b, f.c, f.d, normals[ncount].x*ndirection, normals[ncount].y*ndirection, normals[ncount].z*ndirection)
else:
code += '\tf4(%d, %d, %d, %d);\n' % (f.a, f.b, f.c, f.d)
if hasUV:
uv = uvw.Get(uvcount);
# uvs += '[Vector('+str(uv[0].x)+','+str(1.0-uv[0].y)+'),Vector('+str(uv[1].x)+','+str(1.0-uv[1].y)+'),Vector('+str(uv[2].x)+','+str(1.0-uv[2].y)+')],'
if len(uv) == 4:
code += '\tuv(%.6f, %.6f, %.6f, %.6f, %.6f, %.6f, %.6f, %.6f);\n' % (uv[0].x, uv[0].y, uv[1].x, uv[1].y, uv[2].x, uv[2].y, uv[3].x, uv[3].y)
else:
code += '\tuv(%.6f, %.6f, %.6f, %.6f, %.6f, %.6f);\n' % (uv[0].x, uv[0].y, uv[1].x, uv[1].y, uv[2].x, uv[2].y)
ncount += 1
uvcount += 1
#selection color
code +='\n\tscope.colors = {};\n'
code +='\tscope.selections = {};\n'
selName = ''
for tag in op.GetTags():
if(tag.GetType() == 5616): #texture tag
material = tag.GetMaterial()
color = material[sy.MATERIAL_COLOR_COLOR]
tag.SetBit(c4d.BIT_ACTIVE)
selName = clean(tag[sy.TEXTURETAG_RESTRICTION])
if len(selName) == 0: print "*** WARNING! *** Missing selection name for material: " + material.GetName()
code += '\tscope.colors["'+selName+'"] = '+str(RGBToHTMLColor((color.x*255,color.y*255,color.z*255)))+';\n'
if tag.GetType() == 5673: #selection tag
# print 'selection: ' + tag.GetName()
sel = tag.GetSelection()
selName = clean(tag.GetName())
ids = sel.GetAll(op.GetPointCount())
indices = [i for i, e in enumerate(ids) if e != 0]
code += '\tscope.selections["'+selName+'"] = '+str(indices)+';\n'
code += '\n\tscope.autoColor = function(){\n'
code += '\t\tfor(var s in this.selections){\n'
code += '\t\t\tfor(var i = 0 ; i < this.selections[s].length; i++) this.faces[this.selections[s][i]].material = [ new THREE.MeshColorFillMaterial(this.colors[s],1) ];\n'
code += '\t\t}\n\t}\n'
# model position, rotation, scale rotation x,y,z = H,P,B => three.js x,y,z is P,H,B => y,x,z
p = op.GetPos()
r = op.GetRot()
s = op.GetScale()
code += '\n\tscope.getPosition = function(){\treturn new THREE.Vector3'+str((p.x,p.y,p.z))+';\t}\n'
code += '\n\tscope.getRotation = function(){\treturn new THREE.Vector3'+str((r.y,r.x,r.z))+';\t}\n'
code += '\n\tscope.getScale = function(){\treturn new THREE.Vector3'+str((s.x,s.y,s.z))+';\t}\n'
code += '\n'
code += '\tfunction v(x, y, z) {\n\n'
code += '\t\tscope.vertices.push(new THREE.Vertex(new THREE.Vector3(x, y, z)));\n\n'
code += '\t}\n\n'
code += '\tfunction f3(a, b, c, nx, ny, nz) {\n\n'
code += '\t\tscope.faces.push(new THREE.Face3(a, b, c, nx && ny && nz ? new THREE.Vector3(nx, ny, nz) : null));\n\n'
code += '\t}\n\n'
code += '\tfunction f4(a, b, c, d, nx, ny, nz) {\n\n'
code += '\t\tscope.faces.push(new THREE.Face4(a, b, c, d, nx && ny && nz ? new THREE.Vector3(nx, ny, nz) : null));\n\n'
code += '\t}\n\n'
code += '\tfunction uv(u1, v1, u2, v2, u3, v3, u4, v4) {\n\n'
code += '\t\tvar uv = [];\n'
code += '\t\tuv.push(new THREE.UV(u1, v1));\n'
code += '\t\tuv.push(new THREE.UV(u2, v2));\n'
code += '\t\tuv.push(new THREE.UV(u3, v3));\n'
code += '\t\tif (u4 && v4) uv.push(new THREE.UV(u4, v4));\n'
code += '\t\tscope.uvs.push(uv);\n'
code += '\t}\n\n'
code += '}\n\n'
code += '%s.prototype = new THREE.Geometry();\n' % classname
code += '%s.prototype.constructor = %s;' % (classname, classname)
SendModelingCommand(command = MCOMMAND_REVERSENORMALS, list = [op], mode = MODIFY_ALL, bc = c4d.BaseContainer(), doc = doc)
return code
code = GetMesh(code)
docPath = doc.GetDocumentPath()
jspath = docPath+'/'+classname+'.js'
htmlpath = docPath+'/'+classname+'.html'
file = open(jspath,'w')
file.write(code)
file.close()
file = open(htmlpath,'w')
file.write(html)
file.close()
file = open(docPath+'/Three.js','w')
file.write(js)
file.close()
print 'Export Complete!'
Export()
而且,增加了 '超薄' 出口到repository應該產生較小的.js文件 爲模型
2
Alirght,要試試這裏:
此插件不適用於C4D R12。由於Maxon吸收了Py4D,他們選擇將符號對象吸收到c4d對象中。我分出你的code並探索了一下,試圖解決11.5的Py4D和R12之間的微小差異。
無論如何,這裏是您提出的plugin cafe post,我對這些問題進行了更多評論。再次感謝您爲真棒鋪平道路!
+0
嗨,這是相當不錯的東西!不幸的是,自從冬天以後,我沒有時間更新我的代碼。 three.js移動得非常快。我會找一些時間來更新我的分支和出口商(因爲他們不再適合最新的three.js主要回購版)謝謝! – 2011-04-07 19:02:35
5
另一種選擇是導出爲COLLADA/DAE或OBJ並使用COLLADALoader或OBJLoader。
1
如果您收到對象屬性錯誤,則需要在three.js
導出器腳本(c4d13 +)中將GetPos
調用與GetAbsPos
進行交換。
相關問題
- 1. 如何將SketchUp模型導出到three.js?
- 2. 如何取出三維數組並將其轉換爲模型?
- 3. 導入三維模型opengl
- 4. 從cinema4d導出動畫到攪拌機
- 5. 將三維線框轉換爲三維實體模型
- 6. 如何紋理到從Blender導出到JSON模型到Three.js?
- 7. 如何將模型和相關紋理從Blender導入three.js?
- 8. 如何將sparkR模型導出爲PMML?
- 9. 我如何將我的攪拌機模型從mysql數據庫導出到three.js
- 10. 將模型導出爲PMML
- 11. 紋理三維模型使用three.js與<canvas>(不是WebGL)
- 12. 如何將導軌模型導出爲json模式?
- 13. 將動畫模型導入Three.JS
- 14. 將模型導入到three.js中 - 性能
- 15. 從3dStudioMax導入模型到THREE.js
- 16. 從Mathematica導出三維圖到MATLAB
- 17. 將三維模型導入Direct3D 11示例
- 18. 是否可以將三維模型導入pyglet?
- 19. 使用blender/threejs.org編輯器將.obj導出到THREE.js模型
- 20. 如何在運行時將three.js(JSON)模型導入Unity?
- 21. 將三維矩陣繪製爲三維條形圖時出錯
- 22. 如何紋理從攪拌器導出的動畫js模型? [Three.js]
- 23. three.js - 如何導出MultiMaterial?
- 24. 將three.js網格導出爲OBJ或STL
- 25. Three.js - 將紋理導出爲圖像
- 26. 如何從SAS模型導出公式
- 27. 將three.js模型轉換爲svg
- 28. 從Babylon.js或Three.js導出
- 29. STL導出器爲BufferGeometry THREE.js
- 30. 如何將三維數據模型轉換爲datamining友好佈局?
我可以爲Cinema 4D R13 +將3D模型導出爲Three.js嗎?我無法看到Py4D的這個版本。任何幫助?謝謝。 – vnpnlz 2013-04-04 08:28:44