Moving blender render files to be accessed via pkg_resources
Previously the .blend and .py files had to be in the same directory mediagoblin/celery launched from. This is now fixed so it pulls them out of the package proper.
This commit is contained in:
parent
8bef424f24
commit
39c340f280
@ -18,6 +18,7 @@ import os
|
|||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
import subprocess
|
import subprocess
|
||||||
|
import pkg_resources
|
||||||
|
|
||||||
from mediagoblin import mg_globals as mgg
|
from mediagoblin import mg_globals as mgg
|
||||||
from mediagoblin.processing import create_pub_filepath, \
|
from mediagoblin.processing import create_pub_filepath, \
|
||||||
@ -29,6 +30,17 @@ from mediagoblin.media_types.stl import model_loader
|
|||||||
_log = logging.getLogger(__name__)
|
_log = logging.getLogger(__name__)
|
||||||
SUPPORTED_FILETYPES = ['stl', 'obj']
|
SUPPORTED_FILETYPES = ['stl', 'obj']
|
||||||
|
|
||||||
|
BLEND_FILE = pkg_resources.resource_filename(
|
||||||
|
'mediagoblin.media_types.stl',
|
||||||
|
os.path.join(
|
||||||
|
'assets',
|
||||||
|
'blender_render.blend'))
|
||||||
|
BLEND_SCRIPT = pkg_resources.resource_filename(
|
||||||
|
'mediagoblin.media_types.stl',
|
||||||
|
os.path.join(
|
||||||
|
'assets',
|
||||||
|
'blender_render.py'))
|
||||||
|
|
||||||
|
|
||||||
def sniff_handler(media_file, **kw):
|
def sniff_handler(media_file, **kw):
|
||||||
if kw.get('media') is not None:
|
if kw.get('media') is not None:
|
||||||
@ -55,7 +67,12 @@ def blender_render(config):
|
|||||||
arg_string = "blender -b blender_render.blend -F "
|
arg_string = "blender -b blender_render.blend -F "
|
||||||
arg_string +="JPEG -P blender_render.py"
|
arg_string +="JPEG -P blender_render.py"
|
||||||
env = {"RENDER_SETUP" : json.dumps(config), "DISPLAY":":0"}
|
env = {"RENDER_SETUP" : json.dumps(config), "DISPLAY":":0"}
|
||||||
subprocess.call(arg_string.split(" "), env=env)
|
subprocess.call(
|
||||||
|
["blender",
|
||||||
|
"-b", BLEND_FILE,
|
||||||
|
"-F", "JPEG",
|
||||||
|
"-P", BLEND_SCRIPT],
|
||||||
|
env=env)
|
||||||
|
|
||||||
|
|
||||||
def process_stl(entry):
|
def process_stl(entry):
|
||||||
@ -93,16 +110,16 @@ def process_stl(entry):
|
|||||||
path = create_pub_filepath(entry, name_builder.fill(name))
|
path = create_pub_filepath(entry, name_builder.fill(name))
|
||||||
render_file = mgg.public_store.get_file(path, "wb")
|
render_file = mgg.public_store.get_file(path, "wb")
|
||||||
shot = {
|
shot = {
|
||||||
"model_path" : queued_filename,
|
"model_path": queued_filename,
|
||||||
"model_ext" : ext,
|
"model_ext": ext,
|
||||||
"camera_coord" : camera,
|
"camera_coord": camera,
|
||||||
"camera_focus" : model.average,
|
"camera_focus": model.average,
|
||||||
"camera_clip" : greatest*10,
|
"camera_clip": greatest*10,
|
||||||
"greatest" : greatest,
|
"greatest": greatest,
|
||||||
"projection" : project,
|
"projection": project,
|
||||||
"width" : width,
|
"width": width,
|
||||||
"height" : height,
|
"height": height,
|
||||||
"out_file" : render_file.name,
|
"out_file": render_file.name,
|
||||||
}
|
}
|
||||||
render_file.close()
|
render_file.close()
|
||||||
blender_render(shot)
|
blender_render(shot)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user