
* Simplify bbox access
* Code cleanup
* Simplify bbox access
* Move code to face helper
* Swap and paste back without insightface
* Swap and paste back without insightface
* Remove semaphore where possible
* Improve paste back performance
* Cosmetic changes
* Move the predictor to ONNX to avoid tensorflow, Use video ranges for prediction
* Make CI happy
* Move template and size to the options
* Fix different color on box
* Uniform model handling for predictor
* Uniform frame handling for predictor
* Pass kps direct to warp_face
* Fix urllib
* Analyse based on matches
* Analyse based on rate
* Fix CI
* ROCM and OpenVINO mapping for torch backends
* Fix the paste back speed
* Fix import
* Replace retinaface with yunet (#168)
* Remove insightface dependency
* Fix urllib
* Some fixes
* Analyse based on matches
* Analyse based on rate
* Fix CI
* Migrate to Yunet
* Something is off here
* We indeed need semaphore for yunet
* Normalize the normed_embedding
* Fix download of models
* Fix download of models
* Fix download of models
* Add score and improve affine_matrix
* Temp fix for bbox out of frame
* Temp fix for bbox out of frame
* ROCM and OpenVINO mapping for torch backends
* Normalize bbox
* Implement gender age
* Cosmetics on cli args
* Prevent face jumping
* Fix the paste back speed
* FIx import
* Introduce detection size
* Cosmetics on face analyser ARGS and globals
* Temp fix for shaking face
* Accurate event handling
* Accurate event handling
* Accurate event handling
* Set the reference_frame_number in face_selector component
* Simswap model (#171)
* Add simswap models
* Add ghost models
* Introduce normed template
* Conditional prepare and normalize for ghost
* Conditional prepare and normalize for ghost
* Get simswap working
* Get simswap working
* Fix refresh of swapper model
* Refine face selection and detection (#174)
* Refine face selection and detection
* Update README.md
* Fix some face analyser UI
* Fix some face analyser UI
* Introduce range handling for CLI arguments
* Introduce range handling for CLI arguments
* Fix some spacings
* Disable onnxruntime warnings
* Use cv2.blur over cv2.GaussianBlur for better performance
* Revert "Use cv2.blur over cv2.GaussianBlur for better performance"
This reverts commit bab666d6f9
.
* Prepare universal face detection
* Prepare universal face detection part2
* Reimplement retinaface
* Introduce cached anchors creation
* Restore filtering to enhance performance
* Minor changes
* Minor changes
* More code but easier to understand
* Minor changes
* Rename predictor to content analyser
* Change detection/recognition to detector/recognizer
* Fix crop frame borders
* Fix spacing
* Allow normalize output without a source
* Improve conditional set face reference
* Update dependencies
* Add timeout for get_download_size
* Fix performance due disorder
* Move models to assets repository, Adjust namings
* Refactor face analyser
* Rename models once again
* Fix spacing
* Highres simswap (#192)
* Introduce highres simswap
* Fix simswap 256 color issue (#191)
* Fix simswap 256 color issue
* Update face_swapper.py
* Normalize models and host in our repo
* Normalize models and host in our repo
---------
Co-authored-by: Harisreedhar <46858047+harisreedhar@users.noreply.github.com>
* Rename face analyser direction to face analyser order
* Improve the UI for face selector
* Add best-worst, worst-best detector ordering
* Clear as needed and fix zero score bug
* Fix linter
* Improve startup time by multi thread remote download size
* Just some cosmetics
* Normalize swagger source input, Add blendface_256 (unfinished)
* New paste back (#195)
* add new paste_back (#194)
* add new paste_back
* Update face_helper.py
* Update face_helper.py
* add commandline arguments and gui
* fix conflict
* Update face_mask.py
* type fix
* Clean some wording and typing
---------
Co-authored-by: Harisreedhar <46858047+harisreedhar@users.noreply.github.com>
* Clean more names, use blur range approach
* Add blur padding range
* Change the padding order
* Fix yunet filename
* Introduce face debugger
* Use percent for mask padding
* Ignore this
* Ignore this
* Simplify debugger output
* implement blendface (#198)
* Clean up after the genius
* Add gpen_bfr_256
* Cosmetics
* Ignore face_mask_padding on face enhancer
* Update face_debugger.py (#202)
* Shrink debug_face() to a minimum
* Mark as 2.0.0 release
* remove unused (#204)
* Apply NMS (#205)
* Apply NMS
* Apply NMS part2
* Fix restoreformer url
* Add debugger cli and gui components (#206)
* Add debugger cli and gui components
* update
* Polishing the types
* Fix usage in README.md
* Update onnxruntime
* Support for webp
* Rename paste-back to face-mask
* Add license to README
* Add license to README
* Extend face selector mode by one
* Update utilities.py (#212)
* Stop inline camera on stream
* Minor webcam updates
* Gracefully start and stop webcam
* Rename capture to video_capture
* Make get webcam capture pure
* Check webcam to not be None
* Remove some is not None
* Use index 0 for webcam
* Remove memory lookup within progress bar
* Less progress bar updates
* Uniform progress bar
* Use classic progress bar
* Fix image and video validation
* Use different hash for cache
* Use best-worse order for webcam
* Normalize padding like CSS
* Update preview
* Fix max memory
* Move disclaimer and license to the docs
* Update wording in README
* Add LICENSE.md
* Fix argument in README
---------
Co-authored-by: Harisreedhar <46858047+harisreedhar@users.noreply.github.com>
Co-authored-by: alex00ds <31631959+alex00ds@users.noreply.github.com>
131 lines
4.5 KiB
Python
131 lines
4.5 KiB
Python
from typing import Dict, Optional, Any, List
|
|
from types import ModuleType
|
|
import importlib
|
|
import sys
|
|
import gradio
|
|
|
|
import facefusion.globals
|
|
from facefusion import metadata, wording
|
|
from facefusion.uis.typing import Component, ComponentName
|
|
from facefusion.utilities import resolve_relative_path
|
|
|
|
UI_COMPONENTS: Dict[ComponentName, Component] = {}
|
|
UI_LAYOUT_MODULES : List[ModuleType] = []
|
|
UI_LAYOUT_METHODS =\
|
|
[
|
|
'pre_check',
|
|
'pre_render',
|
|
'render',
|
|
'listen',
|
|
'run'
|
|
]
|
|
|
|
|
|
def load_ui_layout_module(ui_layout : str) -> Any:
|
|
try:
|
|
ui_layout_module = importlib.import_module('facefusion.uis.layouts.' + ui_layout)
|
|
for method_name in UI_LAYOUT_METHODS:
|
|
if not hasattr(ui_layout_module, method_name):
|
|
raise NotImplementedError
|
|
except ModuleNotFoundError:
|
|
sys.exit(wording.get('ui_layout_not_loaded').format(ui_layout = ui_layout))
|
|
except NotImplementedError:
|
|
sys.exit(wording.get('ui_layout_not_implemented').format(ui_layout = ui_layout))
|
|
return ui_layout_module
|
|
|
|
|
|
def get_ui_layouts_modules(ui_layouts : List[str]) -> List[ModuleType]:
|
|
global UI_LAYOUT_MODULES
|
|
|
|
if not UI_LAYOUT_MODULES:
|
|
for ui_layout in ui_layouts:
|
|
ui_layout_module = load_ui_layout_module(ui_layout)
|
|
UI_LAYOUT_MODULES.append(ui_layout_module)
|
|
return UI_LAYOUT_MODULES
|
|
|
|
|
|
def get_ui_component(name : ComponentName) -> Optional[Component]:
|
|
if name in UI_COMPONENTS:
|
|
return UI_COMPONENTS[name]
|
|
return None
|
|
|
|
|
|
def register_ui_component(name : ComponentName, component: Component) -> None:
|
|
UI_COMPONENTS[name] = component
|
|
|
|
|
|
def launch() -> None:
|
|
with gradio.Blocks(theme = get_theme(), css = get_css(), title = metadata.get('name') + ' ' + metadata.get('version')) as ui:
|
|
for ui_layout in facefusion.globals.ui_layouts:
|
|
ui_layout_module = load_ui_layout_module(ui_layout)
|
|
if ui_layout_module.pre_render():
|
|
ui_layout_module.render()
|
|
ui_layout_module.listen()
|
|
|
|
for ui_layout in facefusion.globals.ui_layouts:
|
|
ui_layout_module = load_ui_layout_module(ui_layout)
|
|
ui_layout_module.run(ui)
|
|
|
|
|
|
def get_theme() -> gradio.Theme:
|
|
return gradio.themes.Base(
|
|
primary_hue = gradio.themes.colors.red,
|
|
secondary_hue = gradio.themes.colors.neutral,
|
|
font = gradio.themes.GoogleFont('Open Sans')
|
|
).set(
|
|
background_fill_primary = '*neutral_100',
|
|
block_background_fill = 'white',
|
|
block_border_width = '0',
|
|
block_label_background_fill = '*primary_100',
|
|
block_label_background_fill_dark = '*primary_600',
|
|
block_label_border_width = 'none',
|
|
block_label_margin = '0.5rem',
|
|
block_label_radius = '*radius_md',
|
|
block_label_text_color = '*primary_500',
|
|
block_label_text_color_dark = 'white',
|
|
block_label_text_weight = '600',
|
|
block_title_background_fill = '*primary_100',
|
|
block_title_background_fill_dark = '*primary_600',
|
|
block_title_padding = '*block_label_padding',
|
|
block_title_radius = '*block_label_radius',
|
|
block_title_text_color = '*primary_500',
|
|
block_title_text_size = '*text_sm',
|
|
block_title_text_weight = '600',
|
|
block_padding = '0.5rem',
|
|
border_color_primary = 'transparent',
|
|
border_color_primary_dark = 'transparent',
|
|
button_large_padding = '2rem 0.5rem',
|
|
button_large_text_weight = 'normal',
|
|
button_primary_background_fill = '*primary_500',
|
|
button_primary_text_color = 'white',
|
|
button_secondary_background_fill = 'white',
|
|
button_secondary_border_color = 'transparent',
|
|
button_secondary_border_color_dark = 'transparent',
|
|
button_secondary_border_color_hover = 'transparent',
|
|
button_secondary_border_color_hover_dark = 'transparent',
|
|
button_secondary_text_color = '*neutral_800',
|
|
button_small_padding = '0.75rem',
|
|
checkbox_background_color = '*neutral_200',
|
|
checkbox_background_color_selected = '*primary_600',
|
|
checkbox_background_color_selected_dark = '*primary_700',
|
|
checkbox_border_color_focus = '*primary_500',
|
|
checkbox_border_color_focus_dark = '*primary_600',
|
|
checkbox_border_color_selected = '*primary_600',
|
|
checkbox_border_color_selected_dark = '*primary_700',
|
|
checkbox_label_background_fill = '*neutral_50',
|
|
checkbox_label_background_fill_hover = '*neutral_50',
|
|
checkbox_label_background_fill_selected = '*primary_500',
|
|
checkbox_label_background_fill_selected_dark = '*primary_600',
|
|
checkbox_label_text_color_selected = 'white',
|
|
input_background_fill = '*neutral_50',
|
|
shadow_drop = 'none',
|
|
slider_color = '*primary_500',
|
|
slider_color_dark = '*primary_600'
|
|
)
|
|
|
|
|
|
def get_css() -> str:
|
|
fixes_css_path = resolve_relative_path('uis/assets/fixes.css')
|
|
overrides_css_path = resolve_relative_path('uis/assets/overrides.css')
|
|
return open(fixes_css_path, 'r').read() + open(overrides_css_path, 'r').read()
|