UI上的label控件为什么不按设计的刷新?

最近由于项目需要,在学习C#程序开发;

遇到一个有意思的问题:Label的Text属性赋值了,但是前面板并不按照设计改变;

问题代码如下:

复制代码
 public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            label1.Text = "提示";
            label2.Text = "点击按钮选择要转换的文件";
            label2.BackColor = Color.White;
            this.Text = "转换";
        }

        private void button1_Click(object sender, EventArgs e)
        {
            OpenFileDialog openFile = new OpenFileDialog();
            openFile.Multiselect = false;
            openFile.Filter = "image files(*.m3dm)|*.m3dm|All files(*.*)|*.*";
            if (openFile.ShowDialog() == DialogResult.OK)
            {
                        label2.Text = "转换中...";
                        label2.BackColor = Color.Yellow;//此处想要指示转换状态

                System.Threading.Thread.Sleep(1000);


                try
                {



                    MP3DFrameManaged Buffer3DLast = new MP3DFrameManaged(openFile.FileName);
                    ToHImage(Convert3DTargetType.Z, Buffer3DLast, openFile.FileName);


                    this.Invoke(new Action(delegate
                    {
                        label2.Text = "转换成功!";
                        label2.BackColor = Color.Green;
                    }));

                }
                catch (Exception)
                {
                    label2.Text = "转换失败!";
                    label2.BackColor = Color.Red;
                }

            }
            else
            {
            label2.Text = "点击按钮选择要转换的文件";
            label2.BackColor = Color.White;
            }
        }
复制代码

但是整个过程中并不能看到UI界面的Label2控件背景色变为黄色;

苦苦思索了很久,不解。

最后在朋友的帮助下找到了原因,多次连续刷新同一个控件属性时,需要增加如下代码;

label2.Text = "转换中...";
label2.BackColor = Color.Yellow;//此处想要指示转换状态
label2.Refresh();//这里就是解决此问题的关键,强制刷新

图片如下:

 

posted @   Stephen_Young  阅读(129)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?

喜欢请打赏

扫描二维码打赏

微信打赏

点击右上角即可分享
微信分享提示