用python实现 将输入的骨架化的图像进行曲线拟合 批量图片输入和批量图片保存

时间: 2024-05-15 13:19:42 浏览: 14
实现思路: 1. 读取输入的骨架化图像; 2. 对图像进行二值化处理; 3. 用OpenCV中的findContours函数找到图像中的轮廓; 4. 对每个轮廓进行曲线拟合; 5. 将拟合后的曲线绘制在一张空白图像上; 6. 将拟合后的曲线绘制在原图像上,形成拟合后的图像; 7. 将拟合后的图像保存。 代码实现: ```python import cv2 import numpy as np import os def curve_fitting(image_path, save_path): # 读取输入的骨架化图像 img = cv2.imread(image_path, 0) # 对图像进行二值化处理 ret, thresh = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY) # 用findContours函数找到图像中的轮廓 contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE) # 创建一张空白图像 blank_img = np.zeros((img.shape[0], img.shape[1], 3), np.uint8) # 对每个轮廓进行曲线拟合 for i in range(len(contours)): cnt = contours[i] if len(cnt) > 10: # 对轮廓进行多项式拟合,拟合出3次曲线 x, y = cnt[:, 0, 0], cnt[:, 0, 1] z = np.polyfit(x, y, 3) p = np.poly1d(z) x_new = np.linspace(x[0], x[-1], 100) y_new = p(x_new) # 将拟合后的曲线绘制在一张空白图像上 for j in range(len(x_new)): cv2.circle(blank_img, (int(x_new[j]), int(y_new[j])), 1, (255, 255, 255), -1) # 将拟合后的曲线绘制在原图像上,形成拟合后的图像 cv2.polylines(img, [np.int32(np.column_stack((x_new, y_new)))], False, (255, 255, 255), 1) # 将拟合后的图像保存 cv2.imwrite(save_path, img) if __name__ == '__main__': # 批量图片输入和批量图片保存 input_folder = './input_folder/' output_folder = './output_folder/' for image_name in os.listdir(input_folder): image_path = input_folder + image_name save_path = output_folder + image_name curve_fitting(image_path, save_path) ``` 使用说明: 1. 将需要处理的骨架化图像放在input_folder文件夹下; 2. 运行上述代码,即可得到拟合后的图像,并保存在output_folder文件夹下。

相关推荐

最新推荐

recommend-type

python实现批量处理将图片粘贴到另一张图片上并保存

今天小编就为大家分享一篇python实现批量处理将图片粘贴到另一张图片上并保存,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Python批量将图片灰度化的实现代码

主要介绍了Python批量将图片灰度化的实现代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

Python实现图片批量加入水印代码实例

主要介绍了Python实现图片批量加入水印代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

python实现批量按比例缩放图片效果

主要为大家详细介绍了python实现批量按比例缩放图片效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

python实现图片批量压缩程序

使用方法: 在Pycharm的terminal中输入”python xxx.py source_dir dest_dir”就可以把source_dir中的图片文件进行压缩并保存到dest_dir中 源码 from PIL import Image import os import sys # 定义可以识别的图片...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

hive中 的Metastore

Hive中的Metastore是一个关键的组件,它用于存储和管理Hive中的元数据。这些元数据包括表名、列名、表的数据类型、分区信息、表的存储位置等信息。Hive的查询和分析都需要Metastore来管理和访问这些元数据。 Metastore可以使用不同的后端存储来存储元数据,例如MySQL、PostgreSQL、Oracle等关系型数据库,或者Hadoop分布式文件系统中的HDFS。Metastore还提供了API,使得开发人员可以通过编程方式访问元数据。 Metastore的另一个重要功能是跟踪表的版本和历史。当用户对表进行更改时,Metastore会记录这些更改,并且可以让用户回滚到
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。