EmguCV学习笔记:Image

运算符重载 (重载运算符 +, -, *,实现图像与图像,图像与值的运算)

Image<Gray,Byte> img1;
//Do somthing to initialize img1

Image<Gray,Byte> img2;
//Do somthing to initialize img2

IMage<Gray,Byte> img3=(img1+img2-2.0)*0.5;


像素操作(赋值,取反等)

Image<Gray, Byte> img1 = new Image<Gray, Byte>(400, 300, new Gray(30));
Image<Gray, Byte> img2 = img1.Not();
Image<Gray, Byte> img3 =
 img1.Convert<Byte>( delegate(Byte b) { return (Byte) (255-b); } );
Image<Gray, Single> img4 = img1.Convert<Single>(
 delegate(Byte b) { return (Single) Math.cos( b * b / 255.0); }  );

注意.And(),.Xor(),.Not()等运算会返回计算结果而原始图像内容未发生改变,

._And(),._Not()则是在图像本身进行运算(而不返回),计算完成后图像内容已改变


元素类型转换(极其方便,一条语句基本上可以搞定大部分的基础转换)

Image<Bgr, Byte> img1;
Image<Gray, Single> img2 = img1.Convert<Gray, Single>();
Bitmap bmp=img2.ToBitmap();

序列化(XML文档)

序列化:将object obj的内容写到XML文档

反序列化:从XML文档构建obj对象

StringBuilder sb = new StringBuilder();
(new XmlSerializer(typeof(Image<Bgr, Byte>))).Serialize(new StringWriter(sb), obj);
XmlDocument xDoc = new XmlDocument();
xDoc.LoadXml(sb.ToString());

Image<Bgr, Byte> image = (Image<Bgr, Byte>) 
(new XmlSerializer(typeof(Image<Bgr, Byte>))).Deserialize(new XmlNodeReader(xDoc));


完整的示例

using System;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using Emgu.CV;
using Emgu.CV.Structure;
using System.IO;
using System.Xml;
using System.Xml.Serialization;

namespace EmguImageProcess
{
    public class ImageProcess
    {
        private Image<Bgr, Byte> image = null;

        /// <summary>
        /// Form中的图片控件(请使用Designer设计器)
        /// </summary>
        // private Emgu.CV.UI.ImageBox imageBox1; 
        // private System.WIndows.Forms.PictureBox pictureBox1;
        ///

        public void MenuItemOpenFile_Click(object sender, EventArgs e)
        {
            OpenFileDialog ofd = new OpenFileDialog();
            ofd.Filter = "Image File(*.jpg;*.png;*.*)|*.*";
            ofd.Multiselect = false;
            if (ofd.ShowDialog() == DialogResult.OK)
            {
                image = new Image<Bgr, byte>(ofd.FileName);
            }
        }

        private void MenuItemDisplayImage_Click(object sender, EventArgs e)
        {
            if (image == null) return;
            imageBox1.Image = image;
            pictureBox1.Image = image.ToBitmap();
        }

        private void MenuItemToGray_Click(object sender, EventArgs e)
        {
            if (image == null) return;
            Image<Gray, Byte> gray = image.Convert<Gray, Byte>();
            imageBox1.Image = gray;
        }

        private void MenuItemConsine_Click(object sender, EventArgs e)
        {
            if (image == null) return;
            Image<Bgr, Single> cosGray = image.Convert<Single>(
                delegate(Byte b) { return (Single)Math.Cos(b * b / 255.0); });
            imageBox1.Image = cosGray;
        }

        private void MenuItemXmlSerial_Click(object sender, EventArgs e)
        {
            if (image == null) return;
            SaveFileDialog sfd = new SaveFileDialog();
            sfd.Filter = "XML File(*.xml)|*.xml";
            if (sfd.ShowDialog() == DialogResult.OK)
            {
                StringBuilder sb = new StringBuilder();
                (new XmlSerializer(typeof(Image<Bgr, Byte>))).Serialize(new StringWriter(sb), image);
                XmlDocument xDoc = new XmlDocument();
                xDoc.LoadXml(sb.ToString());
                xDoc.Save(sfd.FileName);
            }
        }

        private void MenuItemXmlLoad_Click(object sender, EventArgs e)
        {
            OpenFileDialog ofd = new OpenFileDialog();
            ofd.Filter = "XML File(*.xml)|*.xml";
            ofd.Multiselect = false;
            if (ofd.ShowDialog() == DialogResult.OK)
            {
                XmlDocument xDoc = new XmlDocument();
                xDoc.Load(ofd.FileName);
                image = (Image<Bgr, Byte>)(new XmlSerializer(
                    typeof(Image<Bgr, Byte>))).Deserialize(new XmlNodeReader(xDoc));
            }
        }
    }
}


点此领取楼主

转载于:https://www.cnblogs.com/fengyhack/p/10603762.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值