|
|
@ -1,4 +1,5 @@ |
|
|
|
print("How to use: paste into a Blender Text Editor panel, select object, Run Script") |
|
|
|
print("How to use: paste into a Blender Text Editor panel, select" |
|
|
|
" object, Run Script") |
|
|
|
|
|
|
|
y_up = True |
|
|
|
enable_minetest = False |
|
|
@ -32,7 +33,8 @@ class MessageBox(bpy.types.Operator): |
|
|
|
return {'FINISHED'} |
|
|
|
|
|
|
|
def invoke(self, context, event): |
|
|
|
return context.window_manager.invoke_props_dialog(self, width = 400) |
|
|
|
return context.window_manager.invoke_props_dialog(self, |
|
|
|
width=400) |
|
|
|
|
|
|
|
def draw(self, context): |
|
|
|
self.layout.label(self.message) |
|
|
@ -56,32 +58,24 @@ if (mesh is not None) and (not hasattr(mesh, 'vertices')): |
|
|
|
msg = "Collision box for armatures cannot be calculated." |
|
|
|
bpy.ops.message.messagebox('INVOKE_DEFAULT', message = msg) |
|
|
|
else: |
|
|
|
#print(str(thisO)) |
|
|
|
# extents1 = ob1.dimensions.copy() |
|
|
|
#if (extents1.x == 0.0) and (extents1.y == 0.0) and (extents1.z == 0.0) and (ob1.scale.x > 0.0): |
|
|
|
#extents1.x = extents1.x / 10.0 |
|
|
|
#extents1.y = extents1.y / 10.0 |
|
|
|
#extents1.z = extents1.z / 10.0 |
|
|
|
obj1Loc = ob1.location |
|
|
|
#obj1Loc = ob1.matrix_world.translation |
|
|
|
#print(str(extents1)) |
|
|
|
|
|
|
|
#see https://blender.stackexchange.com/questions/8459/get-blender-x-y-z-and-bounding-box-with-script |
|
|
|
# See https://blender.stackexchange.com/questions/8459/get-blender-x-y-z-and-bounding-box-with-script |
|
|
|
# bbox_corners = [ob1.matrix_world * Vector(corner) for corner in ob1.bound_box] |
|
|
|
|
|
|
|
|
|
|
|
#use ground as bottom |
|
|
|
# use ground as bottom (don't do this--it is not the Minetest way) |
|
|
|
# if zMin < 0.0: |
|
|
|
# yMax -= yMin |
|
|
|
# yMin = 0.0 |
|
|
|
|
|
|
|
#print( |
|
|
|
# " collisionbox = {{{:.2f}, {:.2f}, {:.2f}, {:.2f}, {:.2f}, {:.2f}}}".format(xMin, yMin, zMin, xMax, yMax, zMax) |
|
|
|
#) |
|
|
|
print(" collisionbox = {{{:.2f}, {:.2f}, {:.2f}, {:.2f}, {:.2f}," |
|
|
|
" {:.2f}}}".format(xMin, yMin, zMin, xMax, yMax, zMax)) |
|
|
|
|
|
|
|
#see https://blender.stackexchange.com/questions/6139/how-to-iterate-through-all-vertices-of-an-object-that-contains-multiple-meshes |
|
|
|
# See https://blender.stackexchange.com/questions/6139/how-to-iterate-through-all-vertices-of-an-object-that-contains-multiple-meshes |
|
|
|
# print("mesh:" + str(mesh)) |
|
|
|
#print("hasattr(mesh, 'vertices'):" + str(hasattr(mesh, 'vertices')))] |
|
|
|
# print("hasattr(mesh, 'vertices'):" |
|
|
|
# + str(hasattr(mesh, 'vertices')))] |
|
|
|
xMin = None |
|
|
|
if mesh is not None: |
|
|
|
xMin = None |
|
|
@ -112,20 +106,13 @@ else: |
|
|
|
zMax = loc.z |
|
|
|
# print(str(extents1)) |
|
|
|
# print("--by vertices (raw):") |
|
|
|
# print( |
|
|
|
# " collisionbox = {{{:.2f}, {:.2f}, {:.2f}, {:.2f}, {:.2f}, {:.2f}}}".format(xMin, yMin, zMin, xMax, yMax, zMax) |
|
|
|
#) |
|
|
|
|
|
|
|
# use ob1.matrix_world instead of incrementing location. |
|
|
|
# xMax += ob1.location.x |
|
|
|
# xMin += ob1.location.x |
|
|
|
# yMax += ob1.location.y |
|
|
|
# yMin += ob1.location.y |
|
|
|
# zMax += ob1.location.z |
|
|
|
# zMin += ob1.location.z |
|
|
|
print(" collisionbox = {{{:.2f}, {:.2f}, {:.2f}, {:.2f}," |
|
|
|
" {:.2f}, {:.2f}}}".format(xMin, yMin, zMin, xMax, yMax, |
|
|
|
zMax)) |
|
|
|
|
|
|
|
# Use ob1.matrix_world (above) instead of incrementing |
|
|
|
# ob1.location.x, y, and z |
|
|
|
|
|
|
|
# print("--by vertices:") |
|
|
|
newNamePrefix = "Empty.EDGE." + ob1.name |
|
|
|
i = 0 |
|
|
|
wm = ob1.matrix_world |
|
|
@ -135,17 +122,21 @@ else: |
|
|
|
loc = mat @ vert.co # NOT transitive |
|
|
|
except TypeError: |
|
|
|
loc = mat * vert.co # Blender <2.8 |
|
|
|
isFar = True |
|
|
|
isFar = False |
|
|
|
if loc.x == xMax or loc.y == yMax or loc.z == zMax: |
|
|
|
isFar = True |
|
|
|
elif loc.x == xMin or loc.y == yMin or loc.z == zMin: |
|
|
|
isFar = True |
|
|
|
if isFar: |
|
|
|
# result = bpy.ops.object.add(type = 'EMPTY', radius = .25, location = loc); |
|
|
|
pass |
|
|
|
# result = bpy.ops.object.add(type='EMPTY', radius=.25, |
|
|
|
# location=loc); |
|
|
|
# NOTE: result is merely {'FINISHED'} |
|
|
|
# print("{:.2f}, {:.2f}, {:.2f}".format(loc.x, loc.y, loc.z)) |
|
|
|
# print("{:.2f}, {:.2f}, {:.2f}".format(loc.x, loc.y, |
|
|
|
# loc.z)) |
|
|
|
|
|
|
|
# bpy.ops.object.add_named(name = newName, type = 'EMPTY', radius = .25, location = loc) |
|
|
|
bpy.ops.object.add_named(name=newName, type='EMPTY', |
|
|
|
radius=.25, location=loc) |
|
|
|
i += 1 |
|
|
|
else: |
|
|
|
extents1 = ob1.scale.copy() |
|
|
@ -170,7 +161,8 @@ else: |
|
|
|
zMin /= 10.0 |
|
|
|
zMax /= 10.0 |
|
|
|
|
|
|
|
msg = 'Size is not available. Make sure you have a mesh object selected.' |
|
|
|
msg = ('Size is not available. Make sure you have a mesh object' |
|
|
|
' selected.') |
|
|
|
|
|
|
|
if xMin is not None: |
|
|
|
if y_up: |
|
|
@ -180,10 +172,12 @@ else: |
|
|
|
tmp = yMax |
|
|
|
yMax = zMax |
|
|
|
zMax = tmp |
|
|
|
msg = " collisionbox = {{{:.2f}, {:.2f}, {:.2f}, {:.2f}, {:.2f}, {:.2f}}}".format(xMin, yMin, zMin, xMax, yMax, zMax) |
|
|
|
msg = (" collisionbox = {{{:.2f}, {:.2f}, {:.2f}, {:.2f}," |
|
|
|
" {:.2f}, {:.2f}}}".format(xMin, yMin, zMin, xMax, yMax, |
|
|
|
zMax)) |
|
|
|
msg += msgSuffix |
|
|
|
if enable_minetest: |
|
|
|
msg += " #*10" |
|
|
|
# if enable_minetest: |
|
|
|
# msg += " -- *10" |
|
|
|
print(msg) |
|
|
|
|
|
|
|
bpy.ops.message.messagebox('INVOKE_DEFAULT', message=msg) |
|
|
|