python如何批量将图片转成线稿图?
网友回复
有三种不同的方法,从最简单经典的方法到更具艺术感的方法。
首先,请确保您已经安装了必要的库。如果尚未安装,请打开终端或命令提示符运行:
pip install opencv-python numpy matplotlib
opencv-python: 核心的图像处理库。
numpy: OpenCV 依赖它进行高效的数组运算。
matplotlib: 用于方便地在脚本中展示处理前后的图片。
方法一:经典边缘检测法 (Canny Edge Detection)
这是最基础、最直接的方法。它的原理是找出图像中亮度变化剧烈的区域,即“边缘”,然后将这些边缘以线条的形式呈现。
核心步骤:
读取图片并转为灰度图:边缘检测不关心颜色,只关心亮度变化。
高斯模糊去噪:减少图像中的噪点,防止算法将噪点误判为边缘。
Canny 边缘检测:应用 Canny 算法提取出轮廓线。
颜色反转:Canny 算法默认生成的是“白线黑底”的图,我们需要反转成“黑线白底”才符合线稿的习惯。
代码实现:
import cv2 import matplotlib.pyplot as plt def image_to_canny_line_art(image_path): """ 使用 Canny 边缘检测将图片转换为线稿图。 """ # 1. 读取图片并转为灰度图 img = cv2.imread(image_path) gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 2. 高斯模糊去噪 # (kernel_size, sigmaX),kernel_size 必须是奇数 blurred_img = cv2.GaussianBlur(gray_img, (5, 5), 0) # 3. Canny 边缘检测 # threshold1 和 threshold2 是阈值,可以调整以改变细节程度 # 较低的阈值会检测到更多、更细微的边缘 edges = cv2.Canny(blurred_img, threshold1=50, threshold2=150) # 4. 颜色反转 (黑底白线 -> 白底黑线) line_art = cv2.bitwise_not(edges) return img, line_art # --- 主程序 --- if __name__ == '__main__': input_image_path = 'your_image.jpg' # <--- 在这里替换成你的图片路径 original, canny_result = image_to_canny_line_art(input_image_path) # 使用 Matplotlib 展示结果 plt.figure(figsize=(10, 5)) # 显示原图 (注意 OpenCV BGR -> Matplotlib RGB) plt.subplot(1, 2, 1) plt.imshow(cv2.cvtColor(original, cv2.COLOR_BGR2RGB)) plt.title('Original Image') plt.axis('off') # 显示线稿图 plt.subplot(1, 2, 2) plt.imshow(canny_result, cmap='gray') plt.title('Canny Line Art') plt.axis('off') plt.tight_layout() plt.show() # 如果想保存图片 # cv2.imwrite('line_art_canny.jpg', canny_result)
效果:线条干净、清晰,但可能缺少一些艺术感和明暗过渡。
方法二:艺术素描法 (Dodge and Burn)
这种方法模拟了摄影暗房中的“减淡与加深”技术,能够创造出更像手绘...
点击查看剩余70%