5:OpenCV—图像亮度、对比度变换

news2025/5/24 1:48:41

1.更改图像和视频的亮度

更改亮度

更改图像的亮度是常用的点操作。在此操作中,图像中每个像素的值应增加/减少一个常数。要更改视频的亮度,应对视频中的每一帧执行相同的操作。

如果要增加图像的亮度,则必须为图像中的每个像素添加一些正常量值。

new_image (i, j) = image(i, j) + c

如果要降低图像的亮度,则必须从图像中的每个像素中减去一些正常量值。

new_image (i, j) = 图像(i, j) - c

例如,说,这是您的原始图像。假设图像的数据类型是CV_8U(即 - 图像中的像素是 8 位无符号的。因此,图像中每个像素的有效值范围应为 0 - 255。

原始图像

假设您想将原始图像的亮度提高 60。因此,您应该为原始图像中的每个像素添加 60。您必须通过在原始图像上加 60 来确保输出图像中的像素值不应超过允许的最大限制。如果超过最大限制,则必须分配最大值而不是正确的值。

这是亮度增加60的输出图像。您可能已经注意到,(3, 1) 位置的像素值为 255,尽管在 200 上加上 60 后,它应该是 260。这是因为此图像的最大允许像素值为 255。

假设您想将原始图像的亮度降低 20。因此,您应该从原始图像中的每个像素中减去 20。您必须确保从原始图像中减去 20 后,输出图像中的像素值不应低于允许的最小限制。如果它低于最小限制,则必须分配最小值而不是正确的值。

这是亮度降低20的输出图像。您可能已经注意到 (0, 0) 位置的像素值为 0,尽管从 8 中减去 20 后它应该是 -12。这是因为具有无符号数据类型的图像的最小允许像素值为 0。

使用 OpenCV 更改图像的亮度

需要在QT中配置包含路径及类库路径

1
2
INCLUDEPATH += D:\Application\opencvdev\opencv3.4.6\rebuild_for_qt\install\include
LIBS += D:\Application\opencvdev\opencv3.4.6\rebuild_for_qt\lib\libopencv_*.a

将上述代码片段复制并粘贴到 IDE 中并运行它。


#include <QCoreApplication>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    // 读取图像
    String rootDir = "D:/Gerry/project/opencvproj/singleandslot/OpenCV-2/ImageAndVideoHandle/resources/lena.png";
    Mat image = imread(rootDir);

    // 对图片进行亮度增强
    Mat imageBright50;
    image.convertTo(imageBright50, -1, 1, 50);

    Mat imageBright100;
    image.convertTo(imageBright100, -1, 1, 100);
    // 对图像进行亮度减少
    Mat imageDark50;
    image.convertTo(imageDark50, -1, 1, -50);

    Mat imageDark100;
    image.convertTo(imageDark100, -1, 1, -100);

    // 定义窗口标题
    String OriginWind = "原图像";
    String Bright50Wind = "增亮50";
    String Bright100Wind = "增亮100";
    String Dark50Wind = "减少亮度50";
    String Dark100Wind = "减少亮度100";
    // 创建四个窗体
    namedWindow(OriginWind, WINDOW_NORMAL);
    namedWindow(Bright50Wind, WINDOW_NORMAL);
    namedWindow(Bright100Wind, WINDOW_NORMAL);
    namedWindow(Dark50Wind, WINDOW_NORMAL);
    namedWindow(Dark100Wind, WINDOW_NORMAL);

    // 分别在四个窗口中显示出来完成的图像
    imshow(OriginWind, image);
    imshow(Bright50Wind, imageBright50);
    imshow(Bright100Wind, imageBright100);
    imshow(Dark50Wind, imageDark50);
    imshow(Dark100Wind, imageDark100);

    waitKey(0);

    destroyAllWindows();


    return a.exec();
}
亮度增加
亮度降低
解释

让我们逐行浏览上面的示例。


// Read the image file
Mat image = imread("D:/My OpenCV Website/My Guitar.jpg");

// Check for failure
if (image.empty())
{
    cout << "Could not open or find the image" << endl;
    cin.get(); //wait for any key press
    return -1;
}

此代码段从指定文件加载图像。如果加载图像失败,程序将退出。

上面的代码段将像素值增加指定的量,并将其存储在给定的输出图像中。如果指定的值为正,则输出图像的亮度将增加。如果指定的值为负,则输出图像的亮度将降低。



Mat imageBrighnessHigh50;
image.convertTo(imageBrighnessHigh50, -1, 1, 50); //increase the brightness by 50

Mat imageBrighnessHigh100;
image.convertTo(imageBrighnessHigh100, -1, 1, 100); //increase the brightness by 100

Mat imageBrighnessLow50;
image.convertTo(imageBrighnessLow50, -1, 1, -50); //decrease the brightness by 50

Mat imageBrighnessLow100;
image.convertTo(imageBrighnessLow100, -1, 1, -100); //decrease the brightness by 100

void Mat::convertTo( OutputArray m, int rtype, double alpha=1, double beta=0 ) const

此函数将每个像素值转换为目标数据类型,并按照以下公式更改值。

pixel_value_of_output_image(x, y) = pixel_value_of_input_image(x, y) * alpha + beta;

  1. m - 输出图像。如果需要,将重新分配此数据结构。
  2. rtype - 输出图像的类型。如果 rtype 为负值,则输出图像的类型将与输入图像的类型相同。
  3. alpha - 在分配给输出图像之前,输入图像中的每个像素将乘以此数字。
  4. beta - 此值将添加到输入图像中的每个像素并分配给输出图像。

//Defining window names for above images
String windowNameOriginalImage = "Original Image";
String windowNameBrightnessHigh50 = "Brightness Increased by 50";
String windowNameWithBrightnessHigh100 = "Brightness Increased by 100";
String windowNameBrightnessLow50 = "Brightness Decreased by 50";
String windowNameBrightnessLow100 = "Brightness Decreased by 100";

//Create and open windows for above images
namedWindow(windowNameOriginalImage, WINDOW_NORMAL);
namedWindow(windowNameBrightnessHigh50, WINDOW_NORMAL);
namedWindow(windowNameWithBrightnessHigh100, WINDOW_NORMAL);
namedWindow(windowNameBrightnessLow50, WINDOW_NORMAL);
namedWindow(windowNameBrightnessLow100, WINDOW_NORMAL);

//Show above images inside the created windows.
imshow(windowNameOriginalImage, image);
imshow(windowNameBrightnessHigh50, imageBrighnessHigh50);
imshow(windowNameWithBrightnessHigh100, imageBrighnessHigh100);
imshow(windowNameBrightnessLow50, imageBrighnessLow50);
imshow(windowNameBrightnessLow100, imageBrighnessLow100);

上面的代码片段将创建窗口并在其中显示图像。

上面的代码段将等待,直到按下任何键。按键后,所有创建的窗口将被销毁。

1
2
3
waitKey(0); // Wait for any key stroke

destroyAllWindows(); //destroy all open windows

使用 OpenCV 更改视频的亮度


#include <QCoreApplication>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    // 读取图像
    String VideoDir = "D:/Gerry/project/opencvproj/singleandslot/OpenCV-2/ImageAndVideoHandle/resources/点云应用.mp4";
    // 打开视频文件并进行数据读取
    VideoCapture cap(VideoDir);

    // 定义窗口标题
    String OriginWind = "原视频";
    String Bright50Wind = "增亮50";
    String Bright100Wind = "增亮100";
    String Dark50Wind = "减少亮度50";
    String Dark100Wind = "减少亮度100";
    // 创建四个窗体
    namedWindow(OriginWind, WINDOW_NORMAL);
    namedWindow(Bright50Wind, WINDOW_NORMAL);
    namedWindow(Bright100Wind, WINDOW_NORMAL);
    namedWindow(Dark50Wind, WINDOW_NORMAL);
    namedWindow(Dark100Wind, WINDOW_NORMAL);

    while(true)
    {
        // 可以把视频中每一帧看成一张图像来进行处理
        Mat frame;
        // 通过视频捕获对象来获取每一帧
        cap.read(frame);

        // 对图片进行亮度增强
        Mat imageBright50;
        frame.convertTo(imageBright50, -1, 1, 50);

        Mat imageBright100;
        frame.convertTo(imageBright100, -1, 1, 100);
        // 对图像进行亮度减少
        Mat imageDark50;
        frame.convertTo(imageDark50, -1, 1, -50);

        Mat imageDark100;
        frame.convertTo(imageDark100, -1, 1, -100);

        // 分别在四个窗口中显示出来完成的图像
        imshow(OriginWind, frame);
        imshow(Bright50Wind, imageBright50);
        imshow(Bright100Wind, imageBright100);
        imshow(Dark50Wind, imageDark50);
        imshow(Dark100Wind, imageDark100);

        if (waitKey(10) == 27)
        {
            cout << "ESC退出程序";
            break;
        }
    }

    destroyAllWindows();
    return a.exec();
}

2.更改图像和视频的对比度

更改图像的对比度也是一种常用的点操作。在此操作中,图像中每个像素的值应乘以不等于 1 的正常数。要更改视频的对比度,应对视频中的每个帧执行相同的操作。为了增加图像的对比度,图像中的每个像素都应乘以大于1的正常数。

new_image (i, j) = image(i, j) * c (c > 1)

为了降低图像的对比度,图像中的每个像素都应乘以小于该常数的正常数。

new_image (i, j) = image(i, j) * c (0 < c < 1)

例如,说,这是您的原始图像。假设图像的数据类型为 CV_8U.(即 - 图像中的像素是 8 位无符号的。请参阅 OpenCV C++ API 了解更多信息。因此,图像中每个像素的有效值范围应为 0 - 255。

原始图像

假设您想将原始图像的对比度提高 2 倍。因此,您应该将原始图像中的每个像素乘以 2。必须确保输出图像中的像素值在乘法后不应超过允许的最大限制。如果超过最大限制,则必须分配最大值而不是正确的值。

这是对比度增加 2 倍的图像。您可能已经注意到 (0, 0) 位置的像素值为 255,尽管将 288 乘以 144 后它应该是 2。这是因为此图像的最大允许像素值为 255。

对比度增加 2 倍的图像

比如说,你想将原始图像的对比度减半。因此,您应该将原始图像中的每个像素乘以 0.5。这是对比度降低的图像。

使用 OpenCV 更改图像的对比度


#include <QCoreApplication>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    // 从文件读取到对象中
    String rootDir = "D:/Gerry/project/opencvproj/singleandslot/OpenCV-2/ImageAndVideoHandle/resources/lena.png";
    Mat image = imread(rootDir);
    // 增加图像对比度
    Mat constrast2;
    image.convertTo(constrast2, -1, 2, 0);

    Mat constrast4;
    image.convertTo(constrast4, -1, 4, 0);
    // 减少图形对比度
    Mat constrastLow_0_5;
    image.convertTo(constrastLow_0_5, -1, 0.5, 0);

    Mat constrastLow_0_2_5;
    image.convertTo(constrastLow_0_2_5, -1, 0.25, 0);

    // 定义窗口标题
    String OriginWind = "原图像";
    String Bright50Wind = "增加2倍";
    String Bright100Wind = "增加4倍";
    String Dark50Wind = "减少0.5倍";
    String Dark100Wind = "减少0.25倍";
    // 创建四个窗体
    namedWindow(OriginWind, WINDOW_NORMAL);
    namedWindow(Bright50Wind, WINDOW_NORMAL);
    namedWindow(Bright100Wind, WINDOW_NORMAL);
    namedWindow(Dark50Wind, WINDOW_NORMAL);
    namedWindow(Dark100Wind, WINDOW_NORMAL);

    // 分别在四个窗口中显示出来完成的图像
    imshow(OriginWind, image);
    imshow(Bright50Wind, constrast2);
    imshow(Bright100Wind, constrast4);
    imshow(Dark50Wind, constrastLow_0_5);
    imshow(Dark100Wind, constrastLow_0_2_5);

    waitKey(0);

    destroyAllWindows();

    return a.exec();
}

对比度增加
对比度降低
代码解释

// Read the image file
Mat image = imread("D:/My OpenCV Website/Christmas.jpg");

// Check for failure
if (image.empty())
{
    cout << "Could not open or find the image" << endl;
    cin.get(); //wait for any key press
    return -1;
}

此代码段从指定文件加载图像。如果加载图像失败,程序将退出。

上面的代码段将像素值乘以指定的量,并将其存储在给定的输出图像中。如果指定的值大于 1,则输出图像的对比度将增加。如果指定的值小于 1,则输出图像的对比度将降低。


Mat imageContrastHigh2;
image.convertTo(imageContrastHigh2, -1, 2, 0); //increase the contrast by 2

Mat imageContrastHigh4;
image.convertTo(imageContrastHigh4, -1, 4, 0); //increase the contrast by 4

Mat imageContrastLow0_5;
image.convertTo(imageContrastLow0_5, -1, 0.5, 0); //decrease the contrast by 0.5

Mat imageContrastLow0_25;
image.convertTo(imageContrastLow0_25, -1, 0.25, 0); //decrease the contrast by 0.25

void Mat::convertTo( OutputArray m, int rtype, double alpha=1, double beta=0 ) const

此函数将每个像素值转换为目标数据类型,并按照以下公式更改值。

pixel_value_of_output_image(x, y) = pixel_value_of_input_image(x, y) * alpha + beta;

  1. m - 输出图像。如果需要,将重新分配此数据结构。
  2. rtype - 输出图像的类型。如果 rtype 为负值,则输出图像的类型将与输入图像的类型相同。
  3. alpha - 在分配给输出图像之前,输入图像中的每个像素将乘以此数字。
  4. beta - 此值将添加到输入图像中的每个像素并分配给输出图像。

//Defining window names for above images
String windowNameOriginalImage = "Original Image";
String windowNameContrastHigh2 = "Contrast Increased by 2";
String windowNameContrastHigh4 = "Contrast Increased by 4";
String windowNameContrastLow0_5 = "Contrast Decreased by 0.5";
String windowNameContrastLow0_25 = "Contrast Decreased by 0.25";

//Create and open windows for above images
namedWindow(windowNameOriginalImage, WINDOW_NORMAL);
namedWindow(windowNameContrastHigh2, WINDOW_NORMAL);
namedWindow(windowNameContrastHigh4, WINDOW_NORMAL);
namedWindow(windowNameContrastLow0_5, WINDOW_NORMAL);
namedWindow(windowNameContrastLow0_25, WINDOW_NORMAL);

//Show above images inside the created windows.
imshow(windowNameOriginalImage, image);
imshow(windowNameContrastHigh2, imageContrastHigh2);
imshow(windowNameContrastHigh4, imageContrastHigh4);
imshow(windowNameContrastLow0_5, imageContrastLow0_5);
imshow(windowNameContrastLow0_25, imageContrastLow0_25);

上面的代码片段将创建窗口并在其中显示图像。由于窗口是通过传递标志WINDOW_NORMAL创建的,因此可以自由调整窗口大小。

上面的代码段将等待,直到按下任何键。按键后,所有创建的窗口将被销毁。

1
2
waitKey(0); // Wait for any key stroke
destroyAllWindows(); //destroy all open windows

使用 OpenCV 更改视频的对比度


#include <QCoreApplication>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    String VideoDir = "D:/Gerry/project/opencvproj/singleandslot/OpenCV-2/ImageAndVideoHandle/resources/点云应用.mp4";
    // 打开视频文件并进行数据读取
    VideoCapture cap(VideoDir);

    // 定义窗口标题
    String OriginWind = "原视频";
    String Bright50Wind = "增加2倍对比度";
    String Bright100Wind = "增加4倍对比度";
    String Dark50Wind = "减少0.5倍对比度";
    String Dark100Wind = "减少0.25倍对比度";
    // 创建四个窗体
    namedWindow(OriginWind, WINDOW_NORMAL);
    namedWindow(Bright50Wind, WINDOW_NORMAL);
    namedWindow(Bright100Wind, WINDOW_NORMAL);
    namedWindow(Dark50Wind, WINDOW_NORMAL);
    namedWindow(Dark100Wind, WINDOW_NORMAL);

    while(true)
    {
        // 可以把视频中每一帧看成一张图像来进行处理
        Mat frame;
        // 通过视频捕获对象来获取每一帧
        cap.read(frame);

        // 对图片进行对比度增强
        Mat imageConstrast2;
        frame.convertTo(imageConstrast2, -1, 2, 0);

        Mat imageConstrast4;
        frame.convertTo(imageConstrast4, -1, 4, 0);
        // 对图像进行对比度减少
        Mat imageDark0_5;
        frame.convertTo(imageDark0_5, -1, 0.5, 0);

        Mat imageDark0_2_5;
        frame.convertTo(imageDark0_2_5, -1, 0.25, 0);

        // 分别在四个窗口中显示出来完成的图像
        imshow(OriginWind, frame);
        imshow(Bright50Wind, imageConstrast2);
        imshow(Bright100Wind, imageConstrast4);
        imshow(Dark50Wind, imageDark0_5);
        imshow(Dark100Wind, imageDark0_2_5);

        if (waitKey(10) == 27)
        {
            cout << "ESC退出程序";
            break;
        }
    }

    destroyAllWindows();

    return a.exec();
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Oracle 的V$ACTIVE_SESSION_HISTORY 视图

Oracle 的V$ACTIVE_SESSION_HISTORY 视图 V$ACTIVE_SESSION_HISTORY显示数据库中的 Sampled Session 活动。 它包含每秒拍摄一次的活动数据库会话的快照。如果数据库会话位于 CPU 上或正在等待不属于等待类的事件&#xff0c;则认为该会话处于活动状态。请参阅 view 以了解有…

【Python 算法零基础 4.排序 ② 冒泡排序】

目录 一、引言 二、算法思想 三、时间复杂度和空间复杂度 1.时间复杂度 2.空间复杂度 四、冒泡排序的优缺点 1.算法的优点 2.算法的缺点 五、实战练习 88. 合并两个有序数组 算法与思路 ① 合并数组 ② 冒泡排序 2148. 元素计数 算法与思路 ① 排序 ② 初始化计数器 ③ 遍历数组…

Python:操作Excel设置行高和列宽

Python 操作 Excel:轻松设置行高与列宽 📊✨ 在处理 Excel 表格时,除了正确展示数据本身,合理设置行高与列宽也是提升可读性和专业度的关键因素。本文将带你了解如何使用 Python 的 openpyxl 库,优雅地控制 Excel 表格的排版布局,实现行高、列宽的灵活设置与自动适配! …

docker-volume-backup 备份 ragflow volumes

自定义项目名称 这里我自定义了 ragflow 项目的名称&#xff0c;修改 .env&#xff0c;添加环境配置 # 自定义项目名称 COMPOSE_PROJECT_NAMEragflow创建备份脚本配置文件 在 ragflow/docker 目录下创建文件 docker-compose-backup.yml version: 3services:backup:image: o…

Axure设计数字乡村可视化大屏:从布局到交互的实战经验分享

乡村治理正从传统模式向“数据驱动”转型。数字乡村可视化大屏作为数据展示的核心载体&#xff0c;不仅能直观呈现乡村发展全貌&#xff0c;还能为决策提供科学依据。本文以Axure为工具&#xff0c;结合实际案例&#xff0c;分享如何从零设计一个功能完备、交互流畅的数字乡村大…

算法第26天 | 贪心算法、455.分发饼干、376. 摆动序列、 53. 最大子序和

弹性算法理论基础 想清楚 局部最优 是什么&#xff0c;如果可以推导出全局最优&#xff0c;那就是正确的贪心算法 455. 分发饼干 题目 思路与解法 class Solution:def findContentChildren(self, g: List[int], s: List[int]) -> int:res 0i 0j 0g.sort()s.sort()whi…

PDF处理控件Aspose.PDF教程:以编程方式将 PDF 导出为 JPG

在本节中&#xff0c;我们将探讨如何使用 Aspose.PDF 库将 PDF 文档转换为 JPG 图像。Aspose.PDF 是一个功能强大且用途广泛的库&#xff0c;专为需要以编程方式处理 PDF 文件的开发人员而设计。它提供了丰富的功能&#xff0c;可用于跨多个平台创建、编辑和转换 PDF 文档。其主…

AI大模型应用之评测篇

在看到公司对于AI 工程师 的岗位要求 &#xff1a;“能够熟练使用各种自动化评测工具与方法&#xff0c;对AI 模型的输出进行有效评估” 时&#xff0c;其实比较疑惑&#xff0c;这个是对大模型能力例如像Deepseek ,GPT-4 ,千问&#xff0c;LLAMA这些模型的能力评测&#xff0c…

力扣小题, 力扣113.路径总和II力扣.111二叉树的最小深度 力扣.221最大正方形力扣5.最长回文子串更加优秀的算法:中心扩展算法

目录 力扣113.路径总和II 力扣.111二叉树的最小深度 力扣.221最大正方形 力扣5.最长回文子串 更加优秀的算法:中心扩展算法 力扣113.路径总和II 这道题&#xff0c;让我明白回溯了到底啥意思 之前我找的时候&#xff0c;我一直在想&#xff0c;如果可以&#xff0c;请你对比…

el-form elform 对齐方式调整

如下页面表单&#xff0c;展示后就很丑。 页面表单&#xff0c;有时候我们想着最左侧的应该合理整齐的左对齐&#xff0c;右侧的表单都是右对齐&#xff0c;这样页面看起来会整洁很多。 <el-form class"w-100 a_form" style"padding: 0 15px 0px 15px"…

JESD204 ip核使用与例程分析(二)

JESD204 ip核使用与例程分析(二) JESD204时钟方案专用差分时钟对例程分析jesd204_0_transport_layer_demapperjesd204_0_sig_chkjesd204_0_clockingjesd204_0 ip核port寄存器AXI-LITE寄存器配置jesd204_phy ip核JESD204时钟方案 图3-1所示为最通用、灵活的时钟解决方案。在图…

50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Blurry Loading (毛玻璃加载)

&#x1f4c5; 我们继续 50 个小项目挑战&#xff01;—— Blurry Loading 组件 仓库地址&#xff1a;https://github.com/SunACong/50-vue-projects 项目预览地址&#xff1a;https://50-vue-projects.vercel.app/ ✨ 组件目标 实现一个加载进度条&#xff0c;随着加载进度的…

演示:【WPF-WinCC3D】 3D工业组态监控平台源代码

一、目的&#xff1a;分享一个应用WPF 3D开发的3D工业组态监控平台源代码 二、功能介绍 WPF-WinCC3D是基于 WPF 3D研发的工业组态软件&#xff0c;提供将近200个预置工业模型&#xff08;机械手臂、科幻零部件、熔炼生产线、机加生产线、管道等&#xff09;&#xff0c;支持组态…

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】1.4 数据库与表的基本操作(DDL/DML语句)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 1.4 数据库与表的基本操作&#xff08;DDL/DML语句&#xff09;1.4.1 数据库生命周期管理&#xff08;DDL核心&#xff09;1.4.1.1 创建数据库&#xff08;CREATE DATABASE&…

如何在电脑上登录多个抖音账号?多开不同IP技巧分解

随着短视频的爆发式增长&#xff0c;抖音已经成为许多人生活和工作的必备平台。不论是个人内容创作者、品牌商家&#xff0c;还是营销人员&#xff0c;都可能需要管理多个抖音账号。如何在电脑上同时登录多个抖音账号&#xff0c;提升工作效率&#xff0c;避免频繁切换账号的麻…

【东枫科技】usrp rfnoc 开发环境搭建

作者 太原市东枫电子科技有限公司 &#xff0c;代理销售 USRP&#xff0c;Nvidia&#xff0c;等产品与技术支持&#xff0c;培训服务。 环境 Ubuntu 20.04 依赖包 sudo apt-get updatesudo apt-get install autoconf automake build-essential ccache cmake cpufrequtils …

【JAVA资料,C#资料,人工智能资料,Python资料】全网最全编程学习文档合集,从入门到全栈,保姆级整理!

文章目录 前言一、编程学习前的准备​1.1 明确学习目标​1.2 评估自身基础​ 二、编程语言的选择​2.1 热门编程语言介绍​2.2 如何根据目标选择语言​ 三、编程基础学习​3.1 变量与数据类型​3.2 控制结构​3.3 函数​ 四、面向对象编程&#xff08;OOP&#xff09;​4.1 OOP…

[IMX] 05.串口 - UART

目录 1.通信格式 2.电平标准 3.IMX UART 模块 4.时钟寄存器 - CCM_CSCDR1 5.控制寄存器 5.1.UART_UCR1 5.2.UART_UCR2 5.3.UART_UCR3 6.状态寄存器 6.1.UART_USR1 6.2.UART_USR2 7.FIFO 控制寄存器 - UART_UFCR 8.波特率寄存器 8.1.分母 - UART_UBIR 8.2.分子 -…

使用Tkinter写一个发送kafka消息的工具

文章目录 背景工具界面展示功能代码讲解运行环境创建GUI程序搭建前端样式编写功能实现代码 背景 公司是做AR实景产品的&#xff0c;近几年无人机特别的火&#xff0c;一来公司比较关注低空经济这个新型领域&#xff0c;二来很多政企、事业单位都采购了无人机用于日常工作。那么…

MongoDB 与 EF Core 深度整合实战:打造结构清晰的 Web API 应用

题纲 MongoDB 字符串连接 URIC# 连接字符串实例 实现一个电影信息查询 demo创建项目创建实体实现 DbContext 上下文仓储实现服务实现控制器实现服务注册快照注入数据库连接配置1. 注册配置类2. 注入 IOptionsSnapshot<MongoDbSettings>3. 配置文件 appsettings.json 示例…