This is a very basic example of importing mesh geometry data from an external text file created in the Output Geometry Data – Part One tutorial. The file contains only vertex and face lists.
Related Topics:
Editable_Mesh : GeometryClass and TriMesh : Value
NATURAL LANGUAGE
Create two empty arrays to hold the vertex and face lists.
Define an input file name.
Open the file for reading.
In the file exists, read the vertex and face number values from the file.
Step through all vertex values and read them into a variable, then append the value of the variable to the vertex array.
Step through all face values and read them into a variable, then append the value of the variable to the vertex array.
Close the file.
Create a new mesh using the vertex and face arrays.
MAXSCRIPT
vert_array = #() face_array = #() in_name = ((GetDir #export)+"/testmesh.dat") in_file = openFile in_name if in_file != undefined then ( num_verts = readValue in_file num_faces = readValue in_file vert_array.count = num_verts face_array.count = num_faces for v = 1 to num_verts do ( vert = readValue in_file vert_array[v] = vert ) for f = 1 to num_faces do ( face = readValue in_file face_array[f] = face ) close in_file new_mesh = mesh vertices:vert_array faces:face_array )
vert_array = #() face_array = #()
In the beginning, we define two empty arrays to collect the vertex and face data into.
in_name = ((GetDir #export)+"/testmesh.dat")
Then we define the imput file name just like in the Output Geometry – Part One tutorial. This is currently a hard-coded name in both the output and input script. We will let the user pick a file from an open file dialog in Part Two of this tutorial.
in_file = openFile in_name
Using the file name, we try to open the file for input. If the specified path exists, a fileStream value will be stored in the in_file variable. If the path does not exist, the value undefined will be stored instead.
if in_file != undefined then (
Knowing the above, we check to see if the file is valid or not. If the value isn’t undefined, the file has been opened successfully. If not, all of the next lines enclosed in the brackets will be ignored.
num_verts = readValue in_file
The file will contain the number of vertices and faces separated by a comma in the first line. Using the readValue method, we read the first value from the file. The value will be stored in the num_verts variable.
num_faces = readValue in_file
Using the same readValue method, we read the next value from the file. The value will be stored in the num_faces variable.
vert_array.count = num_verts face_array.count = num_faces
Now that we know the number of vertices and faces stored in the file, we initialize both arrays to those numbers. This will reserve enough memory for both arrays.
for v = 1 to num_verts do (
Then we can read the vertex positions. We start a new loop that will change the variable v from 1 to the number of vertices stored in the file.
vert = readValue in_file
Using the readValue method, we read Point3 values from the file. We store them in a user variable vert...
vert_array[v] = vert
...and then assign the value to the v-th position of the vert_array array.
)
At this point, we have all vertex positions read and put into the array.
for f = 1 to num_faces do (
Using the num_faces variable, we can also read as many face definitions. We start another loop that will change the variable f from 1 to the number of faces stored in the file.
face = readValue in_file
Using the readValue method, we read Point3 values from the file specifying the vertex indices defining the face. We store them in a user variable face...
face_array[f] = face
...and then assign the value to the f-th position of the face_array array.
)
At this point, we have all face definitions read and put into the array.
close in_file
We can close the file...
new_mesh = mesh vertices:vert_array faces:face_array
...and finally construct a new mesh by providing the vertex and face arrays collected from the file.
Editable_Mesh : GeometryClass and TriMesh : Value
)
To test the script, use the Output script first to create a file. Then open this script, select Tools > Evaluate from the Scripting Editor’s menu or alternatively, press Ctrl+E. The object exported to the file by the other script should appear in the scene. Note that it will have to correct position, but its pivot point will be at the world origin as we did not export local coordinates and object transformations.
As already mentioned, this is the basic code for geometry input. Still it can be made even more compact. Below is a shorter version of the same code. Please compare the two scripts and see why both of them do the same thing although expressed slightly differently.
MAXSCRIPT
vert_array = #() face_array = #() in_file = openFile ((GetDir #export)+"/testmesh.dat") if in_file != undefined then ( num_verts = readValue in_file num_faces = readValue in_file vert_array.count = num_verts face_array.count = num_faces for v = 1 to num_verts do vert_array[v] = (readValue in_file) for f = 1 to num_faces do face_array[f] = (readValue in_file) close in_file new_mesh = mesh vertices:vert_array faces:face_array )
In Part Two of the Geometry Input tutorial, we will make the code more robust and add some more features to reflect the changes made to the Geometry Output Part Two tutorial.
Back to
How To ... Output Geometry Data To Text File - Part One
Next