Merge pull request #62 from faceshiftlabs/feat/toggle-checkerboard

Feat/toggle checkerboard
This commit is contained in:
Jeremy Hummel 2019-09-12 17:39:38 -07:00 committed by GitHub
commit 0c10c46624
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 27 additions and 16 deletions

View file

@ -116,13 +116,13 @@ class ConvertSubprocessor(Subprocessor):
return fanseg.extract(*args, **kwargs) return fanseg.extract(*args, **kwargs)
self.fanseg_extract_func = fanseg_extract self.fanseg_extract_func = fanseg_extract
import ebsynth import ebsynth
def ebs_ct(*args, **kwargs): def ebs_ct(*args, **kwargs):
return ebsynth.color_transfer(*args, **kwargs) return ebsynth.color_transfer(*args, **kwargs)
self.ebs_ct_func = ebs_ct self.ebs_ct_func = ebs_ct
return None return None
#override #override
@ -168,7 +168,7 @@ class ConvertSubprocessor(Subprocessor):
raise Exception( 'Error while converting file [%s]: %s' % (filename, e_str) ) raise Exception( 'Error while converting file [%s]: %s' % (filename, e_str) )
elif cfg.type == ConverterConfig.TYPE_FACE_AVATAR: elif cfg.type == ConverterConfig.TYPE_FACE_AVATAR:
final_img = ConvertFaceAvatar (self.predictor_func, self.predictor_input_shape, final_img = ConvertFaceAvatar (self.predictor_func, self.predictor_input_shape,
cfg, pf.prev_temporal_frame_infos, cfg, pf.prev_temporal_frame_infos,
pf.frame_info, pf.frame_info,
pf.next_temporal_frame_infos ) pf.next_temporal_frame_infos )
@ -266,7 +266,7 @@ class ConvertSubprocessor(Subprocessor):
if self.model_iter != s_model_iter or \ if self.model_iter != s_model_iter or \
len(self.frames_idxs) == 0: len(self.frames_idxs) == 0:
#rewind to begin if model is more trained or all frames are done #rewind to begin if model is more trained or all frames are done
while len(self.frames_done_idxs) > 0: while len(self.frames_done_idxs) > 0:
prev_frame = self.frames[self.frames_done_idxs.pop()] prev_frame = self.frames[self.frames_done_idxs.pop()]
self.frames_idxs.insert(0, prev_frame.idx) self.frames_idxs.insert(0, prev_frame.idx)
@ -482,6 +482,9 @@ class ConvertSubprocessor(Subprocessor):
self.screen_manager.get_current().diff_scale(-0.1) self.screen_manager.get_current().diff_scale(-0.1)
elif chr_key == '=': elif chr_key == '=':
self.screen_manager.get_current().diff_scale(0.1) self.screen_manager.get_current().diff_scale(0.1)
elif chr_key == '\\':
self.main_screen.toggle_checkerboard()
self.main_screen.show(True)
if go_prev_frame: if go_prev_frame:
@ -557,7 +560,7 @@ class ConvertSubprocessor(Subprocessor):
for i in range ( min(len(self.frames_idxs), self.prefetch_frame_count) ): for i in range ( min(len(self.frames_idxs), self.prefetch_frame_count) ):
frame = self.frames[ self.frames_idxs[i] ] frame = self.frames[ self.frames_idxs[i] ]
if not frame.is_done and not frame.is_processing and frame.cfg is not None: if not frame.is_done and not frame.is_processing and frame.cfg is not None:
frame.is_processing = True frame.is_processing = True
return ConvertSubprocessor.ProcessingFrame(idx=frame.idx, return ConvertSubprocessor.ProcessingFrame(idx=frame.idx,
cfg=frame.cfg.copy(), cfg=frame.cfg.copy(),
@ -599,7 +602,7 @@ def main (args, device_args):
import models import models
model = models.import_model( args['model_name'] )(model_path, device_args=device_args) model = models.import_model( args['model_name'] )(model_path, device_args=device_args)
converter_session_filepath = model.get_strpath_storage_for_file('converter_session.dat') converter_session_filepath = model.get_strpath_storage_for_file('converter_session.dat')
predictor_func, predictor_input_shape, cfg = model.get_ConverterConfig() predictor_func, predictor_input_shape, cfg = model.get_ConverterConfig()
if not is_interactive: if not is_interactive:
@ -726,8 +729,8 @@ def main (args, device_args):
is_interactive = is_interactive, is_interactive = is_interactive,
converter_session_filepath = converter_session_filepath, converter_session_filepath = converter_session_filepath,
predictor_func = predictor_func, predictor_func = predictor_func,
predictor_input_shape = predictor_input_shape, predictor_input_shape = predictor_input_shape,
converter_config = cfg, converter_config = cfg,
frames = frames, frames = frames,
output_path = output_path, output_path = output_path,
model_iter = model.get_iter() model_iter = model.get_iter()

View file

@ -35,6 +35,18 @@ class Screen(object):
self.checkerboard_image = None self.checkerboard_image = None
self.set_image (image) self.set_image (image)
self.scrn_manager = None self.scrn_manager = None
self.show_checkerboard = True
def draw_checkerboard(self, screen):
if self.checkerboard_image is None or self.checkerboard_image.shape[0:2] != screen.shape[0:2]:
self.checkerboard_image = ScreenAssets.build_checkerboard_a(screen.shape)
screen = screen[...,0:3]*0.75 + 64*self.checkerboard_image*(1- (screen[...,3:4].astype(np.float32)/255.0) )
screen = screen.astype(np.uint8)
return screen
def toggle_checkerboard(self):
self.show_checkerboard = not self.show_checkerboard
def set_waiting_icon(self, b): def set_waiting_icon(self, b):
self.waiting_icon = b self.waiting_icon = b
@ -84,12 +96,8 @@ class Screen(object):
if self.scale != 1.0: if self.scale != 1.0:
screen = cv2.resize ( screen, ( int(w*self.scale), int(h*self.scale) ) ) screen = cv2.resize ( screen, ( int(w*self.scale), int(h*self.scale) ) )
if c == 4: if c == 4 and self.show_checkerboard:
if self.checkerboard_image is None or self.checkerboard_image.shape[0:2] != screen.shape[0:2]: screen = self.draw_checkerboard(screen)
self.checkerboard_image = ScreenAssets.build_checkerboard_a(screen.shape)
screen = screen[...,0:3]*0.75 + 64*self.checkerboard_image*(1- (screen[...,3:4].astype(np.float32)/255.0) )
screen = screen.astype(np.uint8)
io.show_image(self.scrn_manager.wnd_name, screen) io.show_image(self.scrn_manager.wnd_name, screen)

Binary file not shown.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 288 KiB

After

Width:  |  Height:  |  Size: 216 KiB

Before After
Before After