Additional BlenderConnection World capabilities

This commit is contained in:
Jack Andersen 2016-10-07 17:40:08 -10:00
parent d307e645b1
commit 7f5ba744da
8 changed files with 85 additions and 27 deletions

View File

@ -204,12 +204,7 @@ def write_action_aabb(writebuf, arm_obj, mesh_obj):
root_aabb_min[0], root_aabb_min[1], root_aabb_min[2], root_aabb_min[0], root_aabb_min[1], root_aabb_min[2],
root_aabb_max[0], root_aabb_max[1], root_aabb_max[2])) root_aabb_max[0], root_aabb_max[1], root_aabb_max[2]))
# Cook def _out_armatures(sact_data, writebuf):
def cook(writebuf):
bpy.context.scene.hecl_auto_remap = False
sact_data = bpy.context.scene.hecl_sact_data
# Output armatures
writebuf(struct.pack('I', len(bpy.data.armatures))) writebuf(struct.pack('I', len(bpy.data.armatures)))
for arm in bpy.data.armatures: for arm in bpy.data.armatures:
writebuf(struct.pack('I', len(arm.name))) writebuf(struct.pack('I', len(arm.name)))
@ -231,7 +226,7 @@ def cook(writebuf):
for child in bone.children: for child in bone.children:
writebuf(struct.pack('i', arm.bones.find(child.name))) writebuf(struct.pack('i', arm.bones.find(child.name)))
# Output subtypes def _out_subtypes(sact_data, writebuf):
writebuf(struct.pack('I', len(sact_data.subtypes))) writebuf(struct.pack('I', len(sact_data.subtypes)))
for subtype in sact_data.subtypes: for subtype in sact_data.subtypes:
writebuf(struct.pack('I', len(subtype.name))) writebuf(struct.pack('I', len(subtype.name)))
@ -273,8 +268,7 @@ def cook(writebuf):
else: else:
writebuf(struct.pack('I', 0)) writebuf(struct.pack('I', 0))
def _out_actions(sact_data, writebuf):
# Output actions
writebuf(struct.pack('I', len(sact_data.actions))) writebuf(struct.pack('I', len(sact_data.actions)))
for action_idx in range(len(sact_data.actions)): for action_idx in range(len(sact_data.actions)):
sact_data.active_action = action_idx sact_data.active_action = action_idx
@ -306,6 +300,33 @@ def cook(writebuf):
mesh = bpy.data.objects[subtype.linked_mesh] mesh = bpy.data.objects[subtype.linked_mesh]
write_action_aabb(writebuf, arm, mesh) write_action_aabb(writebuf, arm, mesh)
# Cook
def cook(writebuf):
bpy.context.scene.hecl_auto_remap = False
sact_data = bpy.context.scene.hecl_sact_data
# Output armatures
_out_armatures(sact_data, writebuf)
# Output subtypes
_out_subtypes(sact_data, writebuf)
# Output actions
_out_actions(sact_data, writebuf)
# Cook Character Data only
def cook_character_only(writebuf):
sact_data = bpy.context.scene.hecl_sact_data
# Output armatures
_out_armatures(sact_data, writebuf)
# Output subtypes
_out_subtypes(sact_data, writebuf)
# Output no actions
writebuf(struct.pack('I', 0))
# Access actor's contained armature names # Access actor's contained armature names
def get_armature_names(writebuf): def get_armature_names(writebuf):
writebuf(struct.pack('I', len(bpy.data.armatures))) writebuf(struct.pack('I', len(bpy.data.armatures)))

View File

@ -5,7 +5,7 @@ def build_dock_connections():
areas = [] areas = []
docks = [] docks = []
for obj in bpy.context.scene.objects: for obj in sorted(bpy.context.scene.objects, key=lambda x: x.name):
if obj.type == 'MESH' and obj.parent is None: if obj.type == 'MESH' and obj.parent is None:
dock_list = [] dock_list = []
for ch in obj.children: for ch in obj.children:
@ -29,8 +29,8 @@ def build_dock_connections():
dock_dict[dockA[2].name] = dockB dock_dict[dockA[2].name] = dockB
match = True match = True
break break
if not match: #if not match:
raise RuntimeError('No dock match for %s' % dockA[2].name) # raise RuntimeError('No dock match for %s' % dockA[2].name)
return (areas, dock_dict) return (areas, dock_dict)
@ -66,10 +66,13 @@ def cook(writebuf):
for vi in range(4): for vi in range(4):
v = wmtx * ch.data.vertices[vi].co v = wmtx * ch.data.vertices[vi].co
writebuf(struct.pack('fff', v[0], v[1], v[2])) writebuf(struct.pack('fff', v[0], v[1], v[2]))
if ch.name in dock_conns:
conn_dock = dock_conns[ch.name] conn_dock = dock_conns[ch.name]
writebuf(struct.pack('I', conn_dock[0])) writebuf(struct.pack('I', conn_dock[0]))
writebuf(struct.pack('I', conn_dock[1])) writebuf(struct.pack('I', conn_dock[1]))
else:
writebuf(struct.pack('I', 0xffffffff))
writebuf(struct.pack('I', 0xffffffff))
# Panel draw # Panel draw
def draw(layout, context): def draw(layout, context):

View File

@ -310,6 +310,10 @@ def dataout_loop():
writepipeline(b'OK') writepipeline(b'OK')
hecl.sact.cook(writepipebuf) hecl.sact.cook(writepipebuf)
elif cmdargs[0] == 'ACTORCOMPILECHARACTERONLY':
writepipeline(b'OK')
hecl.sact.cook_character_only(writepipebuf)
elif cmdargs[0] == 'GETARMATURENAMES': elif cmdargs[0] == 'GETARMATURENAMES':
writepipeline(b'OK') writepipeline(b'OK')
hecl.sact.get_armature_names(writepipebuf) hecl.sact.get_armature_names(writepipebuf)

2
hecl/extern/athena vendored

@ -1 +1 @@
Subproject commit b3ca9a0a9023580db5dff68158606a64841b7f4e Subproject commit a5a3244e1aee88f683f95bc1ffc226759acf9ca1

View File

@ -750,6 +750,7 @@ public:
}; };
Actor compileActor(); Actor compileActor();
Actor compileActorCharacterOnly();
std::vector<std::string> getArmatureNames(); std::vector<std::string> getArmatureNames();
std::vector<std::string> getSubtypeNames(); std::vector<std::string> getSubtypeNames();
std::vector<std::string> getActionNames(); std::vector<std::string> getActionNames();

View File

@ -110,7 +110,7 @@ public:
{(void)path;LogModule.report(logvisor::Error, "not implemented");return false;} {(void)path;LogModule.report(logvisor::Error, "not implemented");return false;}
virtual const DataSpecEntry* overrideDataSpec(const ProjectPath& path, virtual const DataSpecEntry* overrideDataSpec(const ProjectPath& path,
const Database::DataSpecEntry* oldEntry, const Database::DataSpecEntry* oldEntry,
BlenderToken& btok) BlenderToken& btok) const
{(void)path;return oldEntry;} {(void)path;return oldEntry;}
virtual void doCook(const ProjectPath& path, const ProjectPath& cookedPath, virtual void doCook(const ProjectPath& path, const ProjectPath& cookedPath,
bool fast, BlenderToken& btok, FCookProgress progress) bool fast, BlenderToken& btok, FCookProgress progress)
@ -454,19 +454,13 @@ public:
PackageDepsgraph buildPackageDepsgraph(const ProjectPath& path); PackageDepsgraph buildPackageDepsgraph(const ProjectPath& path);
/** Add ProjectPath to bridge cache */ /** Add ProjectPath to bridge cache */
void addBridgePathToCache(uint64_t id, const ProjectPath& path) { m_bridgePathCache[id] = path; } void addBridgePathToCache(uint64_t id, const ProjectPath& path);
/** Clear all ProjectPaths in bridge cache */ /** Clear all ProjectPaths in bridge cache */
void clearBridgePathCache() { m_bridgePathCache.clear(); } void clearBridgePathCache();
/** Lookup ProjectPath from bridge cache */ /** Lookup ProjectPath from bridge cache */
const ProjectPath* lookupBridgePath(uint64_t id) const const ProjectPath* lookupBridgePath(uint64_t id) const;
{
auto search = m_bridgePathCache.find(id);
if (search == m_bridgePathCache.cend())
return nullptr;
return &search->second;
}
}; };

View File

@ -1377,6 +1377,23 @@ BlenderConnection::DataStream::Actor BlenderConnection::DataStream::compileActor
return Actor(*m_parent); return Actor(*m_parent);
} }
BlenderConnection::DataStream::Actor
BlenderConnection::DataStream::compileActorCharacterOnly()
{
if (m_parent->m_loadedType != BlendType::Actor)
BlenderLog.report(logvisor::Fatal, _S("%s is not an ACTOR blend"),
m_parent->m_loadedBlend.getAbsolutePath().c_str());
m_parent->_writeLine("ACTORCOMPILECHARACTERONLY");
char readBuf[256];
m_parent->_readLine(readBuf, 256);
if (strcmp(readBuf, "OK"))
BlenderLog.report(logvisor::Fatal, "unable to compile actor: %s", readBuf);
return Actor(*m_parent);
}
BlenderConnection::DataStream::World BlenderConnection::DataStream::World
BlenderConnection::DataStream::compileWorld() BlenderConnection::DataStream::compileWorld()
{ {

View File

@ -543,5 +543,23 @@ PackageDepsgraph Project::buildPackageDepsgraph(const ProjectPath& path)
return PackageDepsgraph(); return PackageDepsgraph();
} }
void Project::addBridgePathToCache(uint64_t id, const ProjectPath& path)
{
m_bridgePathCache[id] = path;
}
void Project::clearBridgePathCache()
{
m_bridgePathCache.clear();
}
const ProjectPath* Project::lookupBridgePath(uint64_t id) const
{
auto search = m_bridgePathCache.find(id);
if (search == m_bridgePathCache.cend())
return nullptr;
return &search->second;
}
} }
} }