PyAPI: gpu utility module to create new batches
Support the common case of creating batches from python geometry, a shader and optionally indices. See D3779
This commit is contained in:

committed by
Campbell Barton

parent
ca8fee62ab
commit
0264c050bf
@@ -17,5 +17,6 @@
|
||||
# ***** END GPL LICENSE BLOCK *****
|
||||
|
||||
__all__ = (
|
||||
"batch",
|
||||
"presets",
|
||||
)
|
||||
|
62
release/scripts/modules/gpu_extras/batch.py
Normal file
62
release/scripts/modules/gpu_extras/batch.py
Normal file
@@ -0,0 +1,62 @@
|
||||
# ***** BEGIN GPL LICENSE BLOCK *****
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU General Public License
|
||||
# as published by the Free Software Foundation; either version 2
|
||||
# of the License, or (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
#
|
||||
# ***** END GPL LICENSE BLOCK *****
|
||||
|
||||
__all__ = (
|
||||
"batch_for_shader"
|
||||
)
|
||||
|
||||
|
||||
def batch_for_shader(shader, type, content, indices=None):
|
||||
"""
|
||||
Return a batch already configured and compatible with the shader.
|
||||
|
||||
:arg shader: shader for which a compatible format will be computed.
|
||||
:type shader: :class:`gpu.types.GPUShader`
|
||||
:arg type: "'POINTS', 'LINES', 'TRIS' or 'LINES_ADJ'".
|
||||
:type type: str
|
||||
:arg content: Maps the name of the shader attribute with the data to fill the vertex buffer.
|
||||
:type content: dict
|
||||
:return: compatible batch
|
||||
:rtype: :class:`gpu.types.Batch`
|
||||
"""
|
||||
import gpu
|
||||
from gpu.types import (
|
||||
GPUBatch,
|
||||
GPUIndexBuf,
|
||||
GPUVertBuf,
|
||||
)
|
||||
|
||||
for data in content.values():
|
||||
vbo_len = len(data)
|
||||
break
|
||||
else:
|
||||
raise ValueError("Empty 'content'")
|
||||
|
||||
vbo_format = shader.format_calc()
|
||||
vbo = GPUVertBuf(vbo_format, vbo_len)
|
||||
|
||||
for id, data in content.items():
|
||||
if len(data) != vbo_len:
|
||||
raise ValueError("Length mismatch for 'content' values")
|
||||
vbo.attr_fill(id, data)
|
||||
|
||||
if indices is None:
|
||||
return GPUBatch(type=type, buf=vbo)
|
||||
else:
|
||||
ibo = GPUIndexBuf(type=type, seq=indices)
|
||||
return GPUBatch(type=type, buf=vbo, elem=ibo)
|
Reference in New Issue
Block a user