Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/qt/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 控制透明度_C#_Winforms - Fatal编程技术网

C# 控制透明度

C# 控制透明度,c#,winforms,C#,Winforms,因此,经过一段时间的尝试,我最终决定询问一种使透明控件相互显示的方法 正如您在图片中看到的,我有两个透明的图片框,它们很好地显示了背景,但是当涉及到所选的图片框时,正如您在图片中看到的,它只渲染表单的背景图像,而不是它下面的另一个图片框。我知道winforms中有一种常见的情况是由于缺乏适当的渲染,但问题是: 有没有办法解决这个渲染问题,有没有办法让透明控件彼此渲染 答案是这样的:控件的透明度取决于它的父控件。但是,您可以使用自定义容器控件而不是父图像的图片框。也许这段代码是完整的 u

因此,经过一段时间的尝试,我最终决定询问一种使透明控件相互显示的方法

正如您在图片中看到的,我有两个透明的图片框,它们很好地显示了背景,但是当涉及到所选的图片框时,正如您在图片中看到的,它只渲染表单的背景图像,而不是它下面的另一个图片框。我知道winforms中有一种常见的情况是由于缺乏适当的渲染,但问题是:

有没有办法解决这个渲染问题,有没有办法让透明控件彼此渲染


答案是这样的:

控件的透明度取决于它的父控件。但是,您可以使用自定义容器控件而不是父图像的图片框。也许这段代码是完整的

    using System;
using System.Windows.Forms;
using System.Drawing;

public class TransparentControl : Control
{
    private readonly Timer refresher;
    private Image _image;

    public TransparentControl()
    {
        SetStyle(ControlStyles.SupportsTransparentBackColor, true);
        BackColor = Color.Transparent;
        refresher = new Timer();
        refresher.Tick += TimerOnTick;
        refresher.Interval = 50;
        refresher.Enabled = true;
        refresher.Start();
    }

    protected override CreateParams CreateParams
    {
        get
        {
            CreateParams cp = base.CreateParams;
            cp.ExStyle |= 0x20;
            return cp;
        }
    }

    protected override void OnMove(EventArgs e)
    {
        RecreateHandle();
    }


    protected override void OnPaint(PaintEventArgs e)
    {
        if (_image != null)
        {
            e.Graphics.DrawImage(_image, (Width / 2) - (_image.Width / 2), (Height / 2) - (_image.Height / 2));
        }
    }

    protected override void OnPaintBackground(PaintEventArgs e)
    {
       //Do not paint background
    }

    //Hack
    public void Redraw()
    {
        RecreateHandle();
    }

    private void TimerOnTick(object source, EventArgs e)
    {
        RecreateHandle();
        refresher.Stop();
    }

    public Image Image
    {
        get
        {
            return _image;
        }
        set
        {
            _image = value;
            RecreateHandle();
        }
    }
}

不幸的是,这并没有给出预期的结果,还有其他想法吗?