我们来比较winform窗体的this方式和win32api handle方式实现窗体的最大化、默认窗体、半透明、不透明的区别

1、窗体界面设计

this方式按钮: btnMaxWindow、 btnNormalWindow、btnOpaWindow 、btnOpacityWindow

handle方式按钮: btnMaxWindow1、 btnNormalWindow1、btnOpaWindow1 、btnOpacityWindow1

2、使用句柄(handle)

首先在项目中引入所需win32api的函数方法

         /// <summary>
/// windowapi 找到指定窗体的句柄函数
/// </summary>
/// <param name="lpClassName">窗体类名</param>
/// <param name="lpWindowName">窗体标题名</param>
/// <returns>返回窗体句柄(IntPtr)</returns>
[DllImport("user32.dll", EntryPoint = "FindWindow", SetLastError = true)]
public static extern IntPtr FindWindow(string lpClassName, string lpWindowName); /// <summary>
/// windowapi 通过句柄显示或隐藏窗体函数
/// </summary>
/// <param name="hWnd">窗体句柄</param>
/// <param name="cmdShow">显示类型(0:隐藏窗体,1:默认大小窗体,2:最小化窗体,3:最大化窗体)</param>
/// <returns>返回成功或失败</returns>
[DllImport("user32.dll", EntryPoint = "ShowWindowAsync", SetLastError = true)]
public static extern bool ShowWindowAsync(IntPtr hWnd, int cmdShow); /// <summary>
/// 设置窗体透明度属性
/// </summary>
/// <param name="hwnd">窗体句柄</param>
/// <param name="crKey">掩码颜色</param>
/// <param name="bAlpha">不透明度</param>
/// <param name="dwFlags">透明方式</param>
/// <returns></returns>
[DllImport("user32.dll", SetLastError = true)]
static extern bool SetLayeredWindowAttributes(IntPtr hwnd, uint crKey, byte bAlpha, uint dwFlags);

3、比较this和handle的区别

1) 最大化窗体

        #region  设置窗体最大化(this、handle)

        /// <summary>
/// this方式 设置窗体最大化
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnMaxWindow_Click(object sender, EventArgs e)
{
//设置窗体状态为最大化
this.WindowState = FormWindowState.Maximized;
//不显示在任务栏
this.ShowInTaskbar = false;
//设置窗体为不可见
// this.Visible = true;
} /// <summary>
/// handle方式 通过句柄设置窗体最大化
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnMaxWindow1_Click(object sender, EventArgs e)
{
//获取窗体句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,最大化窗体
ShowWindowAsync(handle, );
}
} #endregion

2)默认窗体

        #region 设置窗体默认大小(this、handle)

        /// <summary>
/// this方式 设置窗体默认大小
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnNormalWindow_Click(object sender, EventArgs e)
{
//设置窗体状态为默认大小
this.WindowState = FormWindowState.Normal;
//不显示在任务栏
this.ShowInTaskbar = false;
//设置窗体为不可见
//this.Visible = false;
} /// <summary>
/// handle方法 设置窗体默认大小
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnNormalWindow1_Click(object sender, EventArgs e)
{
//获取窗体句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,弹出窗体默认大小
ShowWindowAsync(handle, );
}
} #endregion

3)半透明窗体

        #region 设置窗体为半透明(this、handle)

        /// <summary>
/// this方式 设置窗体透明度为半透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpaWindow_Click(object sender, EventArgs e)
{
//设置当前窗体为不透明度为0.5
this.Opacity = 0.5;
} /// <summary>
/// handle方式 设置窗体透明度为半透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpaWindow1_Click(object sender, EventArgs e)
{
//通过win32FindWindow()函数,获取窗体的句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,设置窗体透明度为半透明(第一个参数:窗体句柄;第二参数:掩码颜色;第三个参数:透明度,范围0-255)
SetLayeredWindowAttributes(handle, , , 0x00000002);
}
} #endregion

4)不透明窗体

 #region 设置窗体为不透明(this、handle)

        /// <summary>
/// this方式 设置窗体为不透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpacityWindow_Click(object sender, EventArgs e)
{
//设置窗体为不透明(0~1)
this.Opacity = ;
} /// <summary>
/// handle方式 设置窗体为不透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpacityWindow1_Click(object sender, EventArgs e)
{
//通过win32FindWindow()函数,获取窗体的句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,设置窗体透明度为不透明(第一个参数:窗体句柄;第二参数:掩码颜色;第三个参数:透明度,范围0-255)
SetLayeredWindowAttributes(handle, , , 0x00000002);
}
} #endregion

4、完整源码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms; namespace WindowsForms
{ public partial class Form1 : Form
{
/// <summary>
/// windowapi 找到指定窗体的句柄函数
/// </summary>
/// <param name="lpClassName">窗体类名</param>
/// <param name="lpWindowName">窗体标题名</param>
/// <returns>返回窗体句柄(IntPtr)</returns>
[DllImport("user32.dll", EntryPoint = "FindWindow", SetLastError = true)]
public static extern IntPtr FindWindow(string lpClassName, string lpWindowName); /// <summary>
/// windowapi 通过句柄显示或隐藏窗体函数
/// </summary>
/// <param name="hWnd">窗体句柄</param>
/// <param name="cmdShow">显示类型(0:隐藏窗体,1:默认大小窗体,2:最小化窗体,3:最大化窗体)</param>
/// <returns>返回成功或失败</returns>
[DllImport("user32.dll", EntryPoint = "ShowWindowAsync", SetLastError = true)]
public static extern bool ShowWindowAsync(IntPtr hWnd, int cmdShow); /// <summary>
/// 设置窗体透明度属性
/// </summary>
/// <param name="hwnd">窗体句柄</param>
/// <param name="crKey">掩码颜色</param>
/// <param name="bAlpha">不透明度</param>
/// <param name="dwFlags">透明方式</param>
/// <returns></returns>
[DllImport("user32.dll", SetLastError = true)]
static extern bool SetLayeredWindowAttributes(IntPtr hwnd, uint crKey, byte bAlpha, uint dwFlags); public Form1()
{
InitializeComponent();
//第一次运行弹出显示在屏幕中间
this.StartPosition = FormStartPosition.CenterScreen;
} #region 设置窗体最大化(this、handle) /// <summary>
/// this方式 设置窗体最大化
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnMaxWindow_Click(object sender, EventArgs e)
{
//设置窗体状态为最大化
this.WindowState = FormWindowState.Maximized;
//不显示在任务栏
this.ShowInTaskbar = true;
//设置窗体为不可见
// this.Visible = true;
} /// <summary>
/// handle方式 通过句柄设置窗体最大化
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnMaxWindow1_Click(object sender, EventArgs e)
{
//获取窗体句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,最大化窗体
ShowWindowAsync(handle, );
}
} #endregion #region 设置窗体默认大小(this、handle) /// <summary>
/// this方式 设置窗体默认大小
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnNormalWindow_Click(object sender, EventArgs e)
{
//设置窗体状态为默认大小
this.WindowState = FormWindowState.Normal;
//不显示在任务栏
this.ShowInTaskbar = false;
//设置窗体为不可见
//this.Visible = false;
} /// <summary>
/// handle方法 设置窗体默认大小
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnNormalWindow1_Click(object sender, EventArgs e)
{
//获取窗体句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,弹出窗体默认大小
ShowWindowAsync(handle, );
}
} #endregion #region 设置窗体为半透明(this、handle) /// <summary>
/// this方式 设置窗体透明度为半透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpaWindow_Click(object sender, EventArgs e)
{
//设置当前窗体为不透明度为0.5
this.Opacity = 0.5;
} /// <summary>
/// handle方式 设置窗体透明度为半透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpaWindow1_Click(object sender, EventArgs e)
{
//通过win32FindWindow()函数,获取窗体的句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,设置窗体透明度为半透明(第一个参数:窗体句柄;第二参数:掩码颜色;第三个参数:透明度,范围0-255)
SetLayeredWindowAttributes(handle, , , 0x00000002);
}
} #endregion #region 设置窗体为不透明(this、handle) /// <summary>
/// this方式 设置窗体为不透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpacityWindow_Click(object sender, EventArgs e)
{
//设置窗体为不透明(0~1)
this.Opacity = ;
} /// <summary>
/// handle方式 设置窗体为不透明
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnOpacityWindow1_Click(object sender, EventArgs e)
{
//通过win32FindWindow()函数,获取窗体的句柄
IntPtr handle = FindWindow(null, "测试窗体");
if (handle != IntPtr.Zero)
{
//通过句柄,设置窗体透明度为不透明(第一个参数:窗体句柄;第二参数:掩码颜色;第三个参数:透明度,范围0-255)
SetLayeredWindowAttributes(handle, , , 0x00000002);
}
} #endregion } }

5、演示窗体顺序

(1)先按this方式的最大化窗体,handle方式恢复默认1

(2)先按handle方式的最大化窗体1,this方式恢复默认

(3)先按this方式的半透明窗体,handle方式不透明窗体1

(4)先按handle方式的半透明窗体1,this方式不透明窗体

演示的效图

按了this方式的半透明按钮

按钮handle方式不透明按钮1

winform窗体this方式和handle(句柄)方式的区别的更多相关文章

  1. winform窗体控件(全)

    回顾跟补充下除了昨天那常用6个其他的winform窗体控件作用 1:Button:按钮 (1)AutoSize:如果是True的情况下,内容将会撑开:False的话会另起一行 (2)Enabled: ...

  2. 重绘Winform窗体

    本文转载自:http://www.cnblogs.com/encoding/p/5603080.html 按照惯例,先来几张样例图(注:为了展示窗口阴影效果,截图范围向外扩展了些,各位凭想象吧). 还 ...

  3. 单例模式(Winform窗体的实现)

    在我的设计模式分类当中,我选择单例模式作为我第一个要写的设计模式,其一,单例模式简单.容易理解让人接受,其二,单例模式很常用,在实际的Winform窗体应用开发中能够带来更好的客户体验. 单例模式的核 ...

  4. 【开源】做了一个WinForm窗体的投影组件,能够为窗口添加影子效果

    最近手头上的项目终于忙得差不多了,想起好久没有更新了的NanUI,再看着每天QQ群未读消息闪烁的标志,突然才发现似乎愧对了群里各位喜爱NanUI的朋友们.于是乎,就想趁这几天有时间,好好的修复一下Na ...

  5. winform窗体嵌套HTML页面,开发出炫彩桌面程序

    一:CEF全称Chromium Embedded Framework,是一个基于Google Chromium 的开源项目.Google Chromium项目主要是为Google Chrome应用开发 ...

  6. C# winform窗体间传值(使用委托或事件)

    窗体间传值 今天得空,刚好看到网上好多人再找winform窗体间传值的问题,由于昨天项目的优化的感觉不错,就写了个C# winform窗体间传值的demo,希望能给需要的人的带来帮助: 工程的源代码地 ...

  7. exe程序嵌入Winform窗体

    1.新建winform程序,添加一个Panel控件和一个button控件,winform窗体命名为:Mainform: 2.新建一个类文件,方便引用,命名为:exetowinform: 3.Mainf ...

  8. C# Winform 窗体传值 利用委托 子窗体传值给父窗体

    常用的Winform窗体传值有两种方式. 1.更改Form.designer.cs文件,将控件的设为Public,供子窗体访问. 在designer.cs文件的最后,找到你的控件声明. private ...

  9. C#使用事件方式Winform窗体之间传值

    [摘自:http://www.cnblogs.com/codeToUp/p/5371062.html] 工程的源代码地址:https://github.com/yes-or-no/WinFormTra ...

随机推荐

  1. Poisson Blending(Seamless clone)研究和实现

    Poisson Blending 实现了非常棒的效果,可以看 <自己动手,实现“你的名字”滤镜> http://www.cnblogs.com/jsxyhelu/p/7216795.htm ...

  2. 20145127《java程序设计》第二周学习总结

    本周我又对java程序进行了更进一步的学习.相比与上一周的学习内容的宏观,这一周的所学更加的系统和调理明确. 本周是对java基础语法的学习.首先,我先是认识类型与变量. Java可区分为基本类型和类 ...

  3. 20145312《网络对抗》MSF基础

    20145312<网络对抗>MSF基础 实验要求 1.掌握metasploit的基本应用方式 2.掌握常用的三种攻击方式的思路 实验问答 用自己的话解释什么是exploit.payload ...

  4. payload

    payload就是协议报文中的有效载荷所占报文的百分比,用报文中去除协议的长度/报文总长度,协议设计的时候需要考虑到有效载荷所占的比重,避免出现payload很小的情况,比如TCP在设计的时候,就考虑 ...

  5. boot sector FAT

  6. dubbo 实战总结

    1,出现重复调用.因为有重试机制,可以改为异步调用或者幂等操作.

  7. org.apache.jasper.JasperException: /WEB-INF/view/../../../common/common1.jsp (line: 7, column: 1) Page directive must not have multiple occurrences of pageencoding

    本文为博主原创,未经允许,不得转载: 先还原错误: org.apache.jasper.JasperException: /WEB-INF/view/../../../../common/common ...

  8. HDU 5873 Football Games(竞赛图兰道定理)

    http://acm.hdu.edu.cn/showproblem.php?pid=5873 题意: 现在有比赛,所有队伍两两进行比赛,赢的积2分,输的积0分,如果平局的话就各自都积1分,现在给出每只 ...

  9. UVa 818 切断圆环链(dfs+二进制枚举)

    https://vjudge.net/problem/UVA-818 题意:有n个圆环,其中有一些已经扣在了一起.现在需要打开尽量少的圆环,使得所有圆环可以组成一条链,例如,有5个圆环,1-2,2-3 ...

  10. Cocos2d-x学习笔记(八)精灵对象的创建

    精灵类即是Sprite,它实际上就是一张二维图. 它首先直接继承了Node类,因此,它具有节点的特征,同时,它也直接继承了TextureProtocol类,因此,它也具有纹理的基本特征. 这里,有必要 ...