流布局面板 - 如何设置动画

时间:2014-03-20 15:25:37

标签: c# winforms flowlayoutpanel

我正在开发Windows窗体应用程序。我正在使用FlowLayoutPanel。 我将所有控件放在FlowLayoutPanel面板中。我有兴趣做像Windows 8主屏幕这样的事情。我会将控件放在FlowLayoutPanel面板中,并以一定的速度一个接一个地控制。

有没有选择来实现这个目标?

其实我在做的是,

在我的表单中,我在FlowLayoutPanel

中有如下控件

主要FlowLayoutPanel属性。

this.flpFullLayout.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
                    | System.Windows.Forms.AnchorStyles.Left)));
this.flpFullLayout.AutoScroll = true;
this.flpFullLayout.BackColor = System.Drawing.SystemColors.Control;
this.flpFullLayout.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle;
this.flpFullLayout.FlowDirection = System.Windows.Forms.FlowDirection.TopDown;
this.flpFullLayout.Location = new System.Drawing.Point(2, 32);
this.flpFullLayout.Name = "flpFullLayout";
this.flpFullLayout.Size = new System.Drawing.Size(1014, 559);
this.flpFullLayout.Controls.Add(this.pnlDummy1);
this.flpFullLayout.Controls.Add(this.pnlAddUserFull);
this.flpFullLayout.Controls.Add(this.pnlDummy2);
this.flpFullLayout.Controls.Add(this.pnlAccess);
this.flpFullLayout.Controls.Add(this.pnlDummy3);
this.flpFullLayout.Controls.Add(this.pnlDashBord);

在表单加载中,我通过后台工作程序减少虚拟面板大小。

Thread.Sleep(200);
            if (pnlDummy2.InvokeRequired)
                pnlDummy2.Invoke(new MethodInvoker(delegate
                {
                    for (int len = 570; len > 0; len -= 10)
                   {
                        Thread.Sleep(2);
                        pnlDummy2.Size = new Size(950, len);
                        flpFullLayout.ScrollControlIntoView(pnlAddUser);
                    }
                    pnlDummy2.Visible = false;
                    flpFullLayout.ScrollControlIntoView(pnlAddUser);
                }));
            else
            {
                for (int len = 570; len > 0; len -= 10)
                {
                    Thread.Sleep(2);
                    pnlDummy2.Size = new Size(950, len);
                    flpFullLayout.ScrollControlIntoView(pnlAddUser);
                }
                pnlDummy2.Visible = false;
                flpFullLayout.ScrollControlIntoView(pnlAddUser);
            }
            Thread.Sleep(200);
            if (pnlDummy3.InvokeRequired)
                pnlDummy3.Invoke(new MethodInvoker(delegate
                {
                    for (int len = 570; len > 0; len -= 10)
                    {
                        Thread.Sleep(2);
                        pnlDummy3.Size = new Size(950, len);
                        flpFullLayout.ScrollControlIntoView(pnlAddUser);
                    }
                    pnlDummy3.Visible = false;
                    flpFullLayout.ScrollControlIntoView(pnlAddUser);
                }));
            else
            {
                for (int len = 570; len > 0; len -= 10)
               {
                    Thread.Sleep(2);
                   pnlDummy3.Size = new Size(950, len);
                   flpFullLayout.ScrollControlIntoView(pnlAddUser);
                }
                pnlDummy3.Visible = false;
                flpFullLayout.ScrollControlIntoView(pnlAddUser);
            }

我正在做这件事来实现简单的动画。有没有简单的方法可以做到这一点。

1 个答案:

答案 0 :(得分:1)

如果您使用Windows窗体执行此操作,那么您将自己限制在可以实现的目标之上。

如果您自己推出此解决方案,那么最好不要使用完全自定义控件。

如果你有一些闲钱,那里已经有组件公司提供了windows 8风格的地铁瓷砖界面。

为获得最佳效果,请抛弃Windows窗体并使用WPF。