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

C# OpenCvSharp 去水印 图像修复

效果

项目

VS2022+.net4.8+OpenCvSharp4

代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Security.Cryptography;
using System.Text;
using System.Windows.Forms;
using OpenCvSharp;
using OpenCvSharp.Extensions;namespace OpenCvSharp_去水印_图像修复
{public partial class Form1 : Form{public Form1(){InitializeComponent();}Bitmap bmp;string fileFilter = "*.*|*.bmp;*.jpg;*.jpeg;*.tiff;*.tiff;*.png";string imgPath = "";public Mat img, img0, inpainted, inpaintMask;int thickness = 10;string CommandText;InpaintMethod inpaintMethod;ListItem li;private void Form1_Load(object sender, EventArgs e){this.SetStyle(ControlStyles.OptimizedDoubleBuffer | ControlStyles.AllPaintingInWmPaint | ControlStyles.UserPaint, true);this.UpdateStyles();//添加项:cBoxThresholdTypes.Items.Add(new ListItem("NS", InpaintMethod.NS));cBoxThresholdTypes.Items.Add(new ListItem("Telea", InpaintMethod.Telea));//设置选中项:cBoxThresholdTypes.SelectedIndex = 0;    //根据索引}private void trackBar2_Scroll(object sender, EventArgs e){thickness = trackBar2.Value;}private void button1_Click(object sender, EventArgs e){OpenFileDialog ofd = new OpenFileDialog();ofd.Filter = fileFilter;if (ofd.ShowDialog() != DialogResult.OK) return;imgPath = ofd.FileName;bmp = new Bitmap(imgPath);pictureBox1.Image = bmp;img0 = Cv2.ImRead(imgPath);inpaintMask = new Mat(img0.Size(), MatType.CV_8U, Scalar.Black);pictureBox2.Image = BitmapConverter.ToBitmap(inpaintMask);pictureBox3.Image = null;}private void cBoxThresholdTypes_SelectedIndexChanged(object sender, EventArgs e){Inpaint();}private void trackBar1_Scroll(object sender, EventArgs e){Inpaint();}private void button4_Click(object sender, EventArgs e){if (pictureBox1.Image == null){return;}img = img0.Clone();inpaintMask = new Mat(img0.Size(), MatType.CV_8U, Scalar.Black);inpainted = img0.EmptyClone();Window wImage = new Window("image", img);OpenCvSharp.Point prevPt = new OpenCvSharp.Point(-1, -1);wImage.SetMouseCallback((MouseEventTypes ev, int x, int y, MouseEventFlags flags, IntPtr userdata) =>{if (ev == MouseEventTypes.LButtonUp || (flags & MouseEventFlags.LButton) == 0){prevPt = new OpenCvSharp.Point(-1, -1);}else if (ev == MouseEventTypes.LButtonDown){prevPt = new OpenCvSharp.Point(x, y);}else if (ev == MouseEventTypes.MouseMove && (flags & MouseEventFlags.LButton) != 0){OpenCvSharp.Point pt = new OpenCvSharp.Point(x, y);if (prevPt.X < 0){prevPt = pt;}inpaintMask.Line(prevPt, pt, Scalar.White, thickness, LineTypes.AntiAlias, 0);pictureBox2.Image = BitmapConverter.ToBitmap(inpaintMask);img.Line(prevPt, pt, Scalar.White, thickness, LineTypes.AntiAlias, 0);prevPt = pt;wImage.ShowImage(img);}});try{for (; ; ){switch ((char)Window.WaitKey(0)){case (char)27:    // exitreturn;case 'r':inpaintMask.SetTo(Scalar.Black);pictureBox2.Image = BitmapConverter.ToBitmap(inpaintMask);img0.CopyTo(img);wImage.ShowImage(img);break;case 'i':case '\r':Inpaint();break;}}}finally{Window.DestroyAllWindows();}}private void button3_Click(object sender, EventArgs e){Inpaint();}void Inpaint(){if (pictureBox1.Image == null){return;}li = (ListItem)cBoxThresholdTypes.SelectedItem;inpaintMethod = (InpaintMethod)li.Value;Cv2.Inpaint(img, inpaintMask, inpainted, trackBar1.Value, inpaintMethod);pictureBox3.Image = BitmapConverter.ToBitmap(inpainted);CommandText = String.Format("Cv2.Inpaint(src, mask, dst,{0},{1})", trackBar1.Value, inpaintMethod.ToString());txtCommandText.Text = CommandText;}}
}

Demo下载 

http://www.lryc.cn/news/117228.html

相关文章:

  • 考研算法第40天:众数 【模拟,简单题】
  • MySQL:内置函数、复合查询和内外连接
  • 【HTML】label 标签
  • python视频流截图(按帧数)
  • MongoDB SQL
  • node js连接mysql数据库
  • 通过Python模拟计算附近WIFI密码,没有我蹭不到的网
  • ubuntu20.04 远程桌面配置记录【亲测好用】
  • 解决selenium的“can‘t access dead object”错误
  • Docker Dockerfile 使用方法
  • (6)(6.3) 复合连接的故障处理
  • 报考红帽认证难不,红帽认证考试容易吗?
  • 如何优雅地用VS编写C#代码——快捷键的使用
  • 微服务——操作索引库+文档操作+RestClient操作索引库和文档(java程序)
  • 【性能测试】性能数据采集工具nmon安装使用及报告参数含义详解
  • 『PostgreSQL』在 PostgreSQL中创建只读权限和读写权限的账号
  • 基于Java+SpringBoot+Vue的网上书城管理系统设计与实现(源码+LW+部署文档等)
  • 安全渗透——AWK知识整理
  • 计算机视觉的应用9-视觉领域中的61个经典数据集【大集合】的应用与实战
  • Go中for循环的遮挡效应
  • UE4 Cesium 学习笔记
  • 【LeetCode】322.零钱兑换
  • 中电金信:国际结算系统的“王冠”,为什么十年都戴在“它”的头上
  • java 企业工程管理系统软件源码+Spring Cloud + Spring Boot +二次开发+ MybatisPlus + Redis em
  • fine-tuning(微调)的理解
  • 深入理解设计模式面经
  • STM32单片机蓝牙APP宠物自动喂食器定时语音提醒喂食系统设计
  • 武汉凯迪正大—串联谐振在电力系统中应用的优点:
  • Git仓库、分支的区别
  • C#生成随机验证码