指定 3D 文件保存选项
Contents
[
Hide
]
3D 文件保存选项
有几个场景。保存方法重载接受一个SaveOptions实例这应该是从SaveOptions类派生的类的实例。每种保存格式都有一个相应的类,该类保存该保存格式的保存选项,例如,FileFormat.COLLADA保存格式有ColladaSaveOptions。
使用 Collada 保存选项
下面的代码显示了如何在将 3D 文件保存为 Collada 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
ColladaSaveOptions saveColladaopts = new ColladaSaveOptions(); | |
// Generates indented XML document | |
saveColladaopts.setIndented(true); | |
// The style of node transformation | |
saveColladaopts.setTransformStyle(ColladaTransformStyle.MATRIX); | |
// Configure the lookup paths to allow importer to find external dependencies. | |
saveColladaopts.getLookupPaths().add(MyDir); |
使用 Discreet3DS 保存选项
下面的代码显示了如何在将 3D 文件保存为谨慎的 3DS 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize an object | |
Discreet3DSSaveOptions saveOpts = new Discreet3DSSaveOptions(); | |
// The start base for generating new name for duplicated names. | |
saveOpts.setDuplicatedNameCounterBase(2); | |
// The format of the duplicated counter. | |
saveOpts.setDuplicatedNameCounterFormat("NameFormat"); | |
// The separator between object's name and the duplicated counter. | |
saveOpts.setDuplicatedNameSeparator("Separator"); | |
// Allows to export cameras | |
saveOpts.setExportCamera(true); | |
// Allows to export light | |
saveOpts.setExportLight(true); | |
// Flip the coordinate system | |
saveOpts.setFlipCoordinateSystem(true); | |
// Prefer to use gamma-corrected color if a 3ds file provides both original color and gamma-corrected color. | |
saveOpts.setGammaCorrectedColor(true); | |
// Use high-precise color which each color channel will use 32bit float. | |
saveOpts.setHighPreciseColor(true); | |
// Configure the look up paths to allow importer to find external dependencies. | |
saveOpts.getLookupPaths().add(MyDir); | |
// Set the master scale | |
saveOpts.setMasterScale(1); |
使用 FBX 保存选项
下面的代码显示了如何在将 3D 文件保存为 FBX 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize an object | |
FBXSaveOptions saveOpts = new FBXSaveOptions(FileFormat.ASE); | |
// Generates the legacy material properties. | |
saveOpts.setExportLegacyMaterialProperties(true); | |
// Fold repeated curve data using FBX's animation reference count | |
saveOpts.setFoldRepeatedCurveData(true); | |
// Always generates material mapping information for geometries if the attached node contains materials. | |
saveOpts.setGenerateVertexElementMaterial(true); | |
// Configure the look up paths to allow importer to find external dependencies. | |
saveOpts.getLookupPaths().add(MyDir); | |
// Generates a video object for texture. | |
saveOpts.setVideoForTexture(true); |
使用 OBJ 保存选项
下面的代码显示了如何在将 3D 文件保存为Obj格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize an object | |
ObjSaveOptions saveObjOpts = new ObjSaveOptions(); | |
// Import materials from external material library file | |
saveObjOpts.setEnableMaterials(true); | |
// Flip the coordinate system. | |
saveObjOpts.setFlipCoordinateSystem(true); | |
// Configure the look up paths to allow importer to find external dependencies. | |
saveObjOpts.getLookupPaths().add(MyDir); | |
// Serialize W component in model's vertex position | |
saveObjOpts.setSerializeW(true); | |
// Generate comments for each section | |
saveObjOpts.setVerbose(true); |
使用 STL 保存选项
下面的代码显示了如何在将 3D 文件保存为 STL 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize an object | |
STLSaveOptions saveSTLOpts = new STLSaveOptions(); | |
// Flip the coordinate system. | |
saveSTLOpts.setFlipCoordinateSystem(true); | |
// Configure the look up paths to allow importer to find external dependencies. | |
saveSTLOpts.getLookupPaths().add(MyDir); |
使用 U3D 保存选项
下面的代码显示了如何在将文档保存为 U3D 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize an object | |
U3DSaveOptions saveU3DOptions = new U3DSaveOptions(); | |
// Export normal data. | |
saveU3DOptions.setExportNormals(true); | |
// Export the texture coordinates. | |
saveU3DOptions.setExportTextureCoordinates(true); | |
// Export the vertex diffuse color. | |
saveU3DOptions.setExportVertexDiffuse(true); | |
// Export vertex specular color | |
saveU3DOptions.setExportVertexSpecular(true); | |
// Flip the coordinate system. | |
saveU3DOptions.setFlipCoordinateSystem(true); | |
// Configure the look up paths to allow importer to find external dependencies. | |
saveU3DOptions.getLookupPaths().add(MyDir); | |
// Compress the mesh data | |
saveU3DOptions.setMeshCompression(true); |
使用 glTF 保存选项
19.8或更高版本支持此功能。
下面的代码显示了如何在将文档保存为 glTF 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize Scene object | |
Scene scene = new Scene(); | |
// Create a child node | |
scene.getRootNode().createChildNode("sphere", new Sphere()); | |
// Set glTF saving options. The code example embeds all assets into the target file usually a glTF file comes with some dependencies, a bin file for model's vertex/indices, two .glsl files for vertex/fragment shaders | |
// Use opt.EmbedAssets to tells the Aspose.3D API to export scene and embed the dependencies inside the target file. | |
GLTFSaveOptions opt = new GLTFSaveOptions(FileContentType.ASCII); | |
opt.setEmbedAssets(true); | |
// Use KHR_materials_common extension to define the material, thus no GLSL files are generated. | |
opt.setUseCommonMaterials(true); | |
// Customize the name of the buffer file which defines model | |
opt.setBufferFile("mybuf.bin"); | |
// Save glTF file | |
scene.save(MyDir + "glTFSaveOptions_out.gltf", opt); | |
// Save a binary glTF file using KHR_binary_glTF extension | |
scene.save(MyDir + "glTFSaveOptions_out.glb", FileFormat.GLTF__BINARY); | |
// Developers may use saving options to create a binary glTF file using KHR_binary_glTF extension | |
GLTFSaveOptions opts = new GLTFSaveOptions(FileContentType.BINARY); | |
scene.save(MyDir + "Test_out.glb", opts); |
glTF 保存选项中的PrettyPrint
您还可以使用GLTFSaveOptions类的setPrettyPrint方法进行人类可理解的JSON打印。下面的代码显示了如何使用此功能。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// For complete examples and data files, please go to https://github.com/aspose-3d/Aspose.3D-for-Java | |
// Initialize 3D scene | |
Scene scene = new Scene(new Sphere()); | |
// Initialize GLTFSaveOptions | |
GLTFSaveOptions opt = new GLTFSaveOptions(FileFormat.GLTF2); | |
// opt.prettyPrint = true; //Old code | |
// The JSON content of GLTF file is indented for human reading, default value is false | |
// Use setter to change this configuration. | |
opt.setPrettyPrint(true); | |
// Save 3D Scene | |
scene.save(RunExamples.getDataDir() + "prettyPrintInGltfSaveOption.gltf", opt); |
在真实文件系统中保存 3D 场景的依赖项
开发人员可能需要将 3D scene的所有依赖项保存在真实文件系统中。它们可以定义本地目录的路径,保存在 MemoryFileSystem
对象中或简单地丢弃依赖项。在all save选项类中添加了FileSystem属性。
放弃保存材料文件
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The code example uses the DummyFileSystem, so the material files are not created. | |
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize Scene object | |
Scene scene = new Scene(); | |
// Create a child node | |
scene.getRootNode().createChildNode("sphere", new Sphere()).setMaterial(new PhongMaterial()); | |
// Set saving options | |
ObjSaveOptions opt = new ObjSaveOptions(); | |
opt.setFileSystem(new DummyFileSystem()); | |
// Save 3D scene | |
scene.save(MyDir + "DiscardSavingMaterial_out.obj", opt); |
在本地目录中保存依赖项
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The code example uses the LocalFileSystem class to save dependencies to the local directory. | |
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize Scene object | |
Scene scene = new Scene(); | |
// Create a child node | |
scene.getRootNode().createChildNode("sphere", new Sphere()).setMaterial(new PhongMaterial()); | |
// Set saving options | |
ObjSaveOptions opt = new ObjSaveOptions(); | |
opt.setFileSystem(new LocalFileSystem(MyDir)); | |
// Save 3D scene | |
scene.save(MyDir + "SavingDependenciesInLocalDirectory_out.obj", opt); |
在MemoryFileSystem实例中保存依赖项
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The code example uses the MemoryFileSystem to intercepts the dependencies writing. | |
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize Scene object | |
Scene scene = new Scene(); | |
// Create a child node | |
scene.getRootNode().createChildNode("sphere", new Sphere()).setMaterial(new PhongMaterial()); | |
// Set saving options | |
ObjSaveOptions opt = new ObjSaveOptions(); | |
MemoryFileSystem mfs = new MemoryFileSystem(); | |
opt.setFileSystem(mfs); | |
// Save 3D scene | |
scene.save(MyDir + "SavingDependenciesInMemoryFileSystem_out.obj", opt); | |
// Get the test.mtl file content | |
byte[] mtl = mfs.getFileContent(MyDir + "SavingDependenciesInMemoryFileSystem_out.mtl"); | |
Files.write(Paths.get(MyDir, "Material.mtl"), mtl); |
使用 Google Draco (.DRC) 保存选项
下面的代码显示了如何在将 3D 模型保存为 DRC 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// The path to the documents directory. | |
String MyDir = RunExamples.getDataDir(); | |
// Initialize Scene object | |
Scene scene = new Scene(); | |
// Create a child node | |
scene.getRootNode().createChildNode("sphere", new Sphere()); | |
// Initialize .DRC saving options. | |
DracoSaveOptions opts = new DracoSaveOptions(); | |
// Quantization bits for position | |
opts.setPositionBits(14); | |
// Quantization bits for texture coordinate | |
opts.setTextureCoordinateBits(8); | |
// Quantization bits for vertex color | |
opts.setColorBits(10); | |
// Quantization bits for normal vectors | |
opts.setNormalBits(7); | |
// Set compression level | |
opts.setCompressionLevel(DracoCompressionLevel.OPTIMAL); | |
// Save Google Draco (.drc) file | |
scene.save(MyDir + "DRCSaveOptions_out.drc", opts); |
使用 RVM 保存选项
下面的代码显示了如何在将 3D 模型保存为 RVM 格式之前设置保存选项。
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// For complete examples and data files, please go to https://github.com/aspose-3d/Aspose.3D-for-Java | |
String dataDir = RunExamples.getDataDir(); | |
Scene scene = new Scene(); | |
Node node = scene.getRootNode().createChildNode("Box", new Box()); | |
node.setProperty("rvm:Refno", "=3462123"); | |
node.setProperty("rvm:Description", "This is the description of the box"); | |
//The RVM attribute's prefix is rvm:, all properties that starts with rvm: will be exported to .att file(the prefix will be removed) | |
RvmSaveOptions opt = new RvmSaveOptions(); | |
opt.setAttributePrefix( "rvm:"); | |
opt.setExportAttributes(true); | |
scene.save(dataDir + "test.rvm", opt); |