C# Winform在图片上添加自定义螺丝控件,并调整位置

        在Winform项目中,我们经常遇到需要显示特殊形状的控件,但是常用基础控件又不满足要求时,我们通常需要自定义控件,并实现其需要的功能。本实例就是自定义圆形的螺丝控件,并对其进行编号和添加选择事件,并可动态调整其位置,支持鼠标框选多个控件。具体效果如下:

实例代码链接:https://download.csdn.net/download/lvxingzhe3/89436437

Winform鼠标框选控件代码:

  private void Form1_Load(object sender, EventArgs e)
        {

            panel1.MouseDown += new MouseEventHandler(MouseDown);
            panel1.MouseUp += new MouseEventHandler(MouseUp);
            panel1.MouseMove += new MouseEventHandler(MouseMove);

        }
        //定义两个变量 
        bool MouseIsDown = false;
        Rectangle MouseRect = Rectangle.Empty; //矩形(为鼠标画出矩形选区)
        #region mouseMove
        //定义三个方法
        private void ResizeToRectangle(object sender, Point p)
        {
            DrawRectangle(sender);
            MouseRect.Width = p.X - MouseRect.Left;
            MouseRect.Height = p.Y - MouseRect.Top;
            DrawRectangle(sender);
        }
        private void DrawRectangle(object sender)
        {
            Rectangle rect = ((Panel)sender).RectangleToScreen(MouseRect);
            ControlPaint.DrawReversibleFrame(rect, Color.White, FrameStyle.Dashed);
        }

        private void DrawStart(object sender, Point StartPoint)
        {
            ((Panel)sender).Capture = true;
            Cursor.Clip = ((Panel)sender).RectangleToScreen(((Panel)sender).Bounds);
            MouseRect = new Rectangle(StartPoint.X, StartPoint.Y, 0, 0);
        }

        private void MouseDown(object sender, MouseEventArgs e)
        {
            MouseIsDown = true;
            DrawStart(sender, e.Location);
        }

        private void MouseUp(object sender, MouseEventArgs e)
        {
            this.Capture = false;
            Cursor.Clip = Rectangle.Empty;
            MouseIsDown = false;
            DrawRectangle(sender);
            MouseRect = Rectangle.Empty;
        }

        private void MouseMove(object sender, MouseEventArgs e)
        {
            if (MouseIsDown)
                ResizeToRectangle(sender, e.Location);


            foreach (Control button in ((Panel)sender).Controls)
            {
                if (MouseRect.IntersectsWith(button.Bounds)) //相交( MouseRect.Contains  完全包含)
                {
                    button.BackColor = Color.Blue;
                }

            }

        }

实例代码链接:https://download.csdn.net/download/lvxingzhe3/89436437

参考:

https://www.cnblogs.com/guo-pc31/p/3652263.html

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
WinForm中动态添加自定义控件的方式有多种,下面是一种常见的方法: 1. 在代码中创建一个循环,根据需要的控件数量进行迭代。例如,可以使用for循环来决定控件的数量。 2. 在循环内部,创建自定义控件的实例。可以使用自定义控件的构造函数来创建控件实例,并设置控件的属性,如名称、大小和位置。 3. 将自定义控件添加到相应的容器控件中。可以使用容器控件的Controls属性来访问和添加控件。使用Add方法将自定义控件添加到容器控件的Controls集合中。 4. 可以为自定义控件设置相应的事件处理程序。例如,可以为自定义控件的点击事件设置一个事件处理程序,以便在点击控件时执行特定的操作。 5. 最后,将容器控件添加到主窗体中,以便在应用程序中显示这些自定义控件。 下面是一个示例代码,演示了如何动态添加自定义控件(以麦田怪圈为例): ``` for (int i = 0; i < 5; i++) { Control.Refueller r1 = new Control.Refueller(); r1.sidePanel1.Click += new EventHandler(r1click); r1.Name = "jy" + i; r1.Size = new Size(220, 281); r1.Location = new Point(220 * i, 0); r1.Show(); panel1.Controls.Add(r1); } private void r1click(object sender, EventArgs e) { MessageBox.Show(this.Name); } ``` 在上述示例中,使用了一个for循环来创建了5个麦田怪圈的自定义控件,并将它们添加到名为panel1的容器控件中。同时,为每个控件的点击事件设置了一个事件处理程序r1click,以便在点击控件时弹出一个消息框。 请注意,以上示例代码仅为演示目的,并假设已经创建了自定义控件Refueller和相应的事件处理程序r1click。你可以根据自己的需求来调整代码,并在其中添加其他所需的控件和事件处理程序。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [C# winform 动态添加自定义控件](https://blog.csdn.net/qq_36074218/article/details/103765069)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [winform如何添加自定义控件,如何给自定义控件添加事件](https://blog.csdn.net/xiexiaodai/article/details/125040976)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

无熵~

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

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

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

打赏作者

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

抵扣说明:

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

余额充值