Как отключить клавиши отправки и завершения на Motorola MC75 - PullRequest
0 голосов
/ 14 марта 2011

Как отключить клавиши отправки и завершения на Motorola MC75?

Мне нужен любой пример кода C # для этого

заранее спасибо

Ответы [ 3 ]

4 голосов
/ 16 марта 2011

Я ответил на это на форумах MSDN .

Вы можете использовать API AllKeys для этого.

Подпись P / Invoke для ее использования в C # находится здесь: http://blogs.msdn.com/b/mikefrancis/archive/2009/03/28/porting-gapi-keys-to-wm-6-1-and-6-5.aspx

Хорошее общее объяснение его использования здесь: http://windowsteamblog.com/windows_phone/b/windowsphone/archive/2009/07/14/just-say-no-to-gapi-what-you-need-to-know-about-allkeys-and-input-management.aspx

1 голос
/ 24 июля 2012

Используйте Motorola AppCenter для ограничения запущенных приложений. Позволяет блокировать ключи, программы и т. Д.

0 голосов
/ 16 марта 2011

Редактировать: я не знал о решении "AllKeys", опубликованном PaulH, это должно быть лучшее решение, чем то, которое я опубликовал.

Я предполагаю, что вы хотите работать с зелеными и красными аппаратными клавишами? Клавиши вызова и зависания?

В этом случае вы можете отслеживать ключевые события и не передавать их в окна, если они соответствуют вашим критериям.

private const int WH_KEYBOARD_LL = 20;
private static int _hookHandle;
private HookProc _hookDelegate;

[DllImport("coredll.dll")]
private static extern int SetWindowsHookEx(int type, HookProc hookProc, IntPtr       hInstance, int m);

[DllImport("coredll.dll")]
private static extern IntPtr GetModuleHandle(string mod);

[DllImport("coredll.dll", SetLastError = true)]
private static extern int UnhookWindowsHookEx(int idHook);

[DllImport("coredll.dll")]
private static extern int CallNextHookEx(HookProc hhk, int nCode, IntPtr wParam, IntPtr lParam);


private bool HookKeyboardEvent(bool action)
{
try
{
    if (action)
    {
        HookKeyboardEvent(false);

        _hookDelegate = new HookProc(HookProcedure);
        _hookHandle = SetWindowsHookEx(WH_KEYBOARD_LL, _hookDelegate, GetModuleHandle(null), 0);

        if (_hookHandle == 0)
        {
            return false;
        }
        return true;
    }
    if (_hookHandle != 0)
    {
        //Unhook the previouse one
        UnhookWindowsHookEx(_hookHandle);
        return true;
    }
    return false;
}
catch (Exception ex)
{
    string dump = ex.Message;
    return false;
}
}

private int HookProcedure(int code, IntPtr wParam, IntPtr lParam)
{
try
{
    var hookStruct = (KBDLLHOOKSTRUCT) Marshal.PtrToStructure(lParam, typeof (KBDLLHOOKSTRUCT));
    if (DoHardwareKeyPress(hookStruct.vkCode, hookStruct.scanCode, wParam.ToInt32()))
        return CallNextHookEx(_hookDelegate, code, wParam, lParam);
    else
        return -1;
}
catch (Exception ex)
{
    string dump = ex.Message;
    return -1;
}
}

private bool DoHardwareKeyPress(int softKey, int hardKey, int keyState)
{
try
{
    string keyPressInformation = string.Format("SoftKey = {0}, HardKey = {1}, KeyState = {2}", softKey, hardKey,
                                               keyState);
    if (softKey == 114 && hardKey == 4 && (keyState == 256 || keyState == 257))
        return false;
    else if (softKey == 115 && hardKey == 12 && (keyState == 256 || keyState == 257))
        return false;
    else
        return true;
}
catch (Exception ex)
{
    string dump = ex.Message;
    return true;
}
}

#region Nested type: HookProc

internal delegate int HookProc(int code, IntPtr wParam, IntPtr lParam);

#endregion

#region Nested type: KBDLLHOOKSTRUCT

private struct KBDLLHOOKSTRUCT
{
public IntPtr dwExtraInfo;
public int flags;
public int scanCode;
public int time;
public int vkCode;
}

#endregion

Это быстрое и грязное решение, которое вы, возможно, захотите очистить перед использованием :) Просто вызовите HookKeyboardEvent (true), чтобы включить ловушку, и HookKeyboardEvent (false), чтобы отцепить.

Надеюсь, это решит вашу проблему.

...