WPF窗体使用AllowsTransparency="True"属性后,从最小化恢复时会有阴影

马云飞 2015-06-04 01:51:12
因为程序自带的边框不好看所以用了AllowsTransparency="True"和 WindowStyle="None"隐藏了边框,但这样却引发了一个问题,当程序从最小化恢复时,会有很短时间的黑色阴影如图所示


...全文
1238 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
一个人听着歌 2019-06-14
  • 打赏
  • 举报
回复
引用 6 楼 openeve 的回复:
使用 AllowsTransparency="True" WindowStyle="None" 解决办法 protected override void OnStateChanged(EventArgs e) { switch (WindowState) { case WindowState.Normal: Opacity = 1; break; case WindowState.Minimized: Opacity = 0; break; } }
这个方法好 赞!
cXspark 2019-06-06
  • 打赏
  • 举报
回复
引用 6 楼 openeve的回复:
使用 AllowsTransparency="True" WindowStyle="None"
解决办法
protected override void OnStateChanged(EventArgs e)
{
switch (WindowState)
{
case WindowState.Normal:
Opacity = 1;
break;
case WindowState.Minimized:
Opacity = 0;
break;
}
}
雪中送炭啊 老哥 困扰了很久
openeve 2018-12-23
  • 打赏
  • 举报
回复
使用 AllowsTransparency="True" WindowStyle="None"
解决办法
protected override void OnStateChanged(EventArgs e)
{
switch (WindowState)
{
case WindowState.Normal:
Opacity = 1;
break;
case WindowState.Minimized:
Opacity = 0;
break;
}
}
ok-go 2016-08-30
  • 打赏
  • 举报
回复
虽然提问已经过好久了,还是答一下吧, wpf 自定义窗口有两个方式 : 第一种: AllowsTransparency="True"和 WindowStyle="None" 也是比较多人用的,但是就会出现你所说的现象,不停的窗口最小化、打开会有花屏的情况--(有些人说是显卡问题,你说傻不傻)。 第二种: 使用 WindowChrome ,引用 Microsoft.Windows.Shell ,这种不需要设置WindowStyle 这些东西,就不会出现花屏的情况,推荐用这种方式 具体可以看看别人写的用法:http://blog.csdn.net/duanzilin/article/details/6385151
胖头鱼2016 2016-07-07
  • 打赏
  • 举报
回复
AllowsTransparency="True"这个属性别要了,你自定义一个窗体的最大化,最小化没问题
exception92 2015-06-04
  • 打赏
  • 举报
回复
引用 2 楼 marshalyunfei 的回复:
[quote=引用 1 楼 duanzi_peng 的回复:] 隐藏了边框 WindowStyle="None" 这句就ok了
您好,感谢您的回复, WindowStyle="None" 已经加到了代码中,可还是会出现此问题 [/quote] 这样 你建立一个空窗体,再设置上边的代码。如果还是没有问题,那就是 你xaml 样式的问题了
马云飞 2015-06-04
  • 打赏
  • 举报
回复
引用 1 楼 duanzi_peng 的回复:
隐藏了边框 WindowStyle="None" 这句就ok了
您好,感谢您的回复, WindowStyle="None" 已经加到了代码中,可还是会出现此问题
exception92 2015-06-04
  • 打赏
  • 举报
回复
隐藏了边框 WindowStyle="None" 这句就ok了
自定义窗体的最大化、最小化和关闭按钮, C#移动无标题栏窗体的三种代码: C#移动无标题栏窗体的三种代码:第一种采用,需注意窗体上的控件是否把窗体覆盖了。。。MouseDown、MouseMove、MouseUp事件应该是鼠标所处位置最顶层的控件的事件 在窗体的类中声明两个变量 private Point mouseOffset; //记录鼠标指针的坐标 private bool isMouseDown = false; //记录鼠标按键是否按下 创建该窗体 MouseDown、MouseMove、MouseUp事件的相应处理程序 private void Form1_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e) { int xOffset; int yOffset; if (e.Button == MouseButtons.Left) { xOffset = -e.X ; yOffset = -e.Y ; mouseOffset = new Point(xOffset, yOffset); isMouseDown = true; } } private void Form1_MouseMove(object sender, System.Windows.Forms.MouseEventArgs e) { if (isMouseDown) { Point mousePos = Control.MousePosition; mousePos.Offset(mouseOffset.X, mouseOffset.Y); Location = mousePos; } } private void Form1_MouseUp(object sender, System.Windows.Forms.MouseEventArgs e) { // 修改鼠标状态isMouseDown的值 // 确保只有鼠标左键按下并移动时,才移动窗体 if (e.Button == MouseButtons.Left) { isMouseDown = false; } } 第二种调用API 未验证 using System.Runtime.InteropServices; [DllImport("user32.dll")] public static extern bool ReleaseCapture(); [DllImport("user32.dll")] public static extern bool SendMessage(IntPtr hwnd, int wMsg, int wParam, int lParam); public const int WM_SYSCOMMAND = 0x0112; public const int SC_MOVE = 0xF010; public const int HTCAPTION = 0x0002; private void Form1_MouseDown(object sender, MouseEventArgs e) { ReleaseCapture(); SendMessage(this.Handle, WM_SYSCOMMAND, SC_MOVE + HTCAPTION, 0); } 第三种未验证 private bool isMouseDown = false; private Point FormLocation; //form的location private Point mouseOffset; //鼠标的按下位置 [DllImport("user32.dll")] public static extern bool ReleaseCapture(); [DllImport("user32.dll")] public static extern bool SendMessage(IntPtr hwnd, int wMsg, int wParam, int lParam); private const int WM_SYSCOMMAND = 0x0112;//点击窗口左上角那个图标时的系统信息 private const int SC_MOVE = 0xF010;//移动信息 private const int HTCAPTION = 0x0002;//表示鼠标在窗口标题栏时的系统信息 private const int WM_NCHITTEST = 0x84;//鼠标在窗体客户区(除了标题栏和边框以外的部分)时发送的消息 private const int HTCLIENT = 0x1;//表示鼠标在窗口客户区的系统消息 private const int SC_MAXIMIZE = 0xF030;//最大化信息 private const int SC_MINIMIZE = 0xF020;//最小化信息 protected override void WndProc(ref Message m) { switch (m.Msg) { case WM_SYSCOMMAND: if (m.WParam == (IntPtr)SC_MAXIMIZE) { m.WParam = (IntPtr)SC_MINIMIZE; } break; case WM_NCHITTEST: //如果鼠标移动或单击 base.WndProc(ref m);//调用基类的窗口过程——WndProc方法处理这个消息 if (m.Result == (IntPtr)HTCLIENT)//如果返回的是HTCLIENT { m.Result = (IntPtr)HTCAPTION;//把它改为HTCAPTION return;//直接返回退出方法 } break; } base.WndProc(ref m);//如果不是鼠标移动或单击消息就调用基类的窗口过程进行处理 } private void Form1_Load(object sender, EventArgs e) { } ------------------------------- 如何在窗体标题栏左边的控制菜单加入自己的菜单啊? 我们一般在窗口标题栏点右键 或 按Alt+空格 可以弹出那个菜单。 ------解决方案-------------------- using System.Runtime.InteropServices; [DllImport( "user32.dll ")] public static extern IntPtr GetSystemMenu(IntPtr hWnd, bool bRevert); [DllImport( "user32.dll ")] public static extern bool InsertMenu(IntPtr hMenu, uint uPosition, uint uFlags, uint uIDNewItem, string lpNewItem); public const int MF_BYCOMMAND = 0; public const int MF_STRING = 0; public const int MF_BYPOSITION = 0x400; public const int MF_SEPARATOR = 0x800; private const uint SC_ABOUT = 0x0001; public const int WM_SYSCOMMAND = 0x0112; private void Form1_Load(object sender, EventArgs e) { IntPtr vMenuHandle = GetSystemMenu(Handle, false); InsertMenu(vMenuHandle, 255, MF_STRING, SC_ABOUT, "About... "); } protected override void WndProc(ref Message m) { switch (m.Msg) { case WM_SYSCOMMAND: if ((uint)m.WParam == SC_ABOUT) { MessageBox.Show( "Zswang 路过! "); } break; } base.WndProc(ref m); }

8,737

社区成员

发帖
与我相关
我的任务
社区描述
WPF/Silverlight相关讨论
社区管理员
  • WPF/Silverlight社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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