opencv-python使用鼠标点击图片显示该点坐标和像素值&&IPM逆透视变换车道线

OpenCV的鼠标操作

实现获取像素点的功能主要基于OpenCV的内置函数cv2.setMouseCallback(),即鼠标事件回调

setMouseCallback(winname, onMouse,userdata=0)

winname: 接收鼠标事件的窗口名称

onMouse: 处理鼠标事件的回调函数指针

userdata: 传给回调函数的用户数据

代码实现:鼠标点击图片时,读取当前鼠标对应位置的像素值(顺序为BGR),在鼠标所在位置的左上角显示当前坐标值和像素值;鼠标移动时,旧的文本框消失

复制代码
import cv2
import numpy as np

img = cv2.imread('./158.jpg')#读取图片
font_face,font_scale,thickness=cv2.FONT_HERSHEY_SIMPLEX,0.5,1
#鼠标交互
def mouseHandler(event,x,y,flags,param):
    points = (x,y)
    global imgCopy
    #鼠标左键双击事件
    if event == cv2.EVENT_LBUTTONDBLCLK:
    	#输出坐标
        print(x,y)
        #拷贝一张与原图像格式相同的新图像
        imgCopy = img.copy()
        #拼接文字
        text = '['+str(x)+','+str(y)+']'+str(img[x,y])
        #读取文字(宽,高),下基线
        (t_w,t_h),baseLine = cv2.getTextSize(text,font_face,font_scale,thickness)
        #在鼠标当前位置的左上角显示文字
        cv2.putText(imgCopy,text,(x-t_w,y),font_face,font_scale,(125,125,125))
        cv2.imshow('win',imgCopy)
    #鼠标移动事件
    elif event == cv2.EVENT_MOUSEMOVE:
    	#显示原图片能使文本框消失
        cv2.imshow('win',img)

cv2.namedWindow('win')
#窗口与回调函数绑定
cv2.setMouseCallback('win',mouseHandler)
cv2.imshow('win',img)
cv2.waitKey()

IPM代码:

复制代码
import cv2  
import numpy as np  
  
def multi_transform(img, pts1):  
  
    ROI_HEIGHT = 30000  
    ROI_WIDTH = 3750  
  
    # 设定逆透视图的宽度  
    IPM_WIDTH = 500  
    N = 5  
  
    # 保证逆透视图的宽度大概为N个车头宽  
    sacale=(IPM_WIDTH/N)/ROI_WIDTH  
    IPM_HEIGHT=ROI_HEIGHT*sacale  
  
    pts2 = np.float32([[IPM_WIDTH/2-IPM_WIDTH/(2*N), 0],  
                       [IPM_WIDTH/2+IPM_WIDTH/(2*N), 0],  
                       [IPM_WIDTH/2-IPM_WIDTH/(2*N), IPM_HEIGHT],  
                       [IPM_WIDTH/2+IPM_WIDTH/(2*N), IPM_HEIGHT]])  
  
    print(IPM_HEIGHT,IPM_WIDTH)  
  
    matrix = cv2.getPerspectiveTransform(pts1, pts2)  
    output = cv2.warpPerspective(img, matrix, (int(IPM_WIDTH),int(IPM_HEIGHT+50)))  
  
    for i in range(0, 4):  
        cv2.circle(img, (pts1[i][0], pts1[i][1]), 6, (0, 0, 255), cv2.FILLED)  
  
    for i in range(0,4):  
        cv2.circle(output, (pts2[i][0], pts2[i][1]),6, (0, 0, 255), cv2.FILLED)  
  
    # p1 = (0, 250)  
    # p2 = (img.shape[1], img.shape[0]-100)  
    # point_color = (255, 0, 0)  
    # cv2.rectangle(img, p1, p2, point_color, 2)  
    cv2.imshow("src image", img)  
    cv2.imshow("output image", output)  
  
    cv2.imwrite("output.jpg", output)  # 新增的代码,将处理后的图像保存为 "output.jpg"  
    cv2.waitKey(0)  
  
if __name__ == '__main__':  
    # 图像1  
    img = cv2.imread("./158.jpg")  
    pts1 = np.float32([[543, 462],       # p1  
                       [749, 466],       # p2  
                       [277, 536],       # p3  
                       [937, 546]])      # p4  
  
    # 图像2  
    # img = cv2.imread("./789.jpeg")  
    # pts1 = np.float32([[243, 189],       # p1  
    #                    [383, 186],       # p2  
    #                    [77, 253],       # p3  
    #                    [533, 253]])      # p4  
  
    multi_transform(img, pts1)

原图:

效果图:

相关推荐
freewlt4 分钟前
科技热点速递:AI技术集中爆发
人工智能·深度学习·计算机视觉
驕傲的兎孒4 分钟前
基于 SpringBoot + Vue3 + AI 打造企业级售后服务支持平台 | 实战方案分享
人工智能·spring boot·后端
vx-程序开发4 分钟前
springboot在线装修管理系统-计算机毕业设计源码56278
java·c语言·spring boot·python·spring·django·php
guoji77885 分钟前
2026年AI编程辅助实战:国内镜像站如何使用Claude提升开发效率?
人工智能·ai编程
程序猿炎义5 分钟前
Agent Skills入门 - Datawhale共学
人工智能
大傻^8 分钟前
Spring AI Alibaba 可观测性实践:AI应用监控与链路追踪
java·人工智能·后端·spring·springaialibaba
星辰yzy9 分钟前
AI 聚合 Token 平台怎么选?我为什么开始长期使用 jige.io
人工智能·语言模型
视***间9 分钟前
京聚全球智,算力观新程——视程空间赴2026北京国际人工智能应用与机器人创新博览会
大数据·人工智能·机器人·边缘计算·ai算力开发板
云烟成雨TD13 分钟前
Spring AI Alibaba 1.x 系列【1】阿里巴巴 AI 生态
java·人工智能·spring
进击的雷神20 分钟前
主办方过滤、展位号模糊提取、多层级官网爬取、缅文编码解码——缅甸塑料展爬虫四大技术难关攻克纪实
网络·爬虫·python