c#winform窗体鼠标穿透,做桌面小工具的来看看啦

失落的神庙 2012-12-22 10:45:30
        private const uint WS_EX_LAYERED = 0x80000;
private const int WS_EX_TRANSPARENT = 0x20;
private const int GWL_STYLE = (-16);
private const int GWL_EXSTYLE = (-20);
private const int LWA_ALPHA = 0;

[DllImport("user32", EntryPoint = "SetWindowLong")]
private static extern uint SetWindowLong(
IntPtr hwnd,
int nIndex,
uint dwNewLong
);

[DllImport("user32", EntryPoint = "GetWindowLong")]
private static extern uint GetWindowLong(
IntPtr hwnd,
int nIndex
);

[DllImport("user32", EntryPoint = "SetLayeredWindowAttributes")]
private static extern int SetLayeredWindowAttributes(
IntPtr hwnd,
int crKey,
int bAlpha,
int dwFlags
);

/// <summary>
/// 设置窗体具有鼠标穿透效果
/// </summary>
public void SetPenetrate()
{
this.TopMost = true;
GetWindowLong(this.Handle, GWL_EXSTYLE);
SetWindowLong(this.Handle, GWL_EXSTYLE, WS_EX_TRANSPARENT | WS_EX_LAYERED);
SetLayeredWindowAttributes(this.Handle, 0, 100, LWA_ALPHA);
}


可能有很多淫分享过。。。但还是忍不住来分享
...全文
985 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
YYLWX 2013-04-29
  • 打赏
  • 举报
回复
引用 12 楼 wawd74520 的回复:
MainForm.FormMian.FormBorderStyle = FormBorderStyle.FixedSingle;//此处为Form的静态对象。也可以用委托 执行此处可以取消穿透
MainForm.FormMian是什么东东。 另外实现局部穿透怎么实现,比如说只穿透一个Picurebox.
wy811007 2012-12-26
  • 打赏
  • 举报
回复
mark 不错 以后有用
失落的神庙 2012-12-26
  • 打赏
  • 举报
回复
可根据鼠标悬停位置和时间来取消穿透 比如悬停在窗体坐标区域5秒 触发 取消穿透
失落的神庙 2012-12-26
  • 打赏
  • 举报
回复
MainForm.FormMian.FormBorderStyle = FormBorderStyle.FixedSingle;//此处为Form的静态对象。也可以用委托 执行此处可以取消穿透
失落的神庙 2012-12-26
  • 打赏
  • 举报
回复
引用 10 楼 youzelin 的回复:
连整个标题栏都穿透了,整个 Form 本身根本无法接受鼠标事件了,能改进一下吗?
可加键盘钩子
using System;
using System.Collections.Generic;
using System.Text;
using System.Windows.Forms;
using System.Runtime.InteropServices;
using System.Diagnostics;

namespace WebClick_Tool
{
    public class KeyPress_o
    {
        [StructLayout(LayoutKind.Sequential)]
        public class KeyBoardHookStruct
        {
            public int vkCode;
            public int scanCode;
            public int flags;
            public int time;
            public int dwExtraInfo;
        }
        //委托 
        public delegate int HookProc(int nCode, int wParam, IntPtr lParam);
        static int hHook = 0;
        public const int WH_KEYBOARD_LL = 13;
        //LowLevel键盘截获,如果是WH_KEYBOARD=2,并不能对系统键盘截取,Acrobat Reader会在你截取之前获得键盘。 
        static HookProc KeyBoardHookProcedure;

        //设置钩子 
        [DllImport("user32.dll")]
        public static extern int SetWindowsHookEx(int idHook, HookProc lpfn, IntPtr hInstance, int threadId);
        [DllImport("user32.dll", CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)]
        //抽掉钩子 
        public static extern bool UnhookWindowsHookEx(int idHook);
        [DllImport("user32.dll")]
        //调用下一个钩子 
        public static extern int CallNextHookEx(int idHook, int nCode, int wParam, IntPtr lParam);
        [DllImport("kernel32.dll")]
        public static extern int GetCurrentThreadId();
        [DllImport("kernel32.dll")]
        public static extern IntPtr GetModuleHandle(string name);

        public static void Hook_Start()
        {
            if (hHook == 0)
            {
                KeyBoardHookProcedure = new HookProc(KeyBoardHookProc);
                hHook = SetWindowsHookEx(WH_KEYBOARD_LL, KeyBoardHookProcedure,
                        GetModuleHandle(Process.GetCurrentProcess().MainModule.ModuleName), 0);
                //如果设置钩子失败. 
                if (hHook == 0)
                {
                    Hook_Clear();
                }
            }
        }

        /// <summary>
        /// 取消钩子事件
        /// </summary>
        public static void Hook_Clear()
        {
            bool retKeyboard = true;
            if (hHook != 0)
            {
                retKeyboard = UnhookWindowsHookEx(hHook);
                hHook = 0;
            }
        }

        public static int KeyBoardHookProc(int nCode, int wParam, IntPtr lParam)
        {
            if (nCode >= 0)
            {
                KeyBoardHookStruct kbh = (KeyBoardHookStruct)Marshal.PtrToStructure(lParam, typeof(KeyBoardHookStruct));
                Keys k = (Keys)Enum.Parse(typeof(Keys), kbh.vkCode.ToString());
                switch (k)
                {
                    case Keys.F2:
                        if (kbh.flags == 0)
                        {
                            // 这里写按下后做什么事
                            MainForm.FormMian.FormBorderStyle = FormBorderStyle.FixedSingle;//此处为Form的静态对象。也可以用委托
                        }
                        else if (kbh.flags == 128)
                        {
                            //放开后做什么事
                        }
                        return 1;
                }
            }
            return CallNextHookEx(hHook, nCode, wParam, lParam);
        }
    }
}
youzelin 2012-12-26
  • 打赏
  • 举报
回复
连整个标题栏都穿透了,整个 Form 本身根本无法接受鼠标事件了,能改进一下吗?
  • 打赏
  • 举报
回复
dylike 2012-12-23
  • 打赏
  • 举报
回复
感谢分享,继续加油,我也是桌面爱好者.
hard_learner 2012-12-22
  • 打赏
  • 举报
回复
非常感谢分享!
Change_L 2012-12-22
  • 打赏
  • 举报
回复
Assassin_ 2012-12-22
  • 打赏
  • 举报
回复
whowhen21 2012-12-22
  • 打赏
  • 举报
回复
mark,
xyz254 2012-12-22
  • 打赏
  • 举报
回复
mark

110,567

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧