我的程序在应用程序中使用气球通知气泡来引导用户,在Windows XP中,气球窗口在右上角有很少的'X',以便在单击时关闭窗口,如果单击任何位置,窗口也会关闭即使你没有点击'X'。
但是,当程序在Windows Server 2008上运行时,气球会出现但没有“X”按钮,当我点击它们时也不会关闭。
偶然我设法通过删除包含以下内容的.MANIFEST文件来复制Windows XP中的行为:
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
<assemblyIdentity version="2.0.0.0" processorArchitecture="x86" name="SofrwareName" type="win32" />
<dependency>
<dependentAssembly>
<assemblyIdentity type="win32" name="Microsoft.Windows.Common-Controls" version="6.0.0.0" publicKeyToken="<Removed>" language="*" processorArchitecture="x86" />
</dependentAssembly>
</dependency>
</assembly>
当我删除此清单并在Windows XP中运行我的程序时,气球就像在Windows Server 2008中一样。我假设这可能意味着某种与Windows Server 2008中的Common Controls v6不兼容。
是否有人知道可能导致气球在点击时不关闭的原因以及没有“X”关闭按钮?
更新:这是气球创建代码:
m_tool = new MessageTool(); //internal class MessageTool : NativeWindow {...}
CreateParams cp = new CreateParams();
cp.ClassName = TOOLTIPS_CLASS; //TOOLTIPS_CLASS = "tooltips_class32";
cp.Style =
WS_POPUP |
TTS_BALLOON |
TTS_NOPREFIX |
TTS_ALWAYSTIP |
TTS_CLOSE;
m_ti = new TOOLINFO();
/*
[StructLayout(LayoutKind.Sequential)]
private struct TOOLINFO
{
public int cbSize;
public int uFlags;
public IntPtr hwnd;
public IntPtr uId;
public RECT rect;
public IntPtr hinst;
[MarshalAs(UnmanagedType.LPTStr)]
public string lpszText;
public uint lParam;
}
*/
m_ti.cbSize = Marshal.SizeOf(m_ti);
m_tool.CreateHandle(cp);
m_ti.uFlags = TTF_TRACK |
TTF_CLOSEONMOUSECLICK |
TTF_TRANSPARENT |
TTF_SUBCLASS |
TTF_PARSELINKS;
m_ti.uId = m_tool.Handle;
m_ti.lpszText = m_text;
m_ti.hwnd = m_parent.Handle;
WindowsAPI.GetClientRect(m_parent.Handle, ref m_ti.rect);
ClientToScreen(m_parent.Handle, ref m_ti.rect);
WindowsAPI.SetWindowPos(
m_tool.Handle,
HWND_TOP,
0, 0, 0, 0,
(int)SetWindowPosFlags.SWP_NOACTIVATE |
(int)SetWindowPosFlags.SWP_NOMOVE |
(int)SetWindowPosFlags.SWP_NOSIZE);
IntPtr ptrStruct = Marshal.AllocHGlobal(Marshal.SizeOf(m_ti));
Marshal.StructureToPtr(m_ti, ptrStruct, true);
WindowsAPI.SendMessage(
m_tool.Handle, TTM_ADDTOOL, 0, ptrStruct);
m_ti = (TOOLINFO)Marshal.PtrToStructure(ptrStruct,
typeof(TOOLINFO));
WindowsAPI.SendMessage(
m_tool.Handle, TTM_SETMAXTIPWIDTH,
0, new IntPtr(m_maxWidth));
WindowsAPI.SendMessage(
m_tool.Handle, TTM_SETTITLE,
(int)m_titleIcon, ptrTitle);
SetBalloonPosition(m_ti.rect);
Marshal.FreeHGlobal(ptrStruct);
Marshal.FreeHGlobal(ptrTitle);
Windows构建信息:Windows Server Standard,SP2,32位
答案 0 :(得分:0)
这可能没有帮助,我讨厌忽略它,但是我遇到了由于文件/文件夹权限导致应用程序无法访问DLL的问题,并且还看到了文件被锁定的位置在计算机之间传输它(甚至是同一域内的计算机)。要取消阻止它,您必须通过Windows资源管理器在高级下进入该文件的属性并取消阻止该文件。