OpenCV快速入门:窗口交互

文章目录

  • 前言
  • 一、鼠标操作
    • 1.1 鼠标操作简介
    • 1.2 鼠标事件类型(event类型)
    • 1.3 鼠标事件标志(flags)
    • 1.4 代码示例
      • 1.4.1 获取鼠标坐标位置
      • 1.4.2 监听鼠标滚轮事件
      • 1.4.3 在图像中显示鼠标坐标
  • 二、键盘操作
    • 2.1 代码示例
    • 2.2 waitKey的等待方法
  • 三、添加窗口控件
    • 3.1 滑动条(Trackbar)的基本使用
    • 3.2 自定义滑动条回调函数
  • 四、实现鼠标跟随绘制方框的交互效果
    • 4.1 代码实现
    • 4.2 代码解析
    • 4.3 运行代码
  • 五、自由调节窗口图像的尺寸
    • 5.1 代码实现
    • 5.2 代码解释
    • 5.3 运行代码
  • 六、中文显示乱码问题
    • 6.1 实现步骤
    • 6.2 代码实现
  • 总结


前言

OpenCV是一种强大的计算机视觉库,广泛用于图像处理和计算机视觉应用。本文将介绍OpenCV中的窗口交互功能,重点关注鼠标和键盘的操作,以及如何添加窗口控件来实现更丰富的用户体验。
OpenCV Logo

一、鼠标操作

1.1 鼠标操作简介

OpenCV提供了丰富的鼠标交互功能,包括但不限于:

  • 获取鼠标的坐标位置
  • 监听鼠标点击事件
  • 监听鼠标滚轮事件

1.2 鼠标事件类型(event类型)

在OpenCV中,通过设置鼠标回调函数,我们可以处理各种鼠标事件。
以下是一些常见的鼠标事件类型:

  1. EVENT_LBUTTONDBLCLK(左键双击) = 7
  2. EVENT_LBUTTONDOWN(左键按下) = 1
  3. EVENT_LBUTTONUP(左键释放) = 4
  4. EVENT_MBUTTONDBLCLK(中键双击) = 9
  5. EVENT_MBUTTONDOWN(中键按下) = 3
  6. EVENT_MBUTTONUP(中键释放) = 6
  7. EVENT_MOUSEHWHEEL(鼠标横向滚轮滚动) = 11
  8. EVENT_MOUSEMOVE(鼠标移动) = 0
  9. EVENT_MOUSEWHEEL(鼠标滚轮滚动) = 10
  10. EVENT_RBUTTONDBLCLK(右键双击) = 8
  11. EVENT_RBUTTONDOWN(右键按下) = 2
  12. EVENT_RBUTTONUP(右键释放) = 5

1.3 鼠标事件标志(flags)

以下是一些常见的鼠标事件标志:

  1. EVENT_FLAG_ALTKEY(Alt键按下) = 32
  2. EVENT_FLAG_CTRLKEY(Ctrl键按下) = 8
  3. EVENT_FLAG_LBUTTON(左键按下) = 1
  4. EVENT_FLAG_MBUTTON(中键按下) = 4
  5. EVENT_FLAG_RBUTTON(右键按下) = 2
  6. EVENT_FLAG_SHIFTKEY(Shift键按下) = 16

通过设置鼠标回调函数,我们可以根据这些事件类型和标志来执行相应的操作。例如,在左键点击时执行某些操作,在鼠标移动时显示坐标信息,或者通过滚轮事件来放大或缩小图像。这为图像处理和计算机视觉应用提供了灵活的交互性。

1.4 代码示例

让我们看一个简单的例子,如何通过OpenCV获取鼠标的坐标位置:

import cv2def resize_image(factor):global imageheight, width = image.shape[:2]new_height = int(height * factor)new_width = int(width * factor)image = cv2.resize(image, (new_width, new_height))cv2.imshow("Image", image)def mouse_callback(event, x, y, flags, param):global imageif event == cv2.EVENT_LBUTTONDOWN:print(f"左键点击坐标:({x}, {y})")elif event == cv2.EVENT_RBUTTONDOWN:print(f"右键点击坐标:({x}, {y})")elif event == cv2.EVENT_MBUTTONDOWN:print(f"中键点击坐标:({x}, {y})")elif event == cv2.EVENT_MOUSEWHEEL:delta = flagsif delta > 0:  # 滚轮向上滚动,放大图像resize_image(1.1)elif delta < 0:  # 滚轮向下滚动,缩小图像resize_image(0.9)elif event == cv2.EVENT_MOUSEMOVE:# 在图像左上角显示坐标coord_text = f"({x}, {y})"image_copy = cv2.putText(image.copy(), coord_text, (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2)cv2.imshow("Image", image_copy)# 创建图像窗口
cv2.namedWindow("Image")
# 设置鼠标回调函数
cv2.setMouseCallback("Image", mouse_callback)
# 读取图像
image = cv2.imread("tulips.jpg")
# 在窗口中显示图像
cv2.imshow("Image", image.copy())
# 等待用户按下任意键退出
cv2.waitKey(0)
# 关闭窗口
cv2.destroyAllWindows()

tulips

在上述代码中,我们通过OpenCV实现了鼠标的各种操作,并结合了图像处理和显示的功能,让用户能够更直观地感受到鼠标事件的影响。

1.4.1 获取鼠标坐标位置

通过设置鼠标回调函数 cv2.setMouseCallback,我们可以监听鼠标的各种事件。在这个例子中,我们主要关注了鼠标左键、右键、中键的点击事件,以及鼠标的滚轮事件。当鼠标左键、右键、中键被点击时,我们在控制台输出了相应的坐标信息。

if event == cv2.EVENT_LBUTTONDOWN:print(f"左键点击坐标:({x}, {y})")
elif event == cv2.EVENT_RBUTTONDOWN:print(f"右键点击坐标:({x}, {y})")
elif event == cv2.EVENT_MBUTTONDOWN:print(f"中键点击坐标:({x}, {y})")

1.4.2 监听鼠标滚轮事件

通过监听鼠标滚轮事件,我们可以实现图像的放大和缩小。在这个例子中,当鼠标滚轮向上滚动时,图像放大1.1倍;当鼠标滚轮向下滚动时,图像缩小0.9倍。

elif event == cv2.EVENT_MOUSEWHEEL:delta = flagsif delta > 0:  # 滚轮向上滚动,放大图像resize_image(1.1)elif delta < 0:  # 滚轮向下滚动,缩小图像resize_image(0.9)

1.4.3 在图像中显示鼠标坐标

通过在图像上绘制文本,我们在图像左上角显示了当前鼠标的坐标位置。这使得用户可以实时了解鼠标相对于图像的位置。

elif event == cv2.EVENT_MOUSEMOVE:# 在图像左上角显示坐标coord_text = f"({x}, {y})"image_copy = cv2.putText(image.copy(), coord_text, (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2)cv2.imshow("Image", image_copy)

通过这些功能的组合,我们实现了一个简单而有趣的OpenCV窗口交互示例,展示了鼠标事件如何影响图像的显示和处理。这对于图像处理和计算机视觉应用中的交互性操作具有很大的实用性。

二、键盘操作

OpenCV不仅支持强大的图像处理功能,还提供了灵活的键盘交互功能,使得用户能够通过键盘来控制图像的显示和处理。我们将简要探讨waitKey的操作以及等待方法的使用。

2.1 代码示例

在OpenCV中,我们可以通过监听键盘按键事件来执行相应的操作。以下是一个简单的示例,演示了如何通过键盘按下事件来实现图像的放大和缩小:

import cv2def resize_image(factor):global imageheight, width = image.shape[:2]new_height = int(height * factor)new_width = int(width * factor)image = cv2.resize(image, (new_width, new_height))cv2.imshow("Image", image)# 读取图像
image = cv2.imread("tulips.jpg")# 创建图像窗口
cv2.namedWindow("Image")
cv2.imshow("Image", image)while True:key = cv2.waitKey(0)if key == ord('q'):  # 按下 'q' 键退出循环breakelif key == ord('+'):  # 按下 '+' 键放大图像resize_image(1.1)elif key == ord('-'):  # 按下 '-' 键缩小图像resize_image(0.9)
# 关闭窗口
cv2.destroyAllWindows()

在这个例子中,我们通过cv2.waitKey(0)监听键盘按键事件,ord函数将字符转换为对应的ASCII码。按下 ‘q’ 键退出循环,按下 ‘+’ 键放大图像,按下 ‘-’ 键缩小图像。这样,用户可以通过简单的键盘操作来改变图像的大小。
注:输入 'q' 时,需要在英文输入法的情况下按下。

2.2 waitKey的等待方法

cv2.waitKey方法不仅用于检测按键事件,还可以设置一个参数,表示等待时间(毫秒)。

# 等待1秒
cv2.waitKey(1000)
# 关闭窗口
cv2.destroyAllWindows()

通过这些简单而实用的键盘交互技巧,我们可以更灵活地控制OpenCV中图像的显示和处理,使得图像处理过程更加交互化。

三、添加窗口控件

在OpenCV中,通过添加窗口控件,我们可以实现更丰富的图形用户界面(GUI),使用户能够通过滑动条、按钮等控件与图像进行交互。这里将以滑动条为例,详细描述如何在OpenCV窗口中添加控件。

3.1 滑动条(Trackbar)的基本使用

滑动条是OpenCV中最常用的窗口控件之一,可以用于调整参数,比如图像的亮度、对比度等。以下是一个简单的例子,演示如何在OpenCV窗口中添加滑动条:

import cv2def on_trackbar_change(value):# 当滑动条数值改变时调用的回调函数print(f"滑动条数值:{value}")# 创建一个图像窗口
cv2.namedWindow("Image")# 创建一个滑动条,并指定其所属的窗口、滑动条的名称、最小值、最大值、回调函数
cv2.createTrackbar("Trackbar", "Image", 50, 100, on_trackbar_change)while True:# 等待用户按下任意键退出循环key = cv2.waitKey(1)if key != -1:break# 关闭窗口
cv2.destroyAllWindows()

在这个例子中,我们通过cv2.createTrackbar创建了一个名为 “Trackbar” 的滑动条,它隶属于名为 “Image” 的窗口,初始值为50,最小值为0,最大值为100。每次滑动条数值发生改变时,都会调用 on_trackbar_change 这个回调函数。

3.2 自定义滑动条回调函数

我们可以根据实际需求,自定义滑动条数值发生变化时的回调函数。例如,在滑动条变化时实时调整图像的亮度、对比度等参数,或者触发其他特定的操作。

import cv2def on_channel_change(value):global image# 获取各个滑动条的值brightness = cv2.getTrackbarPos("Brightness", "Image") - 50red = max(cv2.getTrackbarPos("Red", "Image") - 100, 0)green = max(cv2.getTrackbarPos("Green", "Image") - 100, 0)blue = max(cv2.getTrackbarPos("Blue", "Image") - 100, 0)# 调整图像的亮度和RGB通道adjusted_image = cv2.addWeighted(image, 1, image, 0, brightness)adjusted_image[:, :, 2] += redadjusted_image[:, :, 1] += greenadjusted_image[:, :, 0] += blue# 显示调整后的图像cv2.imshow("Image", adjusted_image)# 创建图像窗口
cv2.namedWindow("Image")# 创建滑动条,并指定窗口、滑动条名称、初始值、最大值、回调函数
cv2.createTrackbar("Brightness", "Image", 50, 100, on_channel_change)
cv2.createTrackbar("Red", "Image", 100, 200, on_channel_change)
cv2.createTrackbar("Green", "Image", 100, 200, on_channel_change)
cv2.createTrackbar("Blue", "Image", 100, 200, on_channel_change)# 读取图像
image = cv2.imread("tulips.jpg")# 在窗口中显示图像
cv2.imshow("Image", image)# 等待用户按下任意键退出
cv2.waitKey(0)# 关闭窗口
cv2.destroyAllWindows()

Trackbar

在这个例子中,on_channel_change 函数会在滑动条数值发生变化时被调用,根据数值的变化调整图像的亮度和颜色,并实时在窗口中显示调整后的图像。

通过这些示例,可以更好地理解如何在OpenCV中添加滑动条及其回调函数,从而实现图像处理中的交互操作。这提供了一种灵活的方式,使用户能够通过控件与图像进行动态交互。

四、实现鼠标跟随绘制方框的交互效果

在图像处理中,有时候需要手动标注或选择感兴趣区域。通过结合鼠标事件和按键处理,我们可以实现鼠标跟随绘制方框的交互效果。下面通过一个简单的例子详细介绍如何在OpenCV中实现这一功能。

4.1 代码实现

下面是一个简单的例子,通过OpenCV实现鼠标跟随绘制方框的功能。代码中还包含了撤销上一个框线的操作。

import cv2drawing = False
start_point = (-1, -1)
rectangles = []  # 存储绘制的框线信息的列表def mouse_callback(event, x, y, flags, param):global drawing, start_point# 检测Ctrl键状态ctrl_pressed = flags & cv2.EVENT_FLAG_CTRLKEY == cv2.EVENT_FLAG_CTRLKEYif event == cv2.EVENT_LBUTTONDOWN:drawing = Truestart_point = (x, y)elif event == cv2.EVENT_LBUTTONUP:drawing = Falseif ctrl_pressed:# 如果按下Ctrl键,画蓝色的框线cv2.rectangle(image, start_point, (x, y), (255, 0, 0), 2)rectangles.append(((start_point[0], start_point[1]), (x, y), (255, 0, 0)))else:# 否则,画绿色的框线cv2.rectangle(image, start_point, (x, y), (0, 255, 0), 2)rectangles.append(((start_point[0], start_point[1]), (x, y), (0, 255, 0)))cv2.imshow("Image", image)elif event == cv2.EVENT_MOUSEMOVE:# 清空图像image_temp = image.copy()# 灰色横线cv2.line(image_temp, (x, 0), (x, image.shape[0]), (127, 127, 127), 1, cv2.LINE_AA)# 灰色竖线cv2.line(image_temp, (0, y), (image.shape[1], y), (127, 127, 127), 1, cv2.LINE_AA)if drawing:# 根据Ctrl键状态画蓝色或绿色的框线if ctrl_pressed:cv2.rectangle(image_temp, start_point, (x, y), (255, 0, 0), 2)else:cv2.rectangle(image_temp, start_point, (x, y), (0, 255, 0), 2)cv2.imshow("Image", image_temp)def undo_last_rectangle():global rectangles, imageif rectangles:# 撤销上一个框线rectangles.pop()# 清空图像image = cv2.imread("tulips.jpg")# 重新绘制之前的所有框线for rect_info in rectangles:cv2.rectangle(image, rect_info[0], rect_info[1], rect_info[2], 2)cv2.imshow("Image", image)# 创建图像窗口
cv2.namedWindow("Image")# 设置鼠标回调函数
cv2.setMouseCallback("Image", mouse_callback)# 读取图像
image = cv2.imread("tulips.jpg")# 在窗口中显示图像
cv2.imshow("Image", image)while True:key = cv2.waitKey(0)if key == 27:  # 退出键breakelif key == ord('z') or key == ord('Z'):  # 按下Z键undo_last_rectangle()# 关闭窗口
cv2.destroyAllWindows()

4.2 代码解析

  1. 鼠标事件处理: mouse_callback 函数处理鼠标事件,包括鼠标按下、抬起和移动事件。在按下左键时,标记开始绘制;抬起左键时,停止绘制,并根据Ctrl键状态选择画绿色或蓝色框线;在移动过程中,显示灰色的辅助线。

  2. 撤销操作: undo_last_rectangle 函数用于撤销上一个绘制的框线。它会清空图像并重新绘制之前所有的框线。

  3. 主循环: 主循环监听键盘按键事件,按下 “Z” 键时执行撤销操作,按下 “ESC” 键时退出循环。

4.3 运行代码

在弹出的图像窗口中,可以通过鼠标绘制绿色或蓝色的框线,按下 “Z” 键撤销上一个框线,按下 “ESC” 键退出程序。

这个例子演示了如何结合鼠标事件和键盘事件,实现一个简单的交互式图像标注工具。我们可以根据实际需求扩展这个例子,添加更多的交互功能。

画框线

五、自由调节窗口图像的尺寸

在图像处理和计算机视觉应用中,有时候需要对图像窗口进行自由调节,以便更好地查看细节或全局图像。通过监听鼠标事件,我们可以实现自由调节窗口图像尺寸的效果。以下是一个使用OpenCV的简单例子,演示了如何通过鼠标事件实现窗口图像尺寸的自由调节。

5.1 代码实现

import cv2resizing = False
window_name = "Image"def mouse_callback(event, x, y, flags, param):global resizingif event == cv2.EVENT_LBUTTONDOWN:resizing = Trueelif event == cv2.EVENT_LBUTTONUP:resizing = Falseelif event == cv2.EVENT_MOUSEMOVE:if resizing:# 获取窗口的位置和大小rect = cv2.getWindowImageRect(window_name)win_x, win_y, win_width, win_height = rect# 判断鼠标是否在窗口的边缘if win_x < x < win_x + win_width and win_y < y < win_y + win_height:cv2.resizeWindow(window_name, x - win_x, y - win_y)# 创建图像窗口
cv2.namedWindow(window_name, cv2.WINDOW_NORMAL)# 设置鼠标回调函数
cv2.setMouseCallback(window_name, mouse_callback)# 读取图像
image = cv2.imread("tulips.jpg")# 在窗口中显示图像
cv2.imshow(window_name, image)# 设置窗口的初始大小为图像的大小
cv2.resizeWindow(window_name, image.shape[1], image.shape[0])# 等待用户按下任意键退出
cv2.waitKey(0)# 关闭窗口
cv2.destroyAllWindows()

5.2 代码解释

  1. 鼠标事件处理: mouse_callback 函数用于处理鼠标事件,包括按下左键、抬起左键和鼠标移动。当鼠标按下左键时,设置 resizing 为 True;当抬起左键时,设置 resizing 为 False。在鼠标移动过程中,如果 resizing 为 True,则获取窗口的位置和大小,并根据鼠标位置调整窗口大小。

  2. 创建图像窗口: 使用 cv2.namedWindow 创建一个图像窗口,并指定窗口名为 “Image”,设置窗口标志为 cv2.WINDOW_NORMAL,这样窗口大小可以被调整。

  3. 设置鼠标回调函数: 使用 cv2.setMouseCallback 设置鼠标回调函数,即上述的 mouse_callback 函数。

  4. 显示图像和设置初始窗口大小: 读取图像,使用 cv2.imshow 在窗口中显示图像,并通过 cv2.resizeWindow 设置窗口的初始大小为图像的大小。

5.3 运行代码

在弹出的图像窗口中,我们可以通过按下左键并拖动鼠标自由调节窗口的大小。这种交互式的窗口调节方式对于查看大尺寸图像或处理细节较多的图像非常有用。

调整窗口

六、中文显示乱码问题

在图像处理中,有时候我们需要在图像上显示中文字符。为了在OpenCV中实现中文显示,我们需要确保系统的字体支持中文。

6.1 实现步骤

  1. 创建一个空白图像
    首先,我们创建一个空白图像,以便后续在图像上添加中文字符。
import cv2
import numpy as np
from PIL import Image, ImageDraw, ImageFont# 创建一个空白图像
height, width, _ = 300, 500, 3
image = np.ones((height, width, 3), np.uint8) * 255
  1. 设置中文字体
    选择一个支持中文的字体,这里以宋体为例。我们需要替换 font_path 变量为本地系统中的字体文件路径,确保字体文件支持中文。
    如果没有字体文件,还需要自行下载字体文件。
# 设置中文字体
font_path = r"C:\Windows\Fonts\simsun.ttc"  # 替换为本地的字体文件路径
font_size = 30
font = ImageFont.truetype(font_path, font_size)
  1. 在图像上添加中文字符
    使用 PIL 库来在图像上添加中文字符。在这个例子中,我们添加了一个简单的中文字符 “你好,OpenCV!”。
# 在图像上添加中文字符
image_pil = Image.fromarray(image)
draw = ImageDraw.Draw(image_pil)
text = "你好,OpenCV!"
text_position = (50, 150)
text_color = (0, 0, 0)  # 黑色
draw.text(text_position, text, font=font, fill=text_color)
  1. 转换回OpenCV图像格式并显示
    PIL 图像格式转换回OpenCV格式,并通过OpenCV显示图像。
# 转换回OpenCV图像格式
image = np.array(image_pil)# 显示图像
cv2.imshow("Chinese Text", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

6.2 代码实现

以下是一个简单的例子,演示了如何在OpenCV中显示中文字符。

import cv2
import numpy as np
from PIL import Image, ImageDraw, ImageFont# 创建一个空白图像
height, width, _ = 300, 500, 3
image = np.ones((height, width, 3), np.uint8) * 255# 设置中文字体
font_path = r"C:\Windows\Fonts\simsun.ttc"  # 替换为本地的字体文件路径
font_size = 30
font = ImageFont.truetype(font_path, font_size)# 在图像上添加中文字符
image_pil = Image.fromarray(image)
draw = ImageDraw.Draw(image_pil)
text = "你好,OpenCV!"
text_position = (50, 150)
text_color = (0, 0, 0)  # 黑色
draw.text(text_position, text, font=font, fill=text_color)# 转换回OpenCV图像格式
image = np.array(image_pil)# 显示图像
cv2.imshow("Chinese Text", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

显示中文


总结

通过这篇文章,我们快速入门了OpenCV的窗口交互功能。从鼠标和键盘操作到窗口控件的添加,我们探索了多种交互方式,并通过实例演示了如何实现调整图像亮度和颜色、鼠标跟随绘制绿色框、自由调节窗口图像尺寸以及中文显示。
希望这些简单而实用的示例能够更好地理解和运用OpenCV的窗口交互功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/199923.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JS判断是否存在某个元素(includes、indexOf、find、findeIndex、some)(every 数组内所有值是否相同)

方法一&#xff1a;array.includes(searcElement[,fromIndex]) 此方法判断数组中是否存在某个值&#xff0c;如果存在返回true&#xff0c;否则返回false。 searchElement&#xff1a;需要查找的元素&#xff0c;必选。fromIndex&#xff1a;可选&#xff0c;从该索引处开始查…

SQLMAP --TAMPER的编写

跟着师傅的文章进行学习 sqlmap之tamper脚本编写_sqlmap tamper编写-CSDN博客 这里学习一下tamper的编写 这里的tamper 其实就是多个绕过waf的插件 通过编写tamper 我们可以学会 在不同过滤下 执行sql注入 我们首先了解一下 tamper的结构 这里我们首先看一个最简单的例子…

动捕设备如何推动线下活动以虚拟主持人创新升级互动形式

随着元宇宙概念兴起&#xff0c;虚拟主持人结合全身动捕设备可以依托大屏、全息等形式直观呈现于线下活动&#xff0c;通过动捕设备实时驱动虚拟主持人&#xff0c;将现实活动场景与虚拟相连接&#xff0c;让活动以科技感、多元化的形式呈现&#xff0c;给活动参与者一种新的视…

YOLOv8优化策略:轻量级Backbone改进 | VanillaNet极简神经网络模型 | 华为诺亚2023

🚀🚀🚀本文改进:一种极简的神经网络模型 VanillaNet,支持vanillanet_5, vanillanet_6, vanillanet_7, vanillanet_8, vanillanet_9, vanillanet_10, vanillanet_11等版本 🚀🚀🚀YOLOv8改进专栏:http://t.csdnimg.cn/hGhVK 学姐带你学习YOLOv8,从入门到创新,…

【自动驾驶解决方案】C++取整与保留小数位

一、C基础 1.1double型保留小数为&#xff0c;并以字符输出 #include <iostream> #include <sstream> #include <iomanip> // 包含std::fixedint main() {//浮点数double number 3.1415926;//转换工具类streamstd::stringstream stream;stream << s…

从入门到精通,mac电脑录屏软件使用教程!

“mac电脑怎么录屏呀&#xff0c;刚买了一台mac电脑&#xff0c;用了几个月感觉挺流畅的&#xff0c;最近因为工作原因&#xff0c;需要用到录屏功能&#xff0c;但是我不会操作&#xff0c;想问问大家有没有简单易懂的录屏教程&#xff0c;谢谢啦。” 在日常生活中&#xff0…

常见Web安全

一.Web安全概述 以下是百度百科对于web安全的解释&#xff1a; Web安全&#xff0c;计算机术语&#xff0c;随着Web2.0、社交网络、微博等等一系列新型的互联网产品的诞生&#xff0c;基于Web环境的互联网应用越来越广泛&#xff0c;企业信息化的过程中各种应用都架设在Web平台…

客户端性能优化实践

背景 双十一大促时&#xff0c;客户客服那边反馈商品信息加载卡顿&#xff0c;在不断有订单咨询时&#xff0c;甚至出现了商品信息一直处于加载状态的情况&#xff0c;显然&#xff0c;在这种高峰期接待客户时&#xff0c;是没法进行正常的接待工作的。 起初&#xff0c;页面一…

音视频技术在手机上的应用与挑战

// 编者按&#xff1a;随着手机相机功能日益强大&#xff0c;4k&#xff0c;8k&#xff0c;各类特色短视频的拍摄&#xff0c;编辑、播放需求日益增长&#xff0c;短视频应用的火爆也对当前的手机音视频技术提出了更高的要求&#xff0c;如何更好地提高用户体验成为了行业共同…

基于SpringBoot+Mybatis+layui的学生成绩管理系统

基于SpringBootMybatislayui的学生成绩管理系统 随着全球信息化的发展&#xff0c;人们的生活节奏越来越快&#xff0c;对信息的时效性越来越重视。以传统的宣传方式为载体的传统媒介早已不能满足用户对获取信息的方式、便捷性的需求。所以平时成绩管理系统渐渐成为用户关注的…

redis--高可用之持久化

redis高可用相关知识 在web服务器中&#xff0c;高可用是指服务器可以正常访问的时间&#xff0c;衡量的标准是在多长时间内可以提供正常服务(99.9%、99.99%、99.999%等等)。 但是在Redis语境中&#xff0c;高可用的含义似乎要宽泛一些&#xff0c;除了保证提供正常服务( 如主…

es的优势

系列文章目录 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 例如&#xff1a;第一章 Python 机器学习入门之pandas的使用 提示&#xff1a;写完文章后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目…

白鳝:聊聊IvorySQL的Oracle兼容技术细节与实现原理

两年前听瀚高的一个朋友说他们要做一个开源数据库项目&#xff0c;基于PostgreSQL&#xff0c;主打与Oracle的兼容性&#xff0c;并且与PG社区版内核同步发布。当时我听了有点不太相信&#xff0c;瀚高的Highgo是在PG内核上增加了一定的Oracle兼容性的特性&#xff0c;一般也会…

vue和uni-app的递归组件排坑

有这样一个数组数据&#xff0c;实际可能有很多级。 tree: [{id: 1,name: 1,children: [{ id: 2, name: 1-1, children: [{id: 7, name: 1-1-1,children: []}]},{ id: 3, name: 1-2 }]},{id: 4,name: 2,children: [{ id: 5, name: 2-1 },{ id: 6, name: 2-2 }]} ]要渲染为下面…

11.15 监控目录文件变化

监视对指定目录的更改&#xff0c;并将有关更改的信息打印到控制台&#xff0c;该功能的实现不仅可以在内核层&#xff0c;在应用层同样可以。程序中使用ReadDirectoryChangesW函数来监视目录中的更改&#xff0c;并使用FILE_NOTIFY_INFORMATION结构来获取有关更改的信息。 Re…

打破传统束缚,释放服务潜能:本地生活服务商聚合系统引领行业新风向!

本地生活服务商聚合系统是一种集合多平台、多项目的创新型服务系统&#xff0c;它打破了传统服务商系统的一对一限制&#xff0c;为创业者和运营商带来了诸多优势。小多将深入探讨本地生活服务商聚合系统的优势。 随着互联网的快速发展&#xff0c;本地生活服务也迎来了蓬勃的发…

ESP32 http 请求

目录 参考教程1.使用的http连接2.使用Vscode-IDF创建http_request例程3.修改http_request_example_main.c函数4.已经获取到响应的数据 参考教程 ESP-IDF HTTP获取网络时间 1.使用的http连接 http://api.m.taobao.com/rest/api3.do?apimtop.common.getTimestamp请求可以得到…

Qt http

文章目录 前言1. 定义的接口2.connect信号槽3. get4. get 下载文件5. post 总结 前言 /* 1.请求报文&#xff1a; 请求报文是由客户端发送给服务器&#xff0c;用于请求特定资源或执行特定操作。它由以下几个部分组成&#xff1a; 请求行&#xff1a;描述了请求的方法、目标资源…

7-tcp 三次握手和四次挥手、osi七层协议,哪七层,每层有哪些?tcp和udp的区别?udp用在哪里了?

1 tcp 三次握手和四次挥手 2 osi七层协议&#xff0c;哪七层&#xff0c;每层有哪些 3 tcp和udp的区别&#xff1f;udp用在哪里了&#xff1f; 1 tcp 三次握手和四次挥手 # tcp协议---》处于osi7层协议的传输层&#xff0c;可靠连接&#xff0c;使用三次握手&#xff0c;四次挥…

Linux 安装多版本 JDK 详细过程

背景说明 服务器已安装jdk1.8,但随着spring全家桶的升级换代&#xff0c;已不满足使用&#xff0c;先要用高版本jdk&#xff0c;暂时不想卸载旧的版本&#xff0c;故安装两个版本&#xff0c;jdk1.8和jdk17,jdk1.8的已经安装过了&#xff0c;所以此次只安装jdk17,以及配置jdk切…