forked from johnzero7/XNALaraMesh
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmock_xps_data.py
206 lines (170 loc) · 5.42 KB
/
mock_xps_data.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
from getpass import getuser
from socket import gethostname
from . import bin_ops
from . import xps_const
from . import xps_types
import bpy
def mockData():
xpsHeader = buildHeader()
bones = buildBones()
meshes = buildMeshes()
xpsData = xps_types.XpsData(xpsHeader, bones, meshes)
return xpsData
def fillPoseString(poseBytes):
poseLenghtUnround = len(poseBytes)
poseLenght = bin_ops.roundToMultiple(
poseLenghtUnround, xps_const.ROUND_MULTIPLE)
emptyFill = b'0' * (poseLenght - poseLenghtUnround)
return poseBytes + emptyFill
def getPoseStringLength(poseString):
return len(poseString)
def bonePoseCount(poseString):
boneList = poseString.split('\n')
return len(boneList) - 1
def buildHeader(poseString=''):
invertUserName = getuser()[::-1]
invertHostName = gethostname()[::-1]
header = xps_types.XpsHeader()
header.magic_number = xps_const.MAGIC_NUMBER
header.version_mayor = xps_const.XPS_VERSION_MAYOR
header.version_minor = xps_const.XPS_VERSION_MINOR
header.xna_aral = xps_const.XNA_ARAL
header.machine = invertHostName
header.user = invertUserName
header.files = f'{invertUserName}@{bpy.data.filepath}'
# header.settings = bytes([0])*
# (xps_const.SETTINGS_LEN * xps_const.ROUND_MULTIPLE)
boneCount = bonePoseCount(poseString)
poseBytes = poseString.encode(xps_const.ENCODING_WRITE)
default_pose = fillPoseString(poseBytes)
poseLengthUnround = getPoseStringLength(poseString)
var_1 = bin_ops.writeUInt32(180) # Hash
var_2 = bin_ops.writeUInt32(3) # Items
var_3 = bin_ops.writeUInt32(1) # Type
var_4 = bin_ops.writeUInt32(poseLengthUnround) # Pose Lenght Unround
var_5 = bin_ops.writeUInt32(boneCount) # Pose Bone Counts
# POSE DATA
var_6 = bin_ops.writeUInt32(2) # Type
var_7 = bin_ops.writeUInt32(4) # Count
var_8 = bin_ops.writeUInt32(4) # Info
var_9 = bin_ops.writeUInt32(2) # Count N1
var_10 = bin_ops.writeUInt32(1) # Count N2
var_11 = bin_ops.writeUInt32(3) # Count N3
var_12 = bin_ops.writeUInt32(0) # Count N4
var_13 = bin_ops.writeUInt32(4) # Type
var_14 = bin_ops.writeUInt32(3) # Count
var_15 = bin_ops.writeUInt32(5) # Info
var_16 = bin_ops.writeUInt32(4)
var_17 = bin_ops.writeUInt32(0)
var_18 = bin_ops.writeUInt32(256)
header_empty = b''
header_empty += var_6
header_empty += var_7
header_empty += var_8
header_empty += var_9
header_empty += var_10
header_empty += var_11
header_empty += var_12
header_empty += var_13
header_empty += var_14
header_empty += var_15
header_empty += var_16
header_empty += var_17
header_empty += var_18
header_unk = var_1 + var_2 + var_3
header_pose = var_4 + var_5 + default_pose
empty_count = ((xps_const.SETTINGS_LEN - len(header_empty)) // 4)
header_empty += bin_ops.writeUInt32(0) * empty_count
settings = header_unk + header_pose + header_empty
header.settingsLen = len(settings) // 4
header.settings = settings
# logHeader(header)
return header
def buildBones():
bones = []
id = 0
name = 'bone1'
co = [0, 0, 0]
parentId = -1
bone = xps_types.XpsBone(id, name, co, parentId)
bones.append(bone)
id = 1
name = 'bone2'
co = [0.5, 0.5, 0.5]
parentId = 0
bone = xps_types.XpsBone(id, name, co, parentId)
bones.append(bone)
return bones
def buildMeshes():
meshes = []
meshName = 'Mesh1'
uvLayerCount = 1
# Textures
textures = []
texId = 0
textureFile = 'textutefile1.png'
uvLayerId = 0
xpsTexture = xps_types.XpsTexture(texId, textureFile, uvLayerId)
textures.append(xpsTexture)
texId = 1
textureFile = 'textutefile2.png'
uvLayerId = 0
xpsTexture = xps_types.XpsTexture(texId, textureFile, uvLayerId)
textures.append(xpsTexture)
# Vertices
vertex = []
# Vertex1
vertexId = 0
coord = (1, 0, 0)
normal = (0, 0, 1)
vertexColor = (255, 255, 255, 0)
uvs = []
uvs.append((.2, .4))
boneWeights = (
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0))
xpsVertex = xps_types.XpsVertex(
vertexId, coord, normal, vertexColor, uvs, boneWeights)
# Vertex2
vertexId = 1
coord = (0, 1, 0)
normal = (0, 1, 0)
vertexColor = (255, 255, 255, 0)
uvs = []
uvs.append((.3, .5))
boneWeights = (
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0))
xpsVertex = xps_types.XpsVertex(
vertexId, coord, normal, vertexColor, uvs, boneWeights)
vertex.append(xpsVertex)
# Vertex3
vertexId = 2
coord = (0, 0, 1)
normal = (1, 0, 0)
vertexColor = (255, 255, 255, 0)
uvs = []
uvs.append((.3, .9))
boneWeights = (
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0),
xps_types.BoneWeight(0, 0))
xpsVertex = xps_types.XpsVertex(
vertexId, coord, normal, vertexColor, uvs, boneWeights)
vertex.append(xpsVertex)
faces = []
face = (0, 1, 2)
faces.append(face)
xpsMesh = xps_types.XpsMesh(
meshName, textures, vertex, faces, uvLayerCount)
meshes.append(xpsMesh)
return meshes
if __name__ == "__main__":
print('BUILD')
xx = mockData()
print('FINISH')