OpenCV图像的基本操作

图像的基本操作(Python)

素材图

P1:die.jpg

在这里插入图片描述

P2:cool.jpg

在这里插入图片描述

V:rabbit.mp4, 下载地址

在这里插入图片描述

读取展示-图像

import cv2img_1 = cv2.imread('./die.jpg')  # default cv2.IMREAD_COLOR
print("die.jpg shape(imread default) : ", img_1.shape)  # 展示图像信息 (行,列,颜色通道数)(h,w,c)
cv2.imshow("die default", img_1)img_2 = cv2.imread('./die.jpg', cv2.IMREAD_GRAYSCALE)  # 指定为灰度图
print("die.jpg shape(imread gray) : ", img_2.shape)  # 展示图像信息 (行,列,颜色通道数)(h,w,c)
cv2.imshow("die gray", img_2)
cv2.imwrite("./grayscale.jpg", img_2)  # 保存图像信息img_3 = cv2.imread('./cool.jpg')  # default cv2.IMREAD_COLOR
print("cool.jpg shape(imread default) : ", img_3.shape)  # 展示图像信息 (行,列,颜色通道数)(h,w,c)
cv2.imshow("cool default", img_3)cv2.waitKey(0)  # 单位是毫秒
cv2.destroyAllWindows()  # 释放所有窗口

在这里插入图片描述

cv2.imshow()

原型:cv2.imshow(winname, mat)

参数:

  • winname(窗口名称): 字符串,表示显示窗口的名称。
  • mat(图像矩阵): 要显示的图像矩阵,通常是一个NumPy数组。

返回值:

功能:

cv2.imshow 主要是用于显示图像,而不是播放视频。**当你使用 cv2.imshow 显示视频帧时,它只会显示当前帧,并不会按照视频的原速度播放。**你需要在代码中通过循环读取视频的帧,并将每一帧传递给 cv2.imshow,以模拟视频的播放效果。

注意: 如果两次imshow的winname相同的话,那将自动关闭前一个窗口。

cv2.waitKey()

原型:cv2.waitKey([delay])

参数:

  • delay(延迟时间): 表示等待时间的毫秒数,如果设置为0,表示无限等待用户输入。默认值是0。

返回值:

  • 返回按键的 ASCII 值(整数)。如果没有按键被按下,返回-1。

功能:

  • 等待用户按下键盘上的按键。
  • 在指定的延迟时间内等待用户输入,然后继续执行程序。

cv2.destroyAllWindows()

原型:cv2.destroyAllWindows()

参数:

返回值:

功能:

  • 关闭所有通过 cv2.namedWindow()cv2.imshow() 创建的窗口。通常在程序执行的最后调用这个函数,以确保在程序结束时关闭所有图形界面窗口,防止它们在程序退出后仍然保留。

cv2.imread()

原型:cv2.imread(filename [,flags])

参数:

  • filename(文件名): 要读取的图像文件的路径。
  • flags(标志): 可选参数,表示如何读取图像。默认值是 cv2.IMREAD_COLOR,表示以彩色图像的形式读取。可以使用以下常量:
    • cv2.IMREAD_COLOR: 以彩色图像形式读取(默认值),注:OpenCV读取的图像是BGR格式,而非RGB
    • cv2.IMREAD_GRAYSCALE: 以灰度图像形式读取。
    • cv2.IMREAD_UNCHANGED: 读取包括 alpha 通道在内的所有图像信息。

返回值:

  • 读取的图像数据,以 NumPy 数组的形式表示。

功能:

  • 读取指定路径下的图像文件,并将其加载到一个 NumPy 数组中,以便在程序中进行处理和分析。

cv2.imwrite()

原型: cv2.imwrite(filename, img [,params])

参数:

  • filename(文件名): 要写入的目标文件的路径。
  • img(图像数据): 要写入文件的图像数据,通常是一个 NumPy 数组。
  • params(可选参数): 写入文件时的附加参数。可以指定图像质量、压缩格式等。

返回值:

  • 如果成功写入文件,则返回 True;否则返回 False

功能:

  • 将图像数据写入指定的文件。

读取展示-视频

import cv2# 打开视频文件
cap = cv2.VideoCapture('./rabbit.mp4')# 检查视频是否成功打开
if not cap.isOpened():print("Error: 无法打开视频文件.")opn = 0
else:opn = 1while opn:# 读取视频帧ret, frame = cap.read()# 检查是否成功读取帧(视频播放完成退出)if not ret:print("Error: 无法读取帧.")break# 转换为灰度帧gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)# 在窗口中显示帧cv2.imshow('Video Player', gray)# 检查用户是否按下了 'q' 键,如果是则退出循环if cv2.waitKey(25) & 0xFF == 27:break# 释放资源
cap.release()
cv2.destroyAllWindows()

在这里插入图片描述

cv2.VideoCapture()

原型:cv2.VideoCapture([filename or index, apiPreference])

参数:

  • filename(可选): 视频文件的路径。
  • index(可选): 摄像头设备的索引号,用于选择要使用的摄像头。通常从0开始递增。
  • apiPreference(可选): 指定视频捕获 API 的首选项。可以是 cv2.CAP_ANYcv2.CAP_V4L2cv2.CAP_FFMPEG 等。

功能:

  • 打开一个视频文件、摄像头或其他图像来源,准备读取帧。
  • 提供方法用于从视频源中读取帧,获取视频的参数等信息。

返回值:

  • VideoCapture 对象:一个用于从视频源读取帧的对象。下面介绍该对象常用属性:

    1. read()

      • 读取视频的下一帧。
      • 返回一个布尔值 ret,表示帧是否成功读取,以及帧的图像数据frame(视频帧的 NumPy 数组)。
      ret, frame = cap.read()
      
    2. get(propId)

      • 获取视频的属性值,例如帧的宽度、高度、帧速率等。
      • propId 是用于指定要获取的属性的标识符。
      width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
      height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
      
    3. set(propId, value)

      • 设置视频的属性值,例如帧的宽度、高度、帧速率等。
      • propId 是用于指定要设置的属性的标识符,value 是要设置的属性值。
      cap.set(cv2.CAP_PROP_FRAME_WIDTH, 640)
      cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 480)
      
    4. release()

      • 释放 VideoCapture 对象占用的资源,关闭视频源。
      cap.release()
      
    5. isOpened()

      • 检查 VideoCapture 对象是否成功打开了视频源。
      if not cap.isOpened():print("Error: Could not open video source.")
      

cv2.cvtColor()

原型:cv2.cvtColor(src, code)

参数:

  • src(源图像): 要进行颜色空间转换的输入图像,通常是一个 NumPy 数组。
  • code(颜色空间转换代码): 指定颜色空间转换的方式,如 cv2.COLOR_BGR2GRAY 表示将 BGR 彩色图转换为灰度图。
  • 还有两个可选参数,用于设置输出图像的尺寸、深度、通道数,这里不进行介绍。

返回值:

  • 转换后的图像,仍是一个 NumPy 数组。

功能:

  • 将输入图像从一个颜色空间转换到另一个颜色空间。

其他:(关于code的其他可选项)

  1. BGR 转灰度:cv2.COLOR_BGR2GRAY
  2. BGR 转HSV:cv2.COLOR_BGR2HSV
  3. BGR 转RGB:cv2.COLOR_BGR2RGB
  4. 灰度转BGR:cv2.COLOR_GRAY2BGR
  5. RGB 转BGR:cv2.COLOR_RGB2BGR

ROI(感兴趣的范围——裁剪)

图像数据的表示方式:

用 “:” 表示区间(左闭右开)

import cv2
img = cv2.imread('./die.jpg')
print(img.shape)  #(40, 240, 3)# 取三维矩阵的前一行、前两列、深度为all
print(img[0:1, 0:2], "\n")
# [[[40 39 83]     [[[BGR][BGR]  ]  ]
#   [39 38 82]]]   三维 —— 图像(r * w) * BGR(h = 3)# 取三维矩阵的前一行、前两列、深度为0
print(img[0:1, 0:2, 0], "\n")
# [[40 39]]      二维 (r * w)  仅显示BGR其中之一(B)print(img[0:1, 0:2, 1], "\n")
# [[39 38]]        仅显示(G)print(img[0:1, 0:2, 2], "\n")
# [[83 82]]        仅显示(R)

查看图像指定区域(imshow时可实现裁剪效果):

import cv2
img = cv2.imread('./die.jpg')
print(img.shape)cv2.imshow("image", img)
cv2.imshow("cut", img[50:150, 0:200])cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

提取/合并 图像的R、G、B

import cv2img = cv2.imread('./die.jpg')# 提取   如果直接show相当于灰度图像,把颜色值当作亮度
img_B = img[:, :, 0]
img_G = img[:, :, 1]
img_R = img[:, :, 2]
# 合并   合并时要注意维度保持一致
img_T = cv2.merge((img_B, img_G, img_R))

在这里插入图片描述

置空通道 (e.g只保留R通道)

import cv2img = cv2.imread('./die.jpg')img_T = img.copy()img_T[:, :, 0] = 0  # 置空 B 通道
img_T[:, :, 1] = 1  # 置空 G 通道cv2.imshow("img_T", img_T)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

cv2.merge()

原型:cv2.merge(mv[, dst])

参数:

  • mv:包含要合并的图像通道的序列(例如,一个包含三个通道的元组或列表)。
  • dst:输出图像,可选。

返回值:

如果指定了 dst 参数,则返回输出图像 dst;否则,返回合并后的图像。

功能:

cv2.merge 函数用于将多个单通道的图像合并成一个多通道的图像。通常,在图像处理中,图像被拆分为单个通道进行处理,然后再合并回来。mv 参数是一个包含要合并的图像通道的序列,通常是一个包含多个单通道图像的元组或列表。在合并时要注意每个通道的尺寸和数据类型保持一致,并注意通道的顺序。

关于dst参数

手动指定 dst 和使用返回值接收的主要区别在于对输出图像的处理和内存管理

手动指定 dst

  • 如果你手动指定了 dst,则你需要提前创建一个多通道的数组,用于存储合并后的结果。这样可以避免在函数内部创建新的数组,有助于更好地控制内存的分配和释放。
  • 通过手动指定 dst,你可以在函数调用之后继续使用这个数组,而不需要将它的内容复制到其他数组中。

使用返回值接收:

  • 如果你使用返回值接收合并后的结果,那么函数会在内部创建一个新的多通道数组,并将合并后的图像存储在其中。这个新数组将作为函数的返回值返回。
  • 使用返回值接收合并后的图像时,你不需要提前创建输出数组,但需要注意新数组的内存管理。你可能需要确保及时释放不再需要的内存,以避免内存泄漏。

在实际应用中,选择手动指定 dst 还是使用返回值接收通常取决于对内存和代码结构的特定需求。如果你有特定的内存管理需求或者想要更好地控制输出数组的生命周期,那么手动指定 dst 可能更为合适。否则,使用返回值接收通常更为简便。

缩放&融合

import cv2img1 = cv2.imread('./die.jpg')
img2 = cv2.imread('./cool.jpg')# 两张图片尺寸不一致不能进行计算(融合)
print(img1.shape)  # (240, 240, 3)
print(img2.shape)  # (1000, 1000, 3)img2_T = cv2.resize(img2, (240, 240))res = cv2.addWeighted(img1, 0.4, img2_T, 0.6, 0)cv2.imshow("blend", res)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

按缩放因子进行scale

import cv2img = cv2.imread('./die.jpg')
print(img.shape)  # (240, 240, 3)# 将y坐标拉伸2倍数,x不变
img_T = cv2.resize(img, (0, 0), fx=1, fy=2)
print(img.shape)  # (240, 240, 3)cv2.imshow("img", img)
cv2.imshow("scale", img_T)
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

cv2.resize()

原型:cv2.resize(src, dsize[, dst[, fx[, fy[, interpolation]]]])

参数:

  • src: 输入图像。

  • dsize: 输出图像的大小,可以是元组 (width, height) 或者 None

  • dst: 输出图像,可选。

  • fx: 沿水平轴的缩放因子,可选。

  • fy: 沿垂直轴的缩放因子,可选。

  • interpolation: 插值方法,用于图像的缩放。默认为 cv2.INTER_LINEAR

    常见的插值方法包括:

    • cv2.INTER_NEAREST: 最近邻插值
    • cv2.INTER_LINEAR: 线性插值(默认)
    • cv2.INTER_CUBIC: 三次样条插值
    • cv2.INTER_AREA: 区域插值

返回值:

  • 返回缩放后的图像。

功能:

  • 该函数用于调整图像大小,可以进行放大或缩小。可以通过指定输出图像的大小 (dsize) 或者缩放因子 (fx, fy) 来控制缩放的程度

cv2.addWeighted()

函数原型:cv2.addWeighted(src1, alpha, src2, beta, gamma[, dst[, dtype]])

参数:

  • src1:第一个输入图像。
  • alphasrc1 的权重。
  • src2:第二个输入图像。
  • betasrc2 的权重。
  • gamma:添加到每个和的标量值,用于调整输出图像的亮度。
  • dst:输出图像,可选。
  • dtype:输出图像的数据类型,可选。

返回值:

  • 如果指定了 dst 参数,则返回输出图像 dst;否则,返回合并后的新图像。

功能:

  • cv2.addWeighted 函数用于将两个图像线性组合,即按照一定的权重相加。具体而言,它的计算公式为:

d s t = s r c 1 × a l p h a + s r c 2 × b e t a + g a m m a dst=src1×alpha+src2×beta+gamma dst=src1×alpha+src2×beta+gamma

  • 这个函数在图像混合、图像融合、对比度调整等方面非常有用。例如,可以使用 cv2.addWeighted 将两个图像按照一定的比例融合,调整图像的对比度和亮度。

数值计算

cv2.add()

img1 = img1 + 5   # 每个像素值都增加了5
imgT = img2 + img1  # img1 的每个像素值都与相应位置上的 img2 的像素值相加# 因为每个值都是uint8,所以可能会出现越界溢出的情况(%256)
# cv2.add()  可以实现饱和截断(溢出时会保持在255)
cv2.add(img1,img2)

matplotlib.pyplot绘制子图

import cv2
import matplotlib.pyplot as plt
import numpy as np                # 暂时没用到# 读取图像
img1 = cv2.imread('./die.jpg')
img2 = cv2.imread('./grayscale.jpg')
img3 = cv2.imread('./cool.jpg')# 使用Matplotlib显示不同边界填充方式的图像(221: 2*2的网格的第1个位置)
plt.subplot(221), plt.imshow(img1), plt.title('die')
plt.subplot(222), plt.imshow(img2), plt.title('grayscale')
plt.subplot(223), plt.imshow(img3), plt.title('cool')plt.show()
cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

边界填充

import cv2
import matplotlib.pyplot as plt
import numpy as np                # 暂时没用到# 读取图像
img = cv2.imread('./die.jpg')# 定义上、下、左、右填充的大小
top_size, bottom_size, left_size, right_size = (70, 70, 70, 70)# 使用不同的边界填充方式生成新的图像
replicate = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, borderType=cv2.BORDER_REPLICATE)
reflect = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_REFLECT)
reflect101 = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_REFLECT_101)
wrap = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_WRAP)
constant = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_CONSTANT, value=0)# 使用Matplotlib显示不同边界填充方式的图像(231: 2*3的网格的第1个位置)
plt.subplot(231), plt.imshow(img), plt.title('ORIGINAL')
plt.subplot(232), plt.imshow(replicate), plt.title('REPLICATE')
plt.subplot(233), plt.imshow(reflect), plt.title('REFLECT')
plt.subplot(234), plt.imshow(reflect101), plt.title('REFLECT_101')
plt.subplot(235), plt.imshow(wrap), plt.title('WRAP')
plt.subplot(236), plt.imshow(constant), plt.title('CONSTANT')# 显示图像
plt.show()# 关闭所有OpenCV窗口
cv2.destroyAllWindows()

在这里插入图片描述

cv2.copyMakeBorder()

函数原型:cv2.copyMakeBorder(src, top, bottom, left, right, borderType[, dst[, value]])

参数:

  • src:输入图像。
  • topbottomleftright:指定在每个边界添加的像素数。
  • borderType
    • BORDER_REPLICATE:复制法,也就是复制最边缘像素。
    • BORDER_REFLECT:反射法,对感兴趣的图像中的像素在两边进行复制例如:fedcba|abcdefgh|hgfedcb
    • BORDER_REFLECT_101:反射法,也就是以最边缘像素为轴,对称,gfedcb|abcdefgh|gfedcba
    • BORDER_WRAP:外包装法cdefgh|abcdefgh|abcdefg
    • BORDER_CONSTANT:常量法,常数值填充。
  • dst:输出图像,可选。
  • value:当 borderTypecv2.BORDER_CONSTANT 时使用的边界常数。

返回值:

  • 如果指定了 dst 参数,则返回输出图像 dst;否则,返回添加边界后的新图像。

功能:

  • cv2.copyMakeBorder 函数用于在图像的四个边界上添加边界。你可以指定要添加的像素数以及边界的类型。不同的 borderType 选项会导致不同的边界填充方式。

  • 这个函数在图像处理中常用于图像扩展、填充以及处理边界条件的情况,例如在进行卷积运算时。

      

Numpy

.shape

shapeNumPy 数组的一个属性。在 NumPy 中,shape 用于获取数组的维度信息。

示例:array.shape

返回值:

  • 一个元组(tuple),表示数组的维度。

功能:

  • 提供数组的维度信息,以元组的形式返回。
  • 对于二维数组,返回的元组包含两个元素,表示行数和列数;对于三维数组,包含三个元素,以此类推。

.copy()

  在NumPy中,copy() 方法用于创建数组的副本(复制)。这个方法返回一个新的数组对象,该对象是原始数组的完整副本,包括数据和属性。这意味着对新数组的任何更改都不会影响原始数组,反之亦然。

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

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

相关文章

【论文笔记】Learning Deconvolution Network for Semantic Segmentation

重要说明:严格来说,论文所指的反卷积并不是真正的 deconvolution network 。 关于 deconvolution network 的详细介绍,请参考另一篇博客:什么是Deconvolutional Network? 一、参考资料 Learning Deconvolution Netwo…

uniapp组件库Line 线条 的适用方法

目录 #平台差异说明 #基本使用 #线条类型 1.3.7 #兼容性 #API #Props 此组件一般用于显示一根线条,用于分隔内容块,有横向和竖向两种模式,且能设置0.5px线条,使用也很简单。 #平台差异说明 AppH5微信小程序支付宝小程序百…

算法:日志采集系统

一、算法描述 题目 日志采集是运维系统的的核心组件。日志是按行生成,每行记做一条,由采集系统分批上报。如果上报太频繁, 会对服务端造成压力;如果上报太晚,会降低用户的体验;如果一次上报的条数太多&…

Java和Redis实现一个简单的热搜功能

1. 前言 我们有一个简单的需求: 搜索栏展示当前登陆的个人用户的搜索历史记录,删除个人历史记录。用户在搜索栏输入某字符,则将该字符记录下来 以zset格式存储的redis中,记录该字符被搜索的个数以及当前的时间戳 (用…

使用DBSyncer同步Oracle11g数据到Mysql5.7中_实现全量数据同步和增量数据实时同步_操作过程---数据同步之DBSyncer工作笔记007

之前都是用mysql和Postgresql之间进行同步的,已经实现了数据的实时同步,现在要实现Oracle数据库到Mysql数据库的全量,以及增量同步. 因为之前配置的不对,这里架构名写成了orcl,所以导致,虽然能连接上,但是,在进行数据同步的时候,看不到表,所以这里说一下如何进行连接 这里,首先…

代码随想录算法训练营第30天 | 回溯总结 + 3道Hard题目

今日任务 332.重新安排行程 51. N皇后 37. 解数独 总结 总结 回溯总结:代码随想录 回溯是递归的副产品,只要有递归就会有回溯,所以回溯法也经常和二叉树遍历,深度优先搜索混在一起,因为这两种方式都是用了递归。 …

Azure AI - 沉浸式阅读器,阅读障碍用户福音

目录 一、什么是沉浸式阅读器将内容划分开来提高可读性显示常用字词的图片突出显示语音的各个部分朗读内容实时翻译内容将单词拆分为音节 二、沉浸式阅读器如何工作?环境准备创建 Web 应用项目设置身份验证配置身份验证值安装标识客户端 NuGet 包更新控制器以获取令…

防火墙在企业园区出口安全方案中的应用(ENSP实现)

拓扑图 需求: 1、企业出口网关设备必须具备较高的可靠性,为了避免单点故障,要求两台设备形成双机热备状态。当一台设备发生故障时,另一台设备会接替其工作,不会影响业务正常运行。 2、企业从两个ISP租用了两条链路&…

HTML-表格

表格 1.基本结构 一个完整的表格由:表格标题、表格头部、表格主体、表格脚注,四部分组成 表格涉及到的标签: table:表格 caption:标题 thead:表格头部 tbody:表格主体 tfoot:表格注…

算法基础之树状数组

文章目录 树状数组 树状数组 树状数组能解决的最关键的问题就是能够 O ( log ⁡ n ) O(\log n) O(logn)内,给某个位置上的数,加上一个数,或者求前缀和 他和前缀和数组的区别就是,树状数组支持修改原数组的内容,而前缀…

2.数据结构 顺序表(自留笔记)

文章目录 一.静态顺序表:长度固定二.动态顺序表1.下面证明原地扩容和异地扩容代码如下:2.下面是写一段Print,打印数字看看:3.头插4.尾删5.头删6.越界一定会报错吗7.下标插入8.下标删除9.查找数字10.应用:利用顺序表写一…

多维时序 | Matlab实现EVO-TCN-Multihead-Attention能量谷算法优化时间卷积网络结合多头注意力机制多变量时间序列预测

多维时序 | Matlab实现EVO-TCN-Multihead-Attention能量谷算法优化时间卷积网络结合多头注意力机制多变量时间序列预测 目录 多维时序 | Matlab实现EVO-TCN-Multihead-Attention能量谷算法优化时间卷积网络结合多头注意力机制多变量时间序列预测效果一览基本介绍程序设计参考资…

项目测试 手机系统 改串号 写IMEI 改MEID 改手机型号 等信息配置信息 演示视频 和一键新机

项目测试 手机系统 改串号 写IMEI 改MEID 改手机型号 等信息配置信息 演示视频 和配置说明 项目-手机系统支持直接改串号 IMEI MEID 手机型号 等信息配置信息 演示视频 支持 条形码 SN IMEI 1 IMEI 2 MEID 唯一SN 蓝牙地址 wifi地址 mac "一键新机"这个术语通常出现…

HTML-表单

表单 概念&#xff1a;一个包含交互的区域&#xff0c;用于收集用户提供的数据。 1.基本结构 示例代码&#xff1a; <form action"https://www.baidu.com/s" target"_blank" method"get"><input type"text" name"wd&q…

Spring 的存储和获取Bean

文章目录 获取 Spring 上下文对象的方式存储 Bean 对象的方式类注解配置扫描路径&#xff08;必须&#xff09;Controller&#xff08;控制器存储&#xff09;Service&#xff08;服务&#xff09;Repository&#xff08;持久层&#xff09;Component&#xff08;工具&#xff…

【WPF.NET开发】WPF 中的 Layout

本文内容 元素边界框布局系统测量和排列子元素面板元素和自定义布局行为布局性能注意事项子像素渲染和布局舍入 本主题介绍 Windows Presentation Foundation (WPF) 布局系统。 了解布局计算发生的方式和时间对于在 WPF 中创建用户界面非常重要。 1、元素边界框 在 WPF 中构…

【mongoDB】集合的创建和删除

目录 1.集合的创建 2. 查看所有集合 3.删除集合 1.集合的创建 格式&#xff1a; db.createCollection ( name ) 例如创建一个名为 bbb 的集合 还可以通过传递一个选项对象来指定集合的属性&#xff0c;例如最大文档的大小&#xff0c;索引选项等 例如 这样创建了一个名为 cc…

TCP 三次握手以及滑动窗口

TCP 三次握手 简介&#xff1a; TCP 是一种面向连接的单播协议&#xff0c;在发送数据前&#xff0c;通信双方必须在彼此间建立一条连接。所谓的 “ 连接” &#xff0c;其实是客户端和服务器的内存里保存的一份关于对方的信息&#xff0c;如 IP 地址、端口号等。 TCP 可以…

人工智能的未来展望:自然语言处理(NLP)与计算机视觉(CV)

NLP和CV是人工智能的两个重要分支&#xff0c;它们在处理和分析信息方面有不同的侧重点和挑战。 NLP&#xff08;自然语言处理&#xff09;旨在让计算机理解和生成人类语言&#xff0c;主要处理的是文本信息。NLP的研究和应用主要集中在如何让计算机理解和生成人类语言&#x…

Github 无法正常访问?一招解决

查询IP网址: https://ip.chinaz.com/ 主页如下&#xff1a; 分别查询以下三个网址的IP&#xff1a; github.com github.global.ssl.fastly.net assets-cdn.github.com 修改 hosts 文件&#xff1a; 将 /etc/hosts 复制到 home 下 sudo cp /etc/hosts ./ gedit hosts 在底下…