C# 文件拖拽和pixturBox缩放与拖拽功能

时间:2021-05-20

文件拖拽:

效果:将一个文件拖拽到窗体的某个控件时,将该控件的路径显示在该控件上,只要拿到了路径自然可以读取文件中的内容了。

将一个控件的属性AllowDrop设置为true,然后添加DragDrop、DragEnter时间处理函数,如下:

private void txtAppPath_DragEnter(object sender, System.Windows.Forms.DragEventArgs e) { if (e.Data.GetDataPresent(DataFormats.FileDrop)) { e.Effect = DragDropEffects.Link; } else { e.Effect = DragDropEffects.None; } } private void txtAppPath_DragDrop(object sender, System.Windows.Forms.DragEventArgs e) { txtLocalFileName.Text = ((System.Array)e.Data.GetData(DataFormats.FileDrop)).GetValue(0).ToString(); }

图片的缩放和拖拽:

一、实现鼠标滚轮控制图片缩放;

1、设置PixtureBox属性:

  Dock:none

  SizeMode:StretchImage

2、添加事件:

(1)设置绑定图片路径

private void ScrewInfoForm_Shown(object sender, EventArgs e) { //加载装配图纸 string drawingPath = Path.Combine(@"\\192.168.2.136\PCS", productCode + ".png"); try { pbxDrawing.Load(drawingPath); } catch (Exception ex) { MessageBox.Show("加载装配图纸失败,详细:" + ex.Message, "测量", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } }

(2)添加事件1

pbxDrawing.MouseWheel += new MouseEventHandler(pbxDrawing_MouseWheel);//实现滚轮缩放 private void pbxDrawing_MouseWheel(object sender, System.Windows.Forms.MouseEventArgs e) { if (e.Delta < 0) { this.pbxDrawing.Width = this.pbxDrawing.Width * 9 / 10; this.pbxDrawing.Height = this.pbxDrawing.Height * 9 / 10; } else { this.pbxDrawing.Width = this.pbxDrawing.Width * 11 / 10; this.pbxDrawing.Height = this.pbxDrawing.Height * 11 / 10; } }

(3)添加事件2

//实现移动图片 int xPos; int yPos; bool MoveFlag; private void pbxDrawing_MouseDown(object sender, MouseEventArgs e) { this.pbxDrawing.Focus(); MoveFlag = true;//已经按下. xPos = e.X;//当前x坐标. yPos = e.Y;//当前y坐标. } //在picturebox的鼠标按下事件里. private void pbxDrawing_MouseUp(object sender, MouseEventArgs e) { MoveFlag = false; } //在picturebox鼠标移动 private void pbxDrawing_MouseMove(object sender, MouseEventArgs e) { if (MoveFlag) { pbxDrawing.Left += Convert.ToInt16(e.X - xPos);//设置x坐标. pbxDrawing.Top += Convert.ToInt16(e.Y - yPos);//设置y坐标. } }

总结

以上所述是小编给大家介绍的c# 文件拖拽和pixturBox缩放与拖拽,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章