背景需求:
我觉得这个代码里面的输入信息分离太远(42行和241行),想重新优化一下
【教学类-102-05】蛋糕剪纸图案(留白边、沿线剪)04——Python白色(255)图片转为透明png再制作“点状边框和虚线边框”-CSDN博客文章浏览阅读864次,点赞14次,收藏27次。【教学类-102-05】蛋糕剪纸图案(留白边、沿线剪)04——Python白色(255)图片转为透明png再制作“点状边框和虚线边框”https://blog.csdn.net/reasonsummer/article/details/147053695?spm=1011.2415.3001.5331
AI优化的代码把参数都放在最前面,便于更改所有的文件夹
'''
255白背景图片(蝴蝶)做成点状虚线,透明\切边\统一大小,保存1图2图4图24图
deepseek,阿夏
20250410
'''
from PIL import Image, ImageDraw
import os
import math
print('------1、基本信息-----')
# 主路径b
path = r'C:\Users\jg2yXRZ\OneDrive\桌面\20250401边缘线剪纸'
a='11'
b='蝴蝶'
# 白边宽度(像素)
white_border_width = 30
# 黑点直径(像素)
dot_size = 5
# 黑点间距(像素)
dot_spacing = dot_size * 2 # 增加间距确保均匀分布
# 白边参数设置
transparent_edge = 40 # 裁剪时不保留额外透明边距(这个没有用)
# 图片大小
target_width = 1000 # 统一宽度
target_height = 1000 # 统一高度
# 定义文件夹路径
in_folder = os.path.join(path,f'{a}_01{b}白背景') # 原始图片(白背景)
transparent_folder = os.path.join(path, f'{a}_02{b}透明背景') # 透明背景输出
output_folder = os.path.join(path, f'{a}_03{b}虚线轮廓') # 最终输出
input_folder = output_folder # 原始图片文件夹
cropped_folder = os.path.join(path,f'{a}_04{b}虚线切边') # 裁剪后的透明图片
final=f'{a}_05{b}虚线切边统一图'# 1000*1000统一图
resized_folder = os.path.join(path,f'{final}')
# 创建输出文件夹
os.makedirs(cropped_folder, exist_ok=True)
os.makedirs(resized_folder, exist_ok=True)
os.makedirs(transparent_folder, exist_ok=True)
os.makedirs(output_folder, exist_ok=True)
print('------2、白色PNG背景变成透明-----')
# 先把图片白色部分变成透明
def process_image_to_transparent(file_path):
img = Image.open(file_path)
img = img.convert("RGBA")
datas = img.getdata()
new_data = []
for item in datas:
if item[0] == 255 and item[1] == 255 and item[2] == 255:
# 设置为完全透明
new_data.append((255, 255, 255, 0))
else:
new_data.append(item)
img.putdata(new_data)
return img
# 第一步:将白背景转为透明背景
print("正在转换白背景为透明背景...")
for file_name in os.listdir(in_folder):
if file_name.lower().endswith((".png", ".jpg", ".jpeg")):
input_file_path = os.path.join(in_folder, file_name)
output_file_path = os.path.join(transparent_folder, file_name)
processed_image = process_image_to_transparent(input_file_path)
processed_image.save(output_file_path)
print(f"已处理: {file_name}")
print('------3、添加点状虚线轮廓-----')
def get_edge_pixels(image):
"""获取图像中不透明像素与透明像素交界的边缘像素坐标"""
edge_pixels = []
pixels = image.load()
width, height = image.size
for y in range(height):
for x in range(width):
if pixels[x, y][3] > 0: # 不透明像素
# 检查4邻域
for dx, dy in [(-1,0),(1,0),(0,-1),(0,1)]: