欢迎大家积极开心的加入讨论群
javaCV图像处理系列:

前言:

本章通过javaCV-openCV处理图像,其中javaCV部分负责摄像头抓取和Frame、Mat转换操作,openCV负责图像加载、图像保存以及 图像叠加、感兴趣区域和透明度处理。

1、实现的功能

(1)摄像头视频抓取
(2)视频帧Frame与Mat图像相互转换
(3)图像加载级图像保存
(4)图像叠加、图像感兴趣区、图像透明处理
(5)文字叠加、字体大小、粗度、颜色及平滑处理等

2、代码实现

// 转换器,用于Frame/Mat/IplImage相互转换
		OpenCVFrameConverter.ToIplImage converter = new OpenCVFrameConverter.ToIplImage();
		// 使用OpenCV抓取本机摄像头,摄像头设备号默认0
		OpenCVFrameGrabber grabber = new OpenCVFrameGrabber(0);
		// 开启抓取器
		grabber.start();
		//做好自己 - - eguid!,转载请注明出处
		CanvasFrame cFrame = new CanvasFrame("做好自己!--eguid!", CanvasFrame.getDefaultGamma() / grabber.getGamma());
		cFrame.setAlwaysOnTop(true);
		cFrame.setVisible(true);
		// 水印文字位置
		Point point = new Point(10, 50);
		// 颜色,使用黄色
		Scalar scalar = new Scalar(0, 255, 255, 0);
		Frame frame = null;
		int index = 0;

		Mat logo = opencv_imgcodecs.imread("4ycfb.png");
		Mat mask = opencv_imgcodecs.imread("4ycfb.png", 0);

		opencv_imgproc.threshold(mask,mask,254,255,opencv_imgcodecs.IMWRITE_PNG_BILEVEL);

		double alpha = 0.5;// 图像透明权重值,0-1之间
		while (cFrame.isShowing()) {
			if ((frame = grabber.grabFrame()) != null) {
				// 取一帧视频(图像),并转换为Mat
				Mat mat = converter.convertToMat(grabber.grabFrame());

				// 加文字水印,opencv_imgproc.putText(图片,水印文字,文字位置,字体,字体大小,字体颜色,字体粗度,平滑字体,是否翻转文字)
				opencv_imgproc.putText(mat, "eguid!", point, opencv_imgproc.CV_FONT_VECTOR0, 1.2, scalar, 1, 20, false);
				// 定义感兴趣区域(位置,logo图像大小)
				Mat ROI = mat.apply(new Rect(400, 350, logo.cols(), logo.rows()));

				opencv_core.addWeighted(ROI, alpha, logo, 1.0 - alpha, 0.0, ROI);
				// 把logo图像复制到感兴趣区域
//				 logo.copyTo(ROI, mask);
				// 显示图像到窗口
				cFrame.showImage(converter.convert(mat));
				if (index == 0) {
					// 保存第一帧图片到本地
					opencv_imgcodecs.imwrite("eguid.jpg", mat);
				}
				// 释放Mat资源
				ROI.release();
				ROI.close();
				mat.release();
				mat.close();
				Thread.sleep(40);
				index++;
			}

			index++;
		}
		// 关闭窗口
		cFrame.dispose();
		// 停止抓取器
		grabber.stop();
		// 释放资源
		logo.release();
		logo.close();
		mask.release();
		mask.close();
		scalar.close();
		point.close();

3、测试结果

左上角的eguid!是文字水印,右下角的是图片水印,中间是图片上传到csdn时添加的文字水印






javacpp-opencv图像处理之2:实时视频添加图片水印,实现不同大小图片叠加,图像透明度控制,文字和图片双水印的更多相关文章

  1. javacpp-opencv图像处理之1:实时视频添加文字水印并截取视频图像保存成图片,实现文字水印的字体、位置、大小、粗度、翻转、平滑等操作

    欢迎大家积极开心的加入讨论群 群号:371249677 (点击这里进群) javaCV图像处理系列: javaCV图像处理之1:实时视频添加文字水印并截取视频图像保存成图片,实现文字水印的字体.位置. ...

  2. 文字和图片居中的HTML代码怎么写?

    HTML 代码 ,怎么将文本/ 图片居中?这是在W3Cschool的编程问答中前端♌蕾儿提出的问题.网友施主同西否给出了详细的解答. html文字居中和html图片居中方法代码,通过在html中实现文 ...

  3. Python+OpenCV图像处理(三)—— Numpy数组操作图片

    一.改变图片每个像素点每个通道的灰度值 (一) 代码如下: #遍历访问图片每个像素点,并修改相应的RGB import cv2 as cv def access_pixels(image): prin ...

  4. Python+OpenCV图像处理(一)

    Python+OpenCV图像处理(一): 读取,写入和展示图片 调用摄像头拍照 调用摄像头录制视频 1. 读取.写入和展示图片 图像读入:cv2.imread() 使用函数cv2.imread() ...

  5. Python+OpenCV图像处理(一)——读取显示一张图片

    先在此处先声明,后面学习python+opencv图像处理时均参考这位博主的博文https://blog.csdn.net/u011321546/article/category/7495016/2? ...

  6. 使用OpenCV通过摄像头捕获实时视频并探测人脸

    在Opencv初接触,图片的基本操作这篇手记中,我介绍了一些图片的基本操作,视频可以看作是一帧一帧的图片,因此图片操作其实是视频操作的基础,这篇手记就来讲讲OpenCV中的视频操作,并实现一个用笔记本 ...

  7. OpenCV图像处理以及人脸识别

    OpenCV基础 OpenCV是一个开源的计算机视觉库.提供了很多图像处理常用的工具 批注:本文所有图片数据都在我的GitHub仓库 读取图片并显示 import numpy as np import ...

  8. 《OpenCV图像处理编程实例》

    <OpenCV图像处理编程实例>例程复现 随书代码下载:http://www.broadview.com.cn/28573 总结+遇到的issue解决: 第一章 初识OpenCV 1.VS ...

  9. OpenCV图像处理学习笔记-Day1

    OpenCV图像处理学习笔记-Day1 目录 OpenCV图像处理学习笔记-Day1 第1课:图像读入.显示和保存 1. 读入图像 2. 显示图像 3. 保存图像 第2课:图像处理入门基础 1. 基本 ...

随机推荐

  1. 【算法】字符串匹配之Z算法

    求文本与单模式串匹配,通常会使用KMP算法.后来接触到了Z算法,感觉Z算法也相当精妙.在以前的博文中也有过用Z算法来解决字符串匹配的题目. 下面介绍一下Z算法. 先一句话讲清楚Z算法能求什么东西. 输 ...

  2. Patterns for application development with ASP.NET Core

    此文章翻译自 NDC { London } 16-20 January 2017 上, Damian Edwards和David Fowler的演讲,如果翻译不周,请大家指出错误. Logging 生 ...

  3. 作死上CODEVS,青铜题

    题面:输入一列整数,输出它们的总和.最大值.最小值.并从大到小输出. 先上一波伪代码,认真地做一波数组排序题. #include<stdio.h> #include<math.h&g ...

  4. crash部分命令用法

    Set set [pid | taskp | [-c cpu] | -p] | [crash_variable [setting]] | -v 1.设置要显示的内容,内容一般以进程为单位. Set p ...

  5. [ext4]磁盘布局 - inode bitmap & table

    在[磁盘布局 group部分]已经介绍过ext4的整体布局,其中存在两个与inode有关的名称:inode bitmap和inode table. Inode bitmap,用于表示inode tab ...

  6. 为何PS出的RSS总和大于实际物理内存

    使用ps  aux  查看系统进程时,第六列即 RSS列显示的就是进程使用的物理内存. 可是把系统所有进程的该列相加时,得到的总和又远远高于系统实际的物理内存?这到底是怎么回事呢? 看一看linux是 ...

  7. node.js—express+ejs、express+swig、

    安装:npm install -g express-generator 普通express 网站 创建:express testWeb 安装依赖:npm install 修改app.js文件并运行 找 ...

  8. OC-不可变数组NSArray

  9. Gulp和webpack的区别,是一种工具吗?

    疑问:gulp和webpack 什么关系,是一种东西吗?可以只用gulp,不用webpack吗 或者反过来? 它们的区别和概念 ------------------------------------ ...

  10. LeetCode5. Longest Palindromic Substring 最长回文子串 4种方法

    题目链接:https://leetcode.com/problems/longest-palindromic-substring/ 题意很简单,就是求一个字符串得最长子串,这里的子串指连续的. 本文给 ...