Merge pull request #7116 from vladmandic/api-image-format
API should use same image format as specified in WebUI settings
This commit is contained in:
commit
756a2c3c0f
@ -22,6 +22,8 @@ from modules.sd_models import checkpoints_list, find_checkpoint_config
|
|||||||
from modules.realesrgan_model import get_realesrgan_models
|
from modules.realesrgan_model import get_realesrgan_models
|
||||||
from modules import devices
|
from modules import devices
|
||||||
from typing import List
|
from typing import List
|
||||||
|
import piexif
|
||||||
|
import piexif.helper
|
||||||
|
|
||||||
def upscaler_to_index(name: str):
|
def upscaler_to_index(name: str):
|
||||||
try:
|
try:
|
||||||
@ -56,18 +58,30 @@ def decode_base64_to_image(encoding):
|
|||||||
def encode_pil_to_base64(image):
|
def encode_pil_to_base64(image):
|
||||||
with io.BytesIO() as output_bytes:
|
with io.BytesIO() as output_bytes:
|
||||||
|
|
||||||
# Copy any text-only metadata
|
if opts.samples_format.lower() == 'png':
|
||||||
use_metadata = False
|
use_metadata = False
|
||||||
metadata = PngImagePlugin.PngInfo()
|
metadata = PngImagePlugin.PngInfo()
|
||||||
for key, value in image.info.items():
|
for key, value in image.info.items():
|
||||||
if isinstance(key, str) and isinstance(value, str):
|
if isinstance(key, str) and isinstance(value, str):
|
||||||
metadata.add_text(key, value)
|
metadata.add_text(key, value)
|
||||||
use_metadata = True
|
use_metadata = True
|
||||||
|
image.save(output_bytes, format="PNG", pnginfo=(metadata if use_metadata else None), quality=opts.jpeg_quality)
|
||||||
|
|
||||||
|
elif opts.samples_format.lower() in ("jpg", "jpeg", "webp"):
|
||||||
|
parameters = image.info.get('parameters', None)
|
||||||
|
exif_bytes = piexif.dump({
|
||||||
|
"Exif": { piexif.ExifIFD.UserComment: piexif.helper.UserComment.dump(parameters or "", encoding="unicode") }
|
||||||
|
})
|
||||||
|
if opts.samples_format.lower() in ("jpg", "jpeg"):
|
||||||
|
image.save(output_bytes, format="JPEG", exif = exif_bytes, quality=opts.jpeg_quality)
|
||||||
|
else:
|
||||||
|
image.save(output_bytes, format="WEBP", exif = exif_bytes, quality=opts.jpeg_quality)
|
||||||
|
|
||||||
|
else:
|
||||||
|
raise HTTPException(status_code=500, detail="Invalid image format")
|
||||||
|
|
||||||
image.save(
|
|
||||||
output_bytes, "PNG", pnginfo=(metadata if use_metadata else None)
|
|
||||||
)
|
|
||||||
bytes_data = output_bytes.getvalue()
|
bytes_data = output_bytes.getvalue()
|
||||||
|
|
||||||
return base64.b64encode(bytes_data)
|
return base64.b64encode(bytes_data)
|
||||||
|
|
||||||
def api_middleware(app: FastAPI):
|
def api_middleware(app: FastAPI):
|
||||||
|
Loading…
Reference in New Issue
Block a user