Blender Python编程实现批量导入网格并保存渲染图像
作者:ShaderJoy 发布时间:2021-06-09 04:21:20
引言
继上一篇 《Blender Python 编程:快速入门》 我们已经了解了 Blender Python 脚本的基本概念。接下来让我们了解如何用 Python 编程实现一些 有意思的功能(减轻部分工作量)。
Blender 并不是唯一一款允许你为场景编程和自动化任务的3D软件; 随着每一个新版本的推出,Blender 正逐渐成为一个可靠的 CG 制作一体化解决方案,从使用油脂铅笔的故事板到基于节点的合成。
事实上,你可以使用 Python 脚本和一些额外的包来批处理你的对象实例化,程序化地生成东西,配置你的渲染设置,甚至获得你当前项目的自定义统计数据,这是非常棒的功能! 这是一种减轻繁琐任务负担的方式,同时也能让开发者参与到这个创造性工具社区中,而不仅仅是美术人员。
打开 Blender 中的文本编辑器,让我们开始编码。这个过程的主要步骤包括
导入所有必需的库
删除默认的立方体对象和相机
编写几个
for
循环来导入多个 “猴头” 网格创建相机
最后保存渲染的图像
导入库
为了实现我们的项目,我们将进口三种主要必需品。首先,我们将导入 bpy 库,它将允许用户在 Blender 文本编辑器中访问 Python 环境。我们将从这个库中导入一些功能,以方便访问。最后,我们还将导入用于执行不同类型计算的 math 库。在这个特殊的场景中,数学库主要用于计算用于测量旋转角度的欧拉角。需要导入的库如下:
import bpy
from bpy import context, data, ops
import math
移除默认对象和相机
我们的下一个目标是从 Blender 环境中删除所有不必要的元素。可以通过两种方式执行此操作。一种方法是使用 delete
函数并将 use_global
参数设置为 False 。另一种方法是创建一个 for
循环,并在默认屏幕中检查所有对象,选择正在寻找的特定类型的对象,并删除适当(认为不必要的特定项目)的元素。下面是执行以下操作的代码块。
# Remove The Default Cude Object
# bpy.ops.object.delete(use_global=False)
bpy.ops.object.delete(use_global=False, confirm=False)
for o in bpy.context.scene.objects:
if o.name == "Cube":
bpy.ops.object.delete(use_global=False)
添加多个 “猴头” 网格
在下一步,我们将在各自的位置添加相应的多个 “猴头” 网格。为了执行这个步骤,我们将把三个变量初始值设为零。这三个变量分别表示 x 轴、y 轴 和 z 轴。我们将相应地修改这些变量,以获得 “猴头” 网格的最佳位置。count
变量用于根据需要改变这些轴的位置。
# Create multiple monkey meshes
x = 0
y = 0
z = 0
count1 = 0
count2 = -5
for i in range(3):
# Import the monkey mesh
bpy.ops.mesh.primitive_monkey_add(location = (x + count1, y + count1, z))
count1 += 5
for i in range(2):
# Import the monkey mesh
bpy.ops.mesh.primitive_monkey_add(location = (x + count2, y - count2, z))
count2 += -5
创建相机
一旦我们完成了创建多个 “猴头” 网格,我们可以添加一个相机来查看我们的对象和它们的整体视图。我们将设置场景和创建我们的相机,并将相机镜头设置为 30 mm。默认的相机尺寸通常是 50 mm 。但是,我们将使用这个特定的大小(30 mm),以便在 指定的范围内所有对象都清晰可见 。然后,我们将创建相机对象,并设置相机的位置和旋转角度。
位置(location
) 将决定相机的位置,在那里我们将有最好的视角,所有对象呈现在屏幕的可见区域。旋转角度(rotation_euler
) 由角度转换为弧度,这是在前面的编码部分中引入的数学库的帮助下完成的。
我们将指定沿所有三轴旋转的角度(弧度),以便 位置 和 旋转角度 都被正确放置。我们将场景的 collection
链接到当前的相机,并确保当前选择的相机被设置为活动
### Creating A New Camera Angle
scn = bpy.context.scene
# create the second camera
cam = bpy.data.cameras.new("Camera")
cam.lens = 30
# create the second camera object
cam_obj = bpy.data.objects.new("Camera", cam)
# Locations
cam_obj.location.x = 16
cam_obj.location.y = -6
cam_obj.location.z = 8
# Rotations
cam_obj.rotation_euler[0] = math.radians(64)
cam_obj.rotation_euler[1] = math.radians(0)
cam_obj.rotation_euler[2] = math.radians(47)
scn.collection.objects.link(cam_obj)
# Set the Camera to active camera
bpy.context.scene.camera = bpy.data.objects["Camera"]
保存渲染的图像
创建多个猴子网格和放置我们的相机在所需位置后的 最后一步 是保存图像。在我们保存图像之前,我们将渲染我们的图像,并将其存储为 “.png” 格式。渲染基本上是将 Blender 空间中的 3D 场景转换为 2D 视图,以便更容易以打印形式可视化。
为了执行这个步骤,我们将设置路径,并将三维模型场景从相机的角度渲染成二维图像,保存在指定路径的目录中。一旦我们的图像被渲染和保存,我们可以恢复之前的路径来执行进一步的计算和操作。
# Setting the path for the first image captured in the first camera
FILE_NAME = "1.png"
FILE_PATH = "D:\\Cool Projects\\Paperspace\\3-D Models\\1.png"
# Save Previous Path
previous_path = bpy.context.scene.render.filepath
# Render Image
bpy.context.scene.render.filepath = FILE_PATH
bpy.ops.render.render(write_still=True)
# Restore Previous Path
bpy.context.scene.render.filepath = previous_path
来源:https://juejin.cn/post/7127926500900208653


猜你喜欢
- 问题描述:想要去掉图像背景,只保留中心部分目标:1.利用ITK-SNAP制作二值化标签(即mask)2.利用软件ITK-SNAP把一幅图像中
- 今天在使用pytorch进行训练,在运行 loss.backward() 误差反向传播时出错 :RuntimeError: grad can
- 登录百度AL开发平台在控制台选择语音合成创建应用填写应用信息在应用列表获取(Appid、API Key、Secret Key)6. 安装py
- 1.数据集分割通过datasets可以直接分别获取训练集和测试集。通常我们会将训练集进行分割,通过torch.utils.data.rand
- 本文实例为大家分享了python实现五子棋游戏的具体代码,供大家参考,具体内容如下话不多说,直接上代码:全部工程文件,在GitHub:五子棋
- 前言FlashText 算法是由 Vikash Singh 于2017年发表的大规模关键词替换算法,这个算法的时间复杂度仅由文本长度(N)决
- 天在刷题的时候用到了正则,用的过程中就感觉有点不太熟练了,很久没有用正则都有点忘了。所以现在呢,我们就一起来review一下python中正
- 主库执行CREATE DATABASE test CHARACTER SET utf8 COLLATE utf8_general_ci;us
- 译注:这是一篇在Stack overflow上很热的帖子。提问者自称已经掌握了有关Python OOP编程中的各种概念,但始终觉得元类(me
- 常用闭包的同学肯定很清楚下面一段代码://通常的闭包写法(function () { ...}())那么我们的问题来了,为什么要在 func
- 这个需求是有个表结构,本身设计为 但现在需要将blob里地17、18、19三个字段里的数据作为数字保存在blob外新增的三个字段Gem1 G
- 一、函数解释1.Softmax函数常用的用法是指定参数dim就可以:(1)dim=0:对每一列的所有元素进行softmax运算,并使得每一列
- javascript:a. 代码:/*@desc:js搜索函数,可用于关键字匹配@param key 关键字@param str 要搜索的字
- TensorBoard是用于可视化图形和其他工具以理解、调试和优化模型的界面。它是一种为机器学习工作流提供测量和可视化的工具。它有助于跟踪损
- 我们的机器学习任务通常会跟全局图像的问题有关(例如,“图像是否包含一只猫呢?”),所以我们最后一层的神经元应该对整个输入的全局敏感。通过逐渐
- JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,它采用完全独立于语言的文本格式,可替换XML成
- 简述由于某些原因,在使用 import 时,Python 找不到相应的模块。这时,解释器就会发牢骚 - ImportError。那么,Pyt
- 问题背景: 日常对Sql Server 2005关系数据库进行操作时,有时对数据库(如:Sharepoint网站配置数据库名Sharepoi
- pycharm是一款高效的python IDE工具,它非常强大,且可以跨平台,是新手首选工具!下面我给第一次使用这款软件的朋友做一个简单的使
- numpy多维数组的创建多维数组(矩阵ndarray)ndarray的基本属性shape维度的大小ndim维度的个数dtype数据类型1.1