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

OpenCV 滑动条调整图像对比度和亮度

一、知识点
1、int createTrackbar(const String & trackbarname, const String & winname, int * value, int count, TrackbarCallback onChange = 0, void * userdata = 0);
  (1)、创建一个滑动条并将其附在指定窗口上。
  (2)、参数说明:
      trackbarname: 创建的滑动条显示名称。
      winname: 包含滑动条的窗口名称。
      value: 将由滑动条更改的整数值的指针。
      count: 滑动条的最大位置。
      onChange: 回调函数,每次滑块改变位置时会调用此函数。 函数原型void Foo(int, void *),第一个参数是滑动条位置,第二个参数是用户数据。 如果为nullptr,则不会调用回调函数,但是value仍然自动更新。
      userdata: 用户数据,传递给回调函数。
      
2、void addWeighted(InputArray src1, double alpha, InputArray src2, double beta, double gamma, OutputArray dst, int dtype = -1);
  (1)、计算两个数组的加权和。 在多通道情况下,每个通道都是独立处理的。
  (2)、算法代码: dst = src1 * alpha + src2 * beta + gamma;
  (3)、参数说明:
      src1: 第一个输入数组。
      alpha: 第一个数组元素的权重。
      src2: 第二个输入数组,和src1大小和通道数相同。
      beta: 第二个数组元素权重。
      gamma: 标量,会添加到总和中。
      dst: 输出数组。
      dtype: 输出数组的可选深度。 当两个输入数组具有相同的深度时,dtype可以设置为-1,这相当于src1.depth()。
  (4)、src1 * alpha可以改变对比度,比如原先2个值为2、4,相差2,分别乘以2后为4、8,相差4,差值变大。
  (5)、gamma可以改变亮度,总和中每个像素的每个通道值都会加上gamma。
  
      
      
二、示例代码: 滑动条调整图像对比度和亮度

#include <iostream>
#include <opencv2/opencv.hpp>void onContrast(int value, void * pSrc)
{cv::Mat src = *((cv::Mat *)pSrc);cv::Mat temp = cv::Mat::zeros(src.size(), CV_8UC3);cv::Mat dst;double contrast = value / 50.0;cv::addWeighted(src, contrast, temp, 0.0, 0.0, dst);cv::imshow("对比度和亮度调整", dst);
}void onLightness(int value, void * pSrc)
{cv::Mat src = *((cv::Mat *)pSrc);cv::Mat temp = cv::Mat::zeros(src.size(), CV_8UC3);cv::Mat dst;cv::addWeighted(src, 1.0, temp, 0.0, value, dst);cv::imshow("对比度和亮度调整", dst);
}int main()
{cv::Mat src = cv::imread("../images/8.png");if (src.empty()){std::cout << "load src image error..." << std::endl;return -1;}cv::imshow("原始图像", src);cv::namedWindow("对比度和亮度调整", cv::WINDOW_AUTOSIZE);int contrastValue = 50;cv::createTrackbar("对比度", "对比度和亮度调整", &contrastValue, 100, onContrast, &src);int lightnessValue = 50;cv::createTrackbar("亮度", "对比度和亮度调整", &lightnessValue, 100, onLightness, &src);cv::waitKey(0);return 0;
}

http://www.xdnf.cn/news/10706.html

相关文章:

  • 嵌入式SDK技术EasyRTC音视频实时通话助力即时通信社交/教育等多场景创新应用
  • 攻防世界-unseping
  • GPR全波形反演中三种初始模型建立方法详解
  • 【嵌入式(2)深入剖析嵌入式开发:从基础到实战】
  • vue3学习
  • 大数据-277 Spark MLib - 基础介绍 机器学习算法 Gradient Boosting GBDT算法原理 高效实现
  • 简单transformer运用
  • 学习NuxtLink标签
  • dvwa6——Insecure CAPTCHA
  • Lovable + Cursor:零基础搭建专业应用的秘密武器
  • Windows下WSL(Ubuntu)安装1Panel
  • ASR技术(自动语音识别)深度解析
  • Eigen实现非线性最小二乘拟合 + Gauss-Newton算法
  • RabbitMQ如何保证消息可靠性
  • python中可以对数组使用的所有方法
  • 工作自动化——工作自动提炼--智能编程——仙盟创梦IDE
  • B站缓存视频数据m4s转mp4
  • 从零开始,搭建一个基于 Django 的 Web 项目
  • django入门-orm数据库操作
  • unity UI Canvas“高”性能写法
  • 如何轻松地将数据从 iPhone传输到iPhone 16
  • 【JSON-to-Video】设置背景视频片断
  • 【OCCT+ImGUI系列】011-Poly-Poly_Triangle三角形面片
  • GIC v3 v4 虚拟化架构
  • 业态即战场:零售平台的生意模型与系统设计解构
  • Elasticsearch集群最大分片数设置详解:从问题到解决方案
  • [特殊字符] Unity UI 性能优化终极指南 — ScrollRect篇
  • spring-boot-admin实现对微服务监控
  • 提升四级阅读速度方法
  • python学习(一)