网友回复
要将多张图片拼接成九宫格(3x3 网格),可以使用 Python + Pillow 库。以下是完整的代码实现和步骤说明,支持自动调整图片大小并填充网格:
完整代码from PIL import Image import os def create_3x3_collage(image_paths, output_path, cell_size=(300, 300), spacing=10): """ 将 9 张图片拼接为九宫格 :param image_paths: 图片路径列表(必须为 9 个) :param output_path: 输出图片路径 :param cell_size: 每个格子的大小 (width, height) :param spacing: 格子之间的间距(像素) """ if len(image_paths) != 9: raise ValueError("需要 9 张图片") # 创建画布 canvas_width = cell_size[0] * 3 + spacing * 2 canvas_height = cell_size[1] * 3 + spacing * 2 canvas = Image.new('RGB', (canvas_width, canvas_height), (255, 255, 255)) # 处理每张图片 for index, img_path in enumerate(image_paths): row = index // 3 # 行号 (0-2) col = index % 3 # 列号 (0-2) # 打开图片并调整大小(强制填充) img = Image.open(img_path) img = img.resize(cell_size, Image.Resampling.LANCZOS) # 使用高质量缩放 # 计算粘贴位置 x = col * (cell_size[0] + spacing) y = row * (cell_size[1] + spacing) canvas.paste(i...
点击查看剩余70%
为啥所有的照片分辨率提升工具都会修改照片上的图案细节?
js如何在浏览器中将webm视频的声音分离为单独音频?
微信小程序如何播放第三方域名url的mp4视频?
ai多模态大模型能实时识别视频中的手语为文字吗?
如何远程调试别人的chrome浏览器获取调试信息?
为啥js打开新网页window.open设置窗口宽高无效?
浏览器中js的navigator.mediaDevices.getDisplayMedia屏幕录像无法录制SpeechSynthesisUtterance产生的说话声音?
js中mediaRecorder如何录制window.speechSynthesis声音音频并下载?
python如何直接获取抖音短视频的音频文件url?
js在浏览器中如何使用MediaStream与MediaRecorder实现声音音频多轨道混流?