+
57
-

python如何批量将图片转成线稿图?

python如何批量将图片转成线稿图?

800_auto

800_auto


网友回复

+
5
-

有三种不同的方法,从最简单经典的方法到更具艺术感的方法。

首先,请确保您已经安装了必要的库。如果尚未安装,请打开终端或命令提示符运行:

pip install opencv-python numpy matplotlib

opencv-python: 核心的图像处理库。

numpy: OpenCV 依赖它进行高效的数组运算。

matplotlib: 用于方便地在脚本中展示处理前后的图片。

方法一:经典边缘检测法 (Canny Edge Detection)

这是最基础、最直接的方法。它的原理是找出图像中亮度变化剧烈的区域,即“边缘”,然后将这些边缘以线条的形式呈现。

核心步骤:

读取图片并转为灰度图:边缘检测不关心颜色,只关心亮度变化。

高斯模糊去噪:减少图像中的噪点,防止算法将噪点误判为边缘。

Canny 边缘检测:应用 Canny 算法提取出轮廓线。

800_auto

颜色反转: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%

我知道答案,我要回答