Opencv图片的旋转和图片的模板匹配

图片的旋转和图片的模板匹配

目录

  • 图片的旋转和图片的模板匹配
    • [1 图片的旋转](#1 图片的旋转)
      • [1.1 numpy旋转](#1.1 numpy旋转)
        • [1.1.1 函数](#1.1.1 函数)
        • [1.1.2 测试](#1.1.2 测试)
      • [1.2 opencv旋转](#1.2 opencv旋转)
        • [1.2.1 函数](#1.2.1 函数)
        • [1.2.2 测试](#1.2.2 测试)
    • [2 图片的模板匹配](#2 图片的模板匹配)
      • [2.1 函数](#2.1 函数)
      • [2.2 实际测试](#2.2 实际测试)

1 图片的旋转


1.1 numpy旋转

1.1.1 函数
  • np.rot90(kl,k=1),k=1逆时针旋转90度,kl为图片
  • np.rot90(kl,k=-1),k=-1顺时针旋转90度,kl为图片
1.1.2 测试

图片

代码展示:

python 复制代码
import numpy as np
kl = cv2.imread('kl.jpg')
kl_rot901 = np.rot90(kl,k=1)
kl_rot90_1 =np.rot90(kl,k=-1)
cv2.imshow('kl',kl)
cv2.waitKey(0)
cv2.imshow('kl_rot901',kl_rot901)
cv2.waitKey(0)
cv2.imshow('kl_rot90_1',kl_rot90_1)
cv2.waitKey(0)

运行结果:

1.2 opencv旋转

1.2.1 函数
  • cv2.rotate(kl,cv2.ROTATE_90_CLOCKWISE),顺时针90度
  • cv2.rotate(kl,cv2.ROTATE_90_COUNTERCLOCKWISE),逆时针90度
  • cv2.rotate(kl,cv2.ROTATE_180),180度
1.2.2 测试

代码展示:

python 复制代码
import cv2
kl = cv2.imread('kl.jpg')
kl_ROTATE_90_CLOCKWISE = cv2.rotate(kl,cv2.ROTATE_90_CLOCKWISE)
kl_ROTATE_180 = cv2.rotate(kl,cv2.ROTATE_180)
kl_ROTATE_90_COUNTERCLOCKWISE = cv2.rotate(kl,cv2.ROTATE_90_COUNTERCLOCKWISE)
cv2.imshow('kl',kl)
cv2.waitKey(0)
cv2.imshow('kl_ROTATE_90_COUNTERCLOCKWISE',kl_ROTATE_90_COUNTERCLOCKWISE)
cv2.waitKey(0)
cv2.imshow('kl_ROTATE_90_CLOCKWISE',kl_ROTATE_90_CLOCKWISE)
cv2.waitKey(0)
cv2.imshow('kl_ROTATE_180',kl_ROTATE_180)
cv2.waitKey(0)

运行结果:

2 图片的模板匹配

2.1 函数

  • re=cv2.matchTemplate(kl,bt,cv2.TM_CCOEFF),进行匹配
  • min_val,max_val,min_loc,max_loc = cv2.minMaxLoc(re) ,匹配得分和坐标
    • min_val最小得分,max_val,最大得分
    • min_loc,最小得分坐标,max_loc,最大得分坐标(x,y)=(max_loc[0],max_loc[1])

2.2 实际测试

图片

代码展示:

python 复制代码
import cv2
bt = cv2.imread('bt.png')
kl = cv2.imread('kl.png')
h,w = bt.shape[:2]
re = cv2.matchTemplate(kl,bt,cv2.TM_CCOEFF)
min_val,max_val,min_loc,max_loc = cv2.minMaxLoc(re)
tp_left = max_loc
bt_right = (tp_left[0]+w, tp_left[1]+h)
kl_copy = kl.copy()
kl_bt = cv2.rectangle(kl_copy,tp_left,bt_right,(255,0,0),2)
cv2.imshow('bt',bt)
cv2.waitKey(0)
cv2.imshow('kl',kl)
cv2.waitKey(0)
cv2.imshow('kl_bt',kl_bt)
cv2.waitKey(0)

运行结果:

相关推荐
一切皆是因缘际会5 小时前
从概率拟合到内生心智:2026 下一代 AI 架构演进与落地实践
人工智能·深度学习·算法·架构
科研前沿5 小时前
镜像视界 CameraGraph™+多智能体:构建自感知自决策的全域空间认知网络技术方案
大数据·运维·人工智能·数码相机·计算机视觉
爱学习的张大5 小时前
具身智能论文问答(2):Diffusion Policy
人工智能
AI科技星5 小时前
全域数学·72分册·射影原本 无穷维射影几何卷细化子目录【乖乖数学】
人工智能·线性代数·算法·机器学习·数学建模·数据挖掘·量子计算
Chef_Chen5 小时前
论文解读:MemOS首次把记忆变成大模型的一等公民资源,Scaling Law迎来第三条曲线
人工智能·agent·memory
风落无尘6 小时前
《智能重生:从垃圾堆到AI工程师》——第四章 变化的艺术
人工智能·线性代数·算法
七颗糖很甜6 小时前
电离层对地基雷达测量精度的影响分析与校正方法
python
发哥来了6 小时前
AI视频生成模型选型指南:五大核心维度对比评测
大数据·人工智能·机器学习·ai·aigc
发哥来了6 小时前
AI驱动生产线的实际落地:一个东莞厂商的技术选型实录
大数据·人工智能·机器学习·ai·aigc
AC赳赳老秦6 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw