使用C#实现WinForm窗体的动画效果

【转】http://www.cnblogs.com/xvqm00/archive/2009/02/16/1391313.html

using System.Runtime.InteropServices;

 
public class Win32
 
{
  
public const Int32 AW_HOR_POSITIVE = 0x00000001// 从左到右打开窗口
  public const Int32 AW_HOR_NEGATIVE = 0x00000002// 从右到左打开窗口
  public const Int32 AW_VER_POSITIVE = 0x00000004// 从上到下打开窗口
  public const Int32 AW_VER_NEGATIVE = 0x00000008// 从下到上打开窗口
  public const Int32 AW_CENTER = 0x00000010//若使用了AW_HIDE标志,则使窗口向内重叠;若未使用AW_HIDE标志,则使窗口向外扩展。
  public const Int32 AW_HIDE = 0x00010000//隐藏窗口,缺省则显示窗口。
  public const Int32 AW_ACTIVATE = 0x00020000//激活窗口。在使用了AW_HIDE标志后不要使用这个标志。
  public const Int32 AW_SLIDE = 0x00040000//使用滑动类型。缺省则为滚动动画类型。当使用AW_CENTER标志时,这个标志就被忽略。
  public const Int32 AW_BLEND = 0x00080000//使用淡出效果。只有当hWnd为顶层窗口的时候才可以使用此标志。
  [DllImport("user32.dll", CharSet = CharSet.Auto)]
  
public static extern bool AnimateWindow(
    IntPtr hwnd, 
// handle to window 
    int dwTime, // duration of animation 
    int dwFlags // animation type 
    );
 }


 
/**//*淡入窗体*/
 
private void Form_Load(object sender, EventArgs e)
 
{
  Win32.AnimateWindow(
this.Handle, 2000, Win32.AW_BLEND);
 }

 
/**//*淡出窗体*/
 
private void Form_FormClosing(object sender, FormClosingEventArgs e)
 
{
  Win32.AnimateWindow(
this.Handle, 2000, Win32.AW_SLIDE | Win32.AW_HIDE | Win32.AW_BLEND);
 }


2,窗体居中

Code
        /**//// <summary>
        
/// 页面居中
        
/// </summary>
        public static void SetMid(Form form)
        
{
            
// Center the Form on the user's screen everytime it requires a Layout.
            form.SetBounds((Screen.GetBounds(form).Width / 2- (form.Width / 2),
                (Screen.GetBounds(form).Height 
/ 2- (form.Height / 2),
                form.Width, form.Height, BoundsSpecified.Location);
        }

这里是一个静态方法,参数为你需要设置居中的窗口对象。你可以在该窗口加载的时候加载这个静态方法实现你要的效果!

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Winform实现动画效果可以借助一些框架和代码来实现。一个常见的动画效果是滑入效果。你可以使用类似jQuery的框架,如使用C#Winform框架中的Animation类来实现滑入效果。 下面是一个代码示例,展示了如何使用Animation类来实现滑入效果: ```csharp if (Animation.control != control && destSize.IsEmpty) { destSize = new Size(control.Width, control.Height); } Animation.control = control; Animation.direction = direction; switch (direction) { case AnchorStyles.Left: case AnchorStyles.Right: if (direction == AnchorStyles.Left) control.Left = control.Width; control.Width = 0; break; case AnchorStyles.Top: case AnchorStyles.Bottom: if (direction == AnchorStyles.Top) control.Top = control.Height; control.Height = 0; break; } control.Show(); tmrAnim.Start(); ``` 这段代码中,destSize变量用于存储控件的目标大小。根据滑入的方向,通过改变控件的位置和大小来实现滑入效果。最后,调用control.Show()方法显示控件,并通过tmrAnim.Start()方法启动动画。 在开发过程中,你可以根据需要适当地使用动画效果来提升用户体验。虽然网上有很多关于Winform动画效果的代码和示例,但需要注意选择可靠的资源来确保代码的运行正常。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [winform 实现动画效果。](https://blog.csdn.net/ligaogang/article/details/83617281)[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_2"}}] [.reference_item style="max-width: 50%"] - *3* [Winform窗体动画效果](https://download.csdn.net/download/shanxing_123/8333163)[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_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值