iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >【Python图像线条坐标提取】
  • 863
分享到

【Python图像线条坐标提取】

python人工智能计算机视觉 2023-09-06 12:09:22 863人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

问题描述: 在进行图像处理时,有时需要对图像上的坐标点进行提取,然后进行曲线拟合,如下图,但是提取的xy坐标会有许多重复的值,影响曲线拟合效果。这里提供三种方法,其它的方法大家可以自行补充。 warn

问题描述:

在进行图像处理时,有时需要对图像上的坐标点进行提取,然后进行曲线拟合,如下图,但是提取的xy坐标会有许多重复的值,影响曲线拟合效果。这里提供三种方法,其它的方法大家可以自行补充。

warn:函数传入的图像是二值化之后的图像,像素只有0和255,如何二值化自行百度。

在这里插入图片描述

1:直接提取黑色的所有点坐标,该方法显而易见,会存在很多重复的x坐标,直接上代码:

def extract_line_position(image):       # 提取坐标,存在bug,会重复提取x的值    list_y = []    list_x = []    # 存储值为0的行号和列号        for i in range(len(image)):        for j in range(len(image[i])):            if image[i][j] == 0:                list_x.append(j)                list_y.append(len(image) - i)    return list_x, list_y

可以看见重复坐标太多,曲线拟合效果并不好

2 直接提取曲线的上边缘坐标,该方法,在曲线较粗或垂直向下时会失真,但是适用于现在的场景,代码如下:

def get_line_position(image):    list_x = []    list_y = []    # y_len = len(image)    # print(y_len)    for i in range(len(image[0])):    #  遍历列数        for j in range(len(image)):   # 遍历行数            if image[j][i] == 0:                list_x.append(i)                list_y.append(len(image)-j)                break    return list_x,list_y

效果还不错

3: 提取曲线上边缘与下边缘的中值来获取位置坐标,代码:

def get_lineMedium_position(image):    image = np.delete(image, 0, axis=0)  # 删除第一行    image = np.delete(image, 0, axis=1)  # 删除第一列    list_x = []    list_y = []    start_index = 0    end_index = 0    for i in range(len(image[0])):  # 遍历列数        for j in range(len(image)-1):  # 遍历行数            if image[j][i] == 255 and image[j+1][i] == 0:                start_index = j                continue            if image[j][i] == 0 and image[j+1][i] == 255:                end_index = j                y_position = (start_index + end_index)/2                list_x.append(i)                list_y.append(len(image) - y_position)                start_index = 0                end_index = 0                break    return list_x, list_y

这里就不上图了,效果挺不错的,不用对曲线进行细化,节省时间,但是要根据实际情况使用。

最后整理了一个类,供大家使用:

import numpy as npimport matplotlib.pyplot as pltplt.rcParams['font.sans-serif'] = ['SimHei']  # 显示中文plt.rcParams['axes.unicode_minus'] = False  # 正常显示负号"""December 16, 2022,LuoNicus获取曲线分割后的图像点坐标类用不同的方法获取坐标只可提取像素 0 or 255,提取其它自行修改正常提取,上边缘提取,中值提取,各有优缺,根据实际情况使用""""""   图像像素示意    [[255,255, 255, 0,   0]     [0,   0,  255, 0,   0]     [0,   0,  255, 0,   0]     [0,   0,  255, 255,255]]     """class Get_Line_Positon:    def __init__(self, image):        self.image = image        self.list_x = []        self.list_y = []        print("已获取图像信息,准备提取二值图像位置坐标")    def by_allline_point(self):  # 提取坐标,存在bug,会重复提取x的值        # 细化算法存在bug,第一行和第一列为0黑色,不合理,因此首先去掉        print("warn:常规算法提取,容易出现多个x为相同值")        self.image = np.delete(self.image, 0, axis=0)  # 删除第一行        self.image = np.delete(self.image, 0, axis=1)  # 删除第一列        for i in range(len(self.image)):            for j in range(len(self.image[i])):                if self.image[i][j] == 0:                    # print(mask[i][j],j,i)                    self.list_x.append(j)                    self.list_y.append(len(self.image) - i)        return self.list_x, self.list_y    def by_upline_point(self):  # 提取直线坐标,提取曲线的边缘坐标,避免出现x的重复值        print("提取曲线上边缘的值")        self.image = np.delete(self.image, 0, axis=0)  # 删除第一行        self.image = np.delete(self.image, 0, axis=1)  # 删除第一列        # y_len = len(self.image)        # print(y_len)        for i in range(len(self.image[0])):  # 遍历列数            for j in range(len(self.image)):  # 遍历行数                if self.image[j][i] == 0:                    self.list_x.append(i)                    self.list_y.append(len(self.image) - j)                    break        return self.list_x, self.list_y    def by_lineMedium_point(self):  # 提取像素上下值的中位数坐标,该方法不用对函数进行细化        print("提取曲线的中值")        self.image = np.delete(self.image, 0, axis=0)  # 删除第一行        self.image = np.delete(self.image, 0, axis=1)  # 删除第一列        start_index = 0        end_index = 0        for i in range(len(self.image[0])):  # 遍历列数            for j in range(len(self.image) - 1):  # 遍历行数                if self.image[j][i] == 255 and self.image[j + 1][i] == 0:                    start_index = j                    continue                if self.image[j][i] == 0 and self.image[j + 1][i] == 255:                    end_index = j                    y_position = (start_index + end_index) / 2                    self.list_x.append(i)                    self.list_y.append(len(self.image) - y_position)                    start_index = 0                    end_index = 0                    break        return self.list_x, self.list_y

欢迎补充!!

来源地址:https://blog.csdn.net/weixin_49594201/article/details/128343729

--结束END--

本文标题: 【Python图像线条坐标提取】

本文链接: https://www.lsjlt.com/news/397007.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 【Python图像线条坐标提取】
    问题描述: 在进行图像处理时,有时需要对图像上的坐标点进行提取,然后进行曲线拟合,如下图,但是提取的xy坐标会有许多重复的值,影响曲线拟合效果。这里提供三种方法,其它的方法大家可以自行补充。 warn...
    99+
    2023-09-06
    python 人工智能 计算机视觉
  • Python从图像中提取文本及其坐标
    Python从图像中提取文本及其坐标 在数字化时代,文本数据已经成为人们生活和工作中重要的数据形式。有时候我们需要从图片中提取文字信息,这就要用到Python编程语言中OCR技术的应用了。本文将介绍如...
    99+
    2023-09-06
    python 数学建模 开发语言
  • Python如何获取图像中像素点坐标
    这篇“Python如何获取图像中像素点坐标”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python如何获取图像中像素点坐标...
    99+
    2023-06-30
  • matlab如何精确提取图像点的坐标
    在MATLAB中,可以使用以下方法精确提取图像点的坐标:1. 使用`ginput`函数:该函数允许用户从图像中选择点,并返回所选点的...
    99+
    2023-09-14
    matlab
  • matlab怎么获取图像坐标
    要获取图像的坐标,可以使用MATLAB中的impoint函数。impoint函数创建一个交互式点的对象,可以在图像上点击鼠标获取点的...
    99+
    2023-08-31
    matlab
  • Python获取图像中像素点坐标实例代码
    在图片处理过程中,有时候我们想要确定图片中某一像素的坐标,可以通过下面方法得到。点击运行程序,用鼠标点击我们想要获取坐标的区域,即可获得其坐标。结束方式是,敲击键盘“q&...
    99+
    2024-04-02
  • 【Python&GIS】无人机影像的像素坐标计算图片某点的地理/投影坐标
            又是掉头发的一天,今天的任务是通过图片中心点的地理坐标以及图片中某点的像素坐标(即这个点位于图片中的x,y坐标)计算该点的地理/投影坐标。经过一整天的搜索,发现网上并没有这方面的教程。然后就是想啊想,头发一抓一大把,终于...
    99+
    2023-09-03
    数学建模 python 经验分享 图像处理 计算机视觉
  • jquery怎么获取图片坐标
    使用jquery获取图片坐标的方法:1.新建html项目,引入jquery;2.使用img标签添加图片;3.添加button按钮,绑定onclick点击事件;4.通过标签名获取图片对象,使用e.pageX和e.pageY方法获取坐标;具体步...
    99+
    2024-04-02
  • python 求直线交点坐标
    参考:http://blog.csdn.net/abcjennifer/article/details/7584628 # -*- coding: utf-8 -*- class Point(object): x =0 ...
    99+
    2023-01-31
    交点 坐标 直线
  • K210摄像头矩形图坐标识别
    我接触的第一个硬件项目是设计一个简陋的智能视觉小车,我在项目里的任务是识别一张纸上六个目标点坐标然后发送给小车。 图一  场地样式 就是将上图六个点的坐标识别然后传输给小车。 识别效果大概是这样:  图二 识别效果 因为是第一次做这样...
    99+
    2023-08-31
    ide python
  • Python鼠标事件及坐标获取窗口和屏幕坐标
    目录效果如下:分析:重写关闭事件重写上下文菜单事件重写自带的绘制事件 也就是自定义重新实现调整窗口大小事件重新实现鼠标的释放事件重新实现鼠标的移动事件重新实现鼠标双击事件重新实现键盘...
    99+
    2024-04-02
  • 如何在Matlab中将图像从笛卡尔坐标更改为极坐标
    要将图像从笛卡尔坐标更改为极坐标,您可以使用Matlab中的polarplot函数。以下是一个简单的示例代码,展示了如何实现这一操作...
    99+
    2023-09-26
    Matlab
  • python如何获取鼠标点击坐标
    在Python中,可以使用`pyautogui`库来获取鼠标点击坐标。下面是一个示例代码:```pythonimport pyaut...
    99+
    2023-08-24
    python
  • matlab画图只有坐标没有图像如何解决
    如果在MATLAB中只有坐标没有图像,可能是由于以下几个原因导致的:1. 没有使用plot函数进行绘图:在MATLAB中,要绘制图像...
    99+
    2023-09-14
    matlab
  • python用opencv将标注提取画框到对应的图像中
    目录前言相应的思路读取前缀列表找出json结构中对应框坐标位置,画出对应的框前言 问题需求: 拥有两个文件夹,一个保存图片image,一个保存标签文件,要求把标签文件中的标注提取出来...
    99+
    2024-04-02
  • python获取软件窗口的坐标
     1.话不多说直接上源码再逐行解释 import win32gui# 获取窗口句柄hwnd = win32gui.FindWindow(None, '窗口标题')# 获取窗口左上角坐标和右下角坐标left, top, right, bott...
    99+
    2023-09-21
    windows python
  • python中的opencv 图像分割与提取
    目录图像分割与提取用分水岭算法实现图像分割与提取算法原理相关函数介绍分水岭算法图像分割实例交互式前景提取图像分割与提取 图像中将前景对象作为目标图像分割或者提取出来。对背景本身并无兴...
    99+
    2024-04-02
  • 在 Python 中从图像中提取表格
    从图像中提取表格可能是一项乏味且耗时的任务,尤其是当您有大量图像需要处理时。但是,使用正确的工具和技术,您可以自动化此过程并快速轻松地从图像中提取表格。 在本文中,我们将探讨如何使用 Python 从...
    99+
    2023-09-05
    python opencv 开发语言
  • excel里折线图的横坐标怎样设置
    在Excel中,折线图的横坐标通常表示数据的分类或时间。横坐标的设置取决于数据类型和展示需求。以下是设置折线图横坐标的一些常见方法:...
    99+
    2023-09-15
    excel
  • 用python绘制极坐标雷达图
    目录综述绘图代码和解析绘制一张多主体雷达图绘制多张单主体雷达图总结综述 python的matplotlib画图库的功能非常强大,可以画很多很多种图,我们日常生活中遇到的雷达图也不例外...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作