C# GDI画图系列(五) 添加文字和导出图片等附加功能

本文介绍如何使用C#的GDI+库实现双击添加和编辑文字,调整文字位置,以及保存图像的功能。在Presenter中添加AddString方法以响应双击事件,通过设置线条宽度来定制线条效果。此外,通过添加菜单项和TextBox控件,允许用户输入文字,并提供保存图像到指定文件夹的功能。
摘要由CSDN通过智能技术生成

实现一些小功能
双击添加文字和再次双击文字修改,和鼠标按住文字可以修改其位置
在这里插入图片描述
在Presenter中添加方法Addstring,并且在OnMouseDoubleClick事件中调用

 private void Addstring(Point poi, string txt)
        {
            TextBox te = new TextBox();
            te.Location = poi;
            te.Text = txt;
            te.Size = new System.Drawing.Size(100, 21);
            te.KeyDown += delegate (object obj, KeyEventArgs es)
            {
                if (es.KeyCode == Keys.Enter)
                {
                    Label label1 = new Label();
                    label1.AutoSize = true;
                    label1.BackColor = System.Drawing.Color.Transparent;
                    label1.Location = te.Location;
                    label1.Text = te.Text.Trim();
                    label1.DoubleClick += delegate (object _obj, EventArgs _es)//再次双击修改文字
                    {
                        Addstring(label1.Location, label1.Text.Trim());
                        _canvas.RemoveChild(label1);
                    };
                    label1.MouseMove += delegate (object _obj, MouseEventArgs _es)
                    {
                        if (_es.Button == MouseButtons.Left)
                        {
                            label1.Location = _canvas.HideFouce(Control.MousePosition);
                        }
                    };
                    _canvas.AddChild(label1);
                    _canvas.RemoveChild(te);
                }
                else if (es.KeyCode == Keys.Escape)
                {
                    _canvas.RemoveChild(te);
                }
            };
            _canvas.AddChild(te);
        }
        public void OnMouseDoubleClick(MouseEventArgs e)
        {
            Addstring(e.Location, "");
        }

设置线条宽
在这里插入图片描述
在Form1的menustrip中添加一个设置菜单,加入textbox控件
在这里插入图片描述
在它的KeyDown事件中,添加代码

 private void toolStripTextBox1_KeyDown(object sender, KeyEventArgs e)
        {
            if (e.KeyCode == Keys.Enter)
            {
                float _penwidth;
                if (float.TryParse(toolStripTextBox1.Text.Trim(), out _penwidth))
                {
                    _presenter.worldDraw.pen.Width = _penwidth;
                }
            }
        }

将图画保存

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在Form2界面添加FolderBrowserDialog控件 ,保存事件中添加方法

private void 保存ToolStripMenuItem_Click(object sender, EventArgs e)
        {
            //将图片保存        
            if (docForm != null)
            {
                if (folderBrowserDialog1.ShowDialog() == DialogResult.OK)
                {
                    docForm.Saveimage(folderBrowserDialog1.SelectedPath);
                    MessageBox.Show("保存成功");
                }
            }
        }

在Form1中添加方法Saveimage

 public void Saveimage(string path)
        {
            _presenter.MySaveImage(path);
        }

在Presenter中添加方法MySaveImage

 public void MySaveImage(string path)
        {
            _bufferBitmap.Save(Path.Combine(path, "myfile.png"));//默认保存格式为PNG,保存成jpg格式质量不是很好
        }

就是这么强大,结束!

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yangzm996

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值