10.31OpenCV作业

实现图片中划线并保存

python 复制代码
import cv2

def draw_test(event,x,y,flag,param):
    global drawing
    # cv2.EVENT_LBUTTONDOWN  鼠键左键按下事件
    if event == cv2.EVENT_LBUTTONDOWN:
        drawing = True
    # cv2.EVENT_MOUSEMOVE  鼠键左键移动事件
    elif event == cv2.EVENT_MOUSEMOVE:
        if drawing:
            cv2.circle(img,(x,y),15,(255,0,0),-1)

    #cv2.EVENT_LBUTTONUP  鼠键左键释放事件
    elif event == cv2.EVENT_LBUTTONUP:
        drawing = False
        cv2.circle(img, (x, y), 15, (255, 0, 0), -1)

img= cv2.imread('images/car.png')
cv2.namedWindow('image')

cv2.setMouseCallback('image', draw_test)
# 真正的标志,表示是否正在绘制
drawing = False
while(True):
    cv2.imshow('image', img)
    if cv2.waitKey(20) == 115:
        rs = cv2.imwrite("save_image/car1.png", img)
    if cv2.waitKey(20) == 27:  # 按ESC退出
        break
cv2.destroyAllWindows()

实现摄像头捕捉和文本显示且鼠标点击文本中的数字加一

python 复制代码
import cv2
from PIL import Image, ImageDraw, ImageFont
import numpy as np

def put_text(image, text, position, font_path, font_size, color):
    pil_image = Image.fromarray(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
    draw = ImageDraw.Draw(pil_image)
    font = ImageFont.truetype(font_path, font_size)
    draw.text(position, text, fill=color, font=font)
    image_with_text = cv2.cvtColor(np.array(pil_image), cv2.COLOR_RGB2BGR)
    return image_with_text

cap = cv2.VideoCapture(0)
cv2.namedWindow("name", cv2.WINDOW_NORMAL)
cv2.resizeWindow("name", 500, 300)

rocket_count = 0

def draw_test(event, x, y, flags, param):
    global rocket_count
    if event == cv2.EVENT_LBUTTONDOWN:
        rocket_count += 1

cv2.setMouseCallback("name", draw_test)

while True:
    ret, frame = cap.read()
    if ret:
        text = f"老铁们,火箭刷起来,你已刷个{rocket_count}火箭"
        position = (0, 50)
        font_path = "simhei.ttf"
        font_size = 25

        color = (255, 0, 0)
        frame = put_text(frame, text, position, font_path, font_size, color)

        cv2.imshow("name", frame)

    if cv2.waitKey(20) == 27:
        break

cap.release()
cv2.destroyAllWindows()
相关推荐
永远都不秃头的程序员(互关)几秒前
零基础掌握AI:实战机器学习全流程
人工智能·机器学习
神算大模型APi--天枢6465 分钟前
从异构调度到边缘部署:国产大模型算力平台的后端开发能力拆解
大数据·人工智能·科技·架构·硬件架构
minhuan5 分钟前
大模型应用:完整语音交互闭环:TTS+ASR融合系统可视化场景实践.22
人工智能·语音识别·tts·asr·语音大模型应用
song5019 分钟前
鸿蒙 Flutter 日志系统:分级日志与鸿蒙 Hilog 集成
图像处理·人工智能·分布式·flutter·华为
Mintopia9 分钟前
🚀 AIGC 如何重塑 Web 内容生产的价值链 —— 一场“硅基文艺复兴”的技术变革
人工智能·aigc·全栈
拉姆哥的小屋16 分钟前
从原子到性能:机器学习如何重塑双金属催化剂的设计范式
人工智能·python·算法·机器学习
sponge'18 分钟前
opencv学习笔记13:U-Net
人工智能·深度学习·机器学习
Evand J19 分钟前
【MATLAB例程】自适应阈值的小波变换去噪,信号噪声:拉普拉斯噪声、脉冲噪声与高斯噪声|混合非高斯。附下载链接
开发语言·人工智能·matlab
skywalk816327 分钟前
openi启智社区提供大模型在线体验功能
人工智能
秋刀鱼 ..28 分钟前
第五届遥感与测绘国际学术会议(RSSM 2026)
大数据·运维·人工智能·机器人·自动化