#!/usr/bin/env python3 import json import re try: from .base_worker import * except ImportError: from base_worker import * from ..engines.blender_engine import Blender class BlenderRenderWorker(BaseRenderWorker): engine = Blender def __init__(self, input_path, output_path, args=None, parent=None, name=None): super(BlenderRenderWorker, self).__init__(input_path=input_path, output_path=output_path, args=args, parent=parent, name=name) # Args self.blender_engine = self.args.get('engine', 'BLENDER_EEVEE').upper() self.export_format = self.args.get('export_format', None) or 'JPEG' self.camera = self.args.get('camera', None) # Stats self.__frame_percent_complete = 0.0 # Scene Info self.scene_info = Blender.get_scene_info(input_path) self.start_frame = int(self.scene_info.get('start_frame', 1)) self.end_frame = int(self.scene_info.get('end_frame', self.start_frame)) self.project_length = (self.end_frame - self.start_frame) + 1 self.current_frame = -1 def generate_worker_subprocess(self): cmd = [self.engine.renderer_path()] if self.args.get('background', True): # optionally run render not in background cmd.append('-b') cmd.append(self.input_path) if self.camera: cmd.extend(['--python-expr', f"import bpy;bpy.context.scene.camera = bpy.data.objects['{self.camera}'];"]) # add dash at end of given path to separate frame numbers path_with_ending_dash = os.path.splitext(self.output_path)[0] + "-" + os.path.splitext(self.output_path)[1] cmd.extend(['-E', self.blender_engine, '-o', path_with_ending_dash, '-F', self.export_format]) # set frame range cmd.extend(['-s', self.start_frame, '-e', self.end_frame, '-a']) # Convert raw args from string if available raw_args = self.get_raw_args() if raw_args: cmd.extend(raw_args) return cmd def _parse_stdout(self, line): pattern = re.compile( r'Fra:(?P\d*).*Mem:(?P\S+).*Time:(?P