C# winform修改背景图 控件双向绑定 拖拽打开图片

修改背景图

说明

这里我准备基于百度飞桨PaddleSeg项目的人像分割模块做一个人像抠图,这里顺便用上了双向绑定和图片拖拽打开。

下面就是示例:

用颜色替换
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

用背景图替换

在这里插入图片描述

在这里插入图片描述

保存成功后的图片

在这里插入图片描述

一、使用百度飞桨PaddleSeg

 //初始化 引擎
 engine = new PaddleSegMattingEngine();
 //参数
 parameter = new MattingParameter();
 //parameter.outbgfile = true;//输出mask图
 //parameter.bgtransparent = true;//背景透明
 engine.Init(modelPath, parameter);

二、下拉框双向绑定

            comb.DataSource = lstCom;
            comb.DisplayMember = "Name";
            comb.DropDownStyle = ComboBoxStyle.DropDownList;

            picOld.DataBindings.Add("SizeMode", lstCom, "Value");
            picNew.DataBindings.Add("SizeMode", lstCom, "Value");
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace SegSharp
{
    public class ComBoxModel : INotifyPropertyChanged
    {
        string _name;
        PictureBoxSizeMode _value;

        public string Name
        {
            get { return _name; }
            set
            {
                _name = value;
                OnPropertyChanged(nameof(Name));
            }
        }

        public PictureBoxSizeMode Value
        {
            get { return _value; }
            set
            {
                _value = value;
                OnPropertyChanged(nameof(Value));
            }
        }

        public event PropertyChangedEventHandler PropertyChanged;

        protected virtual void OnPropertyChanged(string propertyName)  //属性变更通知
        {
            //if (PropertyChanged != null)
            //{
            //    PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
            //}
            PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
        }

    }
}

三、图片拖拽打开

先将form的AllowDrop设置为true

在这里插入图片描述

利用动态库模拟事件

 //函数从动态链接库中倒入(模拟鼠标事件)
 [System.Runtime.InteropServices.DllImport("user32")]
 private static extern int mouse_event(int dwFlags, int dx, int dy, int cButtons, int dwExtraInfo);
 const int MOUSEEVENTF_LEFTDOWN = 0x0002; //模拟鼠标左键按下
 const int MOUSEEVENTF_LEFTUP = 0x0004; //模拟鼠标左键抬起 
                                        //设置静态字段传递图片路径参数
 public static string path_url;

 private void Form1_DragDrop(object sender, DragEventArgs e)
 {
     //获取当前推拽图片的路径
     string path1 = ((Array)e.Data.GetData(DataFormats.FileDrop)).GetValue(0).ToString(); ;
     path_url = path1;
     //模拟鼠标释放鼠标左键的时事件
     mouse_event(MOUSEEVENTF_LEFTUP | MOUSEEVENTF_LEFTUP, Cursor.Position.X, Cursor.Position.Y, 0, 0);
 }

 private void Form1_DragEnter(object sender, DragEventArgs e)
 {
     if (e.Data.GetDataPresent(DataFormats.FileDrop))
         //需求有一需要从QQ的聊天记录中拖拽图片到WinForm窗体中,用ALL会出现QQ的聊天信息中的图片丢失
         //Link和Move不能从QQ的聊天记录中拖拽图片到WinForm窗体中,Copy和Scroll都可以实现,推荐使用Copy
         e.Effect = DragDropEffects.Copy;
     else
         e.Effect = DragDropEffects.None;
 }

 private void picOld_MouseUp(object sender, MouseEventArgs e)
 {
     //给PictureBox设置图片路径
     picOld.ImageLocation = path_url;
     txtName.Text = path_url;
 }

在这里插入图片描述
成功啦~

源码下载

下篇准备利用OCR做一个车牌识别,期待一下~


相关推荐

  1. vue 双向

    2024-03-21 12:30:03       16 阅读
  2. WPF:密码框MVVM

    2024-03-21 12:30:03       10 阅读
  3. vue双向/小程序双向

    2024-03-21 12:30:03       21 阅读
  4. Vue 双向数据

    2024-03-21 12:30:03       19 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-21 12:30:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-21 12:30:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-21 12:30:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-21 12:30:03       20 阅读

热门阅读

  1. OkHttp

    OkHttp

    2024-03-21 12:30:03      18 阅读
  2. git仓库拉取代码

    2024-03-21 12:30:03       21 阅读
  3. 蓝桥杯第14届模拟赛最大连通分块(dfs)

    2024-03-21 12:30:03       18 阅读
  4. 后端使用前端页面的很好的推荐Layui

    2024-03-21 12:30:03       21 阅读
  5. Github 2024-03-20 开源项目日报 Top10

    2024-03-21 12:30:03       20 阅读