2023-02-13 23:34:42 +00:00
|
|
|
from logging import getLogger
|
2023-12-21 04:58:57 +00:00
|
|
|
from typing import Optional, Tuple
|
2023-02-13 23:34:42 +00:00
|
|
|
|
|
|
|
from PIL import Image
|
|
|
|
|
2023-02-27 02:09:42 +00:00
|
|
|
from ..output import save_image
|
2023-02-13 23:34:42 +00:00
|
|
|
from ..params import ImageParams, StageParams
|
2023-02-26 05:49:39 +00:00
|
|
|
from ..server import ServerContext
|
2023-02-19 02:28:21 +00:00
|
|
|
from ..utils import is_debug
|
2023-02-26 20:15:30 +00:00
|
|
|
from ..worker import ProgressCallback, WorkerContext
|
2023-11-18 23:18:23 +00:00
|
|
|
from .base import BaseStage
|
2023-11-19 00:08:38 +00:00
|
|
|
from .result import StageResult
|
2023-02-13 23:34:42 +00:00
|
|
|
|
|
|
|
logger = getLogger(__name__)
|
|
|
|
|
|
|
|
|
2023-07-02 23:21:21 +00:00
|
|
|
class BlendMaskStage(BaseStage):
|
2023-07-01 12:10:53 +00:00
|
|
|
def run(
|
|
|
|
self,
|
2023-07-15 23:54:54 +00:00
|
|
|
_worker: WorkerContext,
|
2023-07-01 12:10:53 +00:00
|
|
|
server: ServerContext,
|
|
|
|
_stage: StageParams,
|
|
|
|
_params: ImageParams,
|
2023-11-19 00:08:38 +00:00
|
|
|
sources: StageResult,
|
2023-07-01 12:10:53 +00:00
|
|
|
*,
|
2023-12-21 04:58:57 +00:00
|
|
|
dims: Tuple[int, int, int],
|
2023-07-01 12:10:53 +00:00
|
|
|
stage_source: Optional[Image.Image] = None,
|
|
|
|
stage_mask: Optional[Image.Image] = None,
|
2023-12-21 05:33:13 +00:00
|
|
|
tile_mask: Optional[Image.Image] = None,
|
2023-07-01 12:10:53 +00:00
|
|
|
_callback: Optional[ProgressCallback] = None,
|
|
|
|
**kwargs,
|
2023-11-19 00:08:38 +00:00
|
|
|
) -> StageResult:
|
2023-07-01 12:10:53 +00:00
|
|
|
logger.info("blending image using mask")
|
|
|
|
|
2023-12-21 05:33:13 +00:00
|
|
|
mask_source = tile_mask or stage_mask
|
|
|
|
mult_mask = Image.new(mask_source.mode, mask_source.size, color="black")
|
|
|
|
mult_mask = Image.alpha_composite(mult_mask, mask_source)
|
2023-07-01 12:10:53 +00:00
|
|
|
mult_mask = mult_mask.convert("L")
|
|
|
|
|
2023-12-22 17:31:31 +00:00
|
|
|
left, top, tile = dims
|
2023-12-21 05:02:58 +00:00
|
|
|
stage_source_tile = stage_source.crop((left, top, left + tile, top + tile))
|
2023-12-21 04:58:57 +00:00
|
|
|
|
2023-07-01 12:10:53 +00:00
|
|
|
if is_debug():
|
2023-12-21 05:33:13 +00:00
|
|
|
save_image(server, "last-mask.png", mask_source)
|
2023-07-01 12:10:53 +00:00
|
|
|
save_image(server, "last-mult-mask.png", mult_mask)
|
2023-12-21 04:58:57 +00:00
|
|
|
save_image(server, "last-stage-source.png", stage_source_tile)
|
2023-07-01 12:10:53 +00:00
|
|
|
|
2023-12-15 02:12:39 +00:00
|
|
|
return StageResult.from_images(
|
|
|
|
[
|
2023-12-21 04:58:57 +00:00
|
|
|
Image.composite(stage_source_tile, source, mult_mask)
|
2024-01-06 02:11:58 +00:00
|
|
|
for source in sources.as_images()
|
|
|
|
],
|
|
|
|
metadata=sources.metadata,
|
2023-11-19 00:13:13 +00:00
|
|
|
)
|