Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/wpf/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在Wpf中禁用acrobat reader上下文菜单?_Wpf_Acrobat_Right Click - Fatal编程技术网

如何在Wpf中禁用acrobat reader上下文菜单?

如何在Wpf中禁用acrobat reader上下文菜单?,wpf,acrobat,right-click,Wpf,Acrobat,Right Click,我正在使用AcrobatActiveX在应用程序中显示PDF文档。 我想知道是否可以禁用右键单击PDF文档?我以前的解决方案不起作用,因此还有另一个解决方案。您只需要在接收鼠标通知的子窗口上设置鼠标挂钩 public class AcrobatReader : AxAcroPDF { private const int WH_MOUSE_LL = 14; private const int WM_RBUTTONDOWN = 0x0204; private static

我正在使用AcrobatActiveX在应用程序中显示PDF文档。
我想知道是否可以禁用右键单击PDF文档?

我以前的解决方案不起作用,因此还有另一个解决方案。您只需要在接收鼠标通知的子窗口上设置鼠标挂钩

public class AcrobatReader : AxAcroPDF
{
    private const int WH_MOUSE_LL = 14;
    private const int WM_RBUTTONDOWN = 0x0204;

    private static LowLevelMouseProc _proc = HookCallback;
    private static IntPtr _hookID = IntPtr.Zero;

    public AcrobatReader()
    {
        _hookID = SetWindowsHookEx(WH_MOUSE_LL, _proc, FindWindow(null, "avpageview"), 0);
    }

    ~AcrobatReader()
    {
        if (_hookID != IntPtr.Zero)
        {
            UnhookWindowsHookEx(_hookID);
            _hookID = IntPtr.Zero;
        }
    }

    private static IntPtr HookCallback(int nCode, IntPtr wParam, IntPtr lParam)
    {
        if (nCode >= 0 && (IntPtr)WM_RBUTTONDOWN == wParam)
        {
            return new IntPtr(1);
        }
        return CallNextHookEx(_hookID, nCode, wParam, lParam);
    }

    private delegate IntPtr LowLevelMouseProc(int nCode, IntPtr wParam, IntPtr lParam);

    [DllImport("user32.dll", SetLastError = true)]
    private static extern IntPtr SetWindowsHookEx(int idHook, LowLevelMouseProc lpfn, IntPtr hMod, uint dwThreadId);

    [DllImport("user32.dll", SetLastError = true)]
    [return: MarshalAs(UnmanagedType.Bool)]
    private static extern bool UnhookWindowsHookEx(IntPtr hhk);

    [DllImport("user32.dll", SetLastError = true)]
    private static extern IntPtr CallNextHookEx(IntPtr hhk, int nCode, IntPtr wParam, IntPtr lParam);

    [DllImport("user32.dll", SetLastError = true)]
    private static extern IntPtr FindWindow(string lpClassName, string lpWindowName);
}

我也这么做了,但是WM_RBUTTONDOWN事件根本没有发生。我不知道为什么。@r,我已经用另一个有效的解决方案更新了我的答案。