当前位置: 首页 > news >正文

网站需要访客上传图片该怎么做网页设计html代码大全

网站需要访客上传图片该怎么做,网页设计html代码大全,工业设计就业方向及就业前景,wordpress语言插件响应鼠标事件 3. 响应鼠标事件3.1 获取鼠标点击的坐标3.2 获取鼠标点击像素点的颜色3.3 在鼠标点击的位置生成圆3.4 通过拖动鼠标来绘制填充矩形3.5 通过拖动鼠标绘制未填充矩形3.6 使用鼠标选点绘制多边形3.7 按住鼠标左键进行绘图 3. 响应鼠标事件 使用OpenCV读取图像&#…

响应鼠标事件

    • 3. 响应鼠标事件
      • 3.1 获取鼠标点击的坐标
      • 3.2 获取鼠标点击像素点的颜色
      • 3.3 在鼠标点击的位置生成圆
      • 3.4 通过拖动鼠标来绘制填充矩形
      • 3.5 通过拖动鼠标绘制未填充矩形
      • 3.6 使用鼠标选点绘制多边形
      • 3.7 按住鼠标左键进行绘图

3. 响应鼠标事件

使用OpenCV读取图像,可以在读取图像的窗口通过鼠标点击可以实现:获取鼠标点击像素点的坐标、获取鼠标点击像素点的颜色和在鼠标点击的像素点生成圆等等。

# 对窗口的鼠标动作做出回应
cv2.setMouseCallback(winname, callback, userdata)
  • winname:窗口的名字
  • callback:回调函数
  • userdata:给回调函数的参数
# 鼠标回调函数,传入到callback参数上去
def mouse_callback(event, x, y, flags, userdata)
  • enent:鼠标事件
  • x:横坐标
  • y:纵坐标
  • flags:事件组合
  • userdata:与cv2.setMouseCallback中的userdata对应,用于传参
鼠标事件event对应
EVENT_MOUSEMOVE鼠标移动
EVENT_LBUTTONDOWN按下鼠标左键
EVENT_RBUTTONDOWN按下鼠标右键
EVENT_LBUTTONUP左键释放
EVENT_RBUTTONUP右键释放
EVENT_LBUTTONDBLCLK左键双击
EVENT_RBUTTONDBLCLK右键双击

3.1 获取鼠标点击的坐标

import cv2
import numpy as np# 回调函数:鼠标点击输出点击的坐标
# (事件(鼠标移动、左键、右键),横坐标,纵坐标,组合键,setMouseCallback的userdata用于传参)
def mouse_callback(event, x, y, flags, userdata):# 如果鼠标左键点击,则输出横坐标和纵坐标if event == cv2.EVENT_LBUTTONDOWN:print(f'({x}, {y})')# 在图像上绘制点cv2.circle(img, (x, y), 3, (0, 0, 255), -1)# 在图像上添加坐标文本# (图像,文本内容,坐标点,字体类型,字体大小,颜色,字体粗细)cv2.putText(img, f'({x},{y})', (x, y),cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255), 2)# 获取指定像素点的颜色pixel_color = img[x, y]print("颜色值BGR:", pixel_color)img = cv2.imread('lena.jpg')# 创建窗口
cv2.namedWindow('Point Coordinates')# 将回调函数绑定到窗口
cv2.setMouseCallback('Point Coordinates', mouse_callback)# 显示图像
while True:cv2.imshow('Point Coordinates', img)k = cv2.waitKey(1) & 0xFF# 按esc键退出if k == 27:break
cv2.destroyAllWindows()

3.2 获取鼠标点击像素点的颜色

# 获取指定像素点的颜色
pixel_color = img[x, y]
print("颜色值BGR:", pixel_color)

请添加图片描述

3.3 在鼠标点击的位置生成圆

import cv2img = cv2.imread('lena.jpg')# 回调函数:鼠标点击输出点击的坐标
# (事件(鼠标移动、左键、右键),横坐标,纵坐标,组合键,setMouseCallback的userdata用于传参)
def mouse_callback(event, x, y, flags, userdata):# 如果鼠标左键点击,则输出横坐标和纵坐标if event == cv2.EVENT_LBUTTONDOWN:print(f'({x}, {y})')# 在图像上绘制圆cv2.circle(img, (x, y), 100, (0, 0, 255), -1)# 创建新窗口
cv2.namedWindow('mouse')# 将回调函数绑定在mouse窗口
cv2.setMouseCallback('mouse', mouse_callback)while True:cv2.imshow('mouse', img)k = cv2.waitKey(1) & 0xFF# 按esc键退出if k == 27:break
cv2.destroyAllWindows()

请添加图片描述

3.4 通过拖动鼠标来绘制填充矩形

在用QQ截图的时候,会有绘制矩形框的选项,使用OpenCV来进行模拟

思路:

  1. 鼠标左键点击开始进行绘制
  2. 鼠标未拖动则生成圆点
  3. 鼠标拖动则绘制矩形
  4. 最后在图像上生成矩形框

可用到的event事件:

  • EVENT_LBUTTONDOWN:按下鼠标左键
  • EVENT_MOUSEMOVE:鼠标移动
  • EVENT_LBUTTONUP:左键释放
import cv2
import numpy as npimg = cv2.imread('lena.jpg')drawing = False # 如果按下鼠标,则为真
start_x, start_y = -1, -1# 回调函数:鼠标点击输出点击的坐标
# (事件(鼠标移动、左键、右键),横坐标,纵坐标,组合键,setMouseCallback的userdata用于传参)
def mouse_callback(event, x, y, flags, userdata):global start_x, start_y, drawing# 鼠标左键单击if event == cv2.EVENT_LBUTTONDOWN:drawing = Truestart_x, start_y = x, y# 鼠标移动elif event == cv2.EVENT_MOUSEMOVE:if drawing == True:cv2.rectangle(img, (start_x, start_y), (x, y), (0, 0, 255), -1)# 鼠标左键松开elif event == cv2.EVENT_LBUTTONUP:drawing = False# 创建新窗口
cv2.namedWindow('mouse')# 将回调函数绑定在mouse窗口
cv2.setMouseCallback('mouse', mouse_callback)while True:cv2.imshow('mouse', img)k = cv2.waitKey(1) & 0xFF# 按esc键退出if k == 27:break
cv2.destroyAllWindows()

请添加图片描述

3.5 通过拖动鼠标绘制未填充矩形

import cv2
import numpy as npimg = cv2.imread('lena.jpg')drawing = False # 如果按下鼠标,则为真
start_x, start_y = -1, -1# 回调函数:鼠标点击输出点击的坐标
# (事件(鼠标移动、左键、右键),横坐标,纵坐标,组合键,setMouseCallback的userdata用于传参)
def mouse_callback(event, x, y, flags, userdata):global start_x, start_y, drawing# 鼠标左键单击if event == cv2.EVENT_LBUTTONDOWN:drawing = Truestart_x, start_y = x, y# 鼠标移动elif event == cv2.EVENT_MOUSEMOVE:pass# 鼠标左键松开elif event == cv2.EVENT_LBUTTONUP:drawing = Falsecv2.rectangle(img, (start_x, start_y), (x, y), (0, 0, 255), 3)# 创建新窗口
cv2.namedWindow('mouse')# 将回调函数绑定在mouse窗口
cv2.setMouseCallback('mouse', mouse_callback)while True:cv2.imshow('mouse', img)k = cv2.waitKey(1) & 0xFF# 按esc键退出if k == 27:break
cv2.destroyAllWindows()

请添加图片描述

3.6 使用鼠标选点绘制多边形

import cv2
import numpy as npimg = cv2.imread('lena.jpg')xys = []# 回调函数:鼠标点击输出点击的坐标
# (事件(鼠标移动、左键、右键),横坐标,纵坐标,组合键,setMouseCallback的userdata用于传参)
def mouse_callback(event, x, y, flags, userdata):global xys, img# 鼠标左键单击if event == cv2.EVENT_LBUTTONDOWN:xys.append([x, y])cv2.circle(img, (x, y), 5, (0, 0, 255), -1)# 鼠标右键单击elif event == cv2.EVENT_RBUTTONDOWN:pts = np.array(xys, np.int32)# 画多条线:(图像,点集合,是否闭合,颜色,粗细)cv2.polylines(img, [pts], True, (0, 0, 0), 2)xys = []# 创建新窗口
cv2.namedWindow('mouse')# 将回调函数绑定在mouse窗口
cv2.setMouseCallback('mouse', mouse_callback)while True:cv2.imshow('mouse', img)k = cv2.waitKey(1) & 0xFF# 按esc键退出if k == 27:break
cv2.destroyAllWindows()

按照鼠标选点的先后位置绘制多边形
请添加图片描述
如果相同选点,但顺序不同,绘制的图像也不同
请添加图片描述

3.7 按住鼠标左键进行绘图

可以想象成绘图工具中的橡皮擦操作

import cv2
import numpy as npimg = cv2.imread('lena.jpg')drawing = False # 按下鼠标左键响应# 回调函数:鼠标点击输出点击的坐标
# (事件(鼠标移动、左键、右键),横坐标,纵坐标,组合键,setMouseCallback的userdata用于传参)
def mouse_callback(event, x, y, flags, userdata):global drawing# 鼠标左键单击if event == cv2.EVENT_LBUTTONDOWN:drawing = True# 鼠标移动elif event == cv2.EVENT_MOUSEMOVE:if drawing == True:cv2.circle(img, (x, y), 5, (255, 255, 255), -1)# 鼠标左键释放elif event == cv2.EVENT_LBUTTONUP:drawing = False# 创建新窗口
cv2.namedWindow('mouse')# 将回调函数绑定在mouse窗口
cv2.setMouseCallback('mouse', mouse_callback)while True:cv2.imshow('mouse', img)k = cv2.waitKey(1) & 0xFF# 按esc键退出if k == 27:break
cv2.destroyAllWindows()

请添加图片描述

http://www.yayakq.cn/news/24022/

相关文章:

  • 浏览器的网站17.zwd一起做网站
  • 个人主页经典句子济南网站优化建设
  • 在线视频网站 一级做爰片抖音开放平台登录入口官网
  • 做内网网站个域名的网站建设方案书
  • 长沙的在线商城网站建设郑州seo技术博客
  • 全屏网站设计wordpress怎么安装主题
  • 网站备案需要哪些东西网站侧边栏
  • 西安建设和住房保障局网站首页源码网站制作教程
  • 张掖市网站建设wordpress机械展示
  • 网站建设的费用计什么科目天津河西做网站贵吗
  • phpwind做的网站便宜网站建设公司哪家好
  • 南京网站建设企业微信公众号设计与布局
  • 商标被注册了做网站个人淘宝客网站备案
  • 微网站备案可以做h5游戏的网站
  • 网站建设工作分解结构词典面试学校网站开发
  • 怎样增加网站反向链接汶上1500元网站建设
  • 华为商城网站设计分析网站制作公司有没有版权
  • 重庆网站建设 制作 设计 优惠价网站添加搜索关键字
  • 网站图片多大网站开发维护前景
  • 网站模版怎么做wordpress 个性博客主题
  • 做特产网站的原因官方网站面膜做代理
  • 免费html5中文网站素材闵行网络推广
  • 山东建设厅网站首页美团代运营
  • seo关键词排名优化联系方式登封seo公司
  • 淘宝网站的建设与运营设计思路一级消防工程师考试难吗
  • 如何让我的网站被百度收录空间怎么做网站
  • 常州建设局建筑职称网站小企业网站建设多少钱
  • 郑州网站建设哪家便宜郑州网站推广多少钱
  • 找一个免费的网站网站公司注册流程
  • 海南住房和城乡建设网站手机单页网站生成系统