| from typing_extensions import Literal, TypeAlias |
|
|
|
|
| Processor_id: TypeAlias = Literal[ |
| "canny", "depth", "softedge", "lineart", "lineart_anime", "openpose", "normal", "tile", "none", "inpaint" |
| ] |
|
|
| class Annotator: |
| def __init__(self, processor_id: Processor_id, model_path="models/Annotators", detect_resolution=None, device='cuda', skip_processor=False): |
| if not skip_processor: |
| if processor_id == "canny": |
| from controlnet_aux.processor import CannyDetector |
| self.processor = CannyDetector() |
| elif processor_id == "depth": |
| from controlnet_aux.processor import MidasDetector |
| self.processor = MidasDetector.from_pretrained(model_path).to(device) |
| elif processor_id == "softedge": |
| from controlnet_aux.processor import HEDdetector |
| self.processor = HEDdetector.from_pretrained(model_path).to(device) |
| elif processor_id == "lineart": |
| from controlnet_aux.processor import LineartDetector |
| self.processor = LineartDetector.from_pretrained(model_path).to(device) |
| elif processor_id == "lineart_anime": |
| from controlnet_aux.processor import LineartAnimeDetector |
| self.processor = LineartAnimeDetector.from_pretrained(model_path).to(device) |
| elif processor_id == "openpose": |
| from controlnet_aux.processor import OpenposeDetector |
| self.processor = OpenposeDetector.from_pretrained(model_path).to(device) |
| elif processor_id == "normal": |
| from controlnet_aux.processor import NormalBaeDetector |
| self.processor = NormalBaeDetector.from_pretrained(model_path).to(device) |
| elif processor_id == "tile" or processor_id == "none" or processor_id == "inpaint": |
| self.processor = None |
| else: |
| raise ValueError(f"Unsupported processor_id: {processor_id}") |
| else: |
| self.processor = None |
|
|
| self.processor_id = processor_id |
| self.detect_resolution = detect_resolution |
| |
| def to(self,device): |
| if hasattr(self.processor,"model") and hasattr(self.processor.model,"to"): |
|
|
| self.processor.model.to(device) |
|
|
| def __call__(self, image, mask=None): |
| width, height = image.size |
| if self.processor_id == "openpose": |
| kwargs = { |
| "include_body": True, |
| "include_hand": True, |
| "include_face": True |
| } |
| else: |
| kwargs = {} |
| if self.processor is not None: |
| detect_resolution = self.detect_resolution if self.detect_resolution is not None else min(width, height) |
| image = self.processor(image, detect_resolution=detect_resolution, image_resolution=min(width, height), **kwargs) |
| image = image.resize((width, height)) |
| return image |
|
|
|
|