Difference between revisions of "SysFn66/ru"

From KolibriOS wiki
Jump to navigation Jump to search
(Created page with ''''Функция 66 - работа с клавиатурой.''' Режим ввода влияет на результаты чтения клавиш функцией 2. Пр...')
 
 
(9 intermediate revisions by 2 users not shown)
Line 1: Line 1:
'''Функция 66 - работа с клавиатурой.'''
+
'''Функция 66''' - работа с клавиатурой.
  
Режим ввода влияет на результаты чтения клавиш функцией 2.
+
Режим ввода влияет на результаты чтения клавиш [[SysFn02/ru|функцией 2]].
 
При загрузке программы для неё устанавливается ASCII-режим ввода.
 
При загрузке программы для неё устанавливается ASCII-режим ввода.
  
 
=== Подфункция 1 - установить режим ввода с клавиатуры. ===
 
=== Подфункция 1 - установить режим ввода с клавиатуры. ===
Параметры:
+
 
  * eax = 66 - номер функции
+
''Параметры:''
  * ebx = 1 - номер подфункции
+
:* eax = 66 - номер функции
  * ecx = режим:
+
:* ebx = 1 - номер подфункции
    * 0 = обычный (ASCII-символы)
+
:* ecx = режим:
    * 1 = сканкоды
+
:** 0 = обычный (ASCII-символы)
Возвращаемое значение:
+
:** 1 = сканкоды
  * функция не возвращает значения
+
 
 +
''Возвращаемое значение:''
 +
:* функция не возвращает значения
 +
 
 +
'''Константы для регистров:'''
 +
::eax - SF_KEYBOARD (66)
 +
::ebx - SSF_SET_INPUT_MODE (1)
  
 
=== Подфункция 2 - получить режим ввода с клавиатуры. ===
 
=== Подфункция 2 - получить режим ввода с клавиатуры. ===
Параметры:
+
 
  * eax = 66 - номер функции
+
''Параметры:''
  * ebx = 2 - номер подфункции
+
:* eax = 66 - номер функции
Возвращаемое значение:
+
:* ebx = 2 - номер подфункции
  * eax = текущий режим
+
 
 +
''Возвращаемое значение:''
 +
:* eax = текущий режим
 +
 
 +
'''Константы для регистров:'''
 +
::eax - SF_KEYBOARD (66)
 +
::ebx - SSF_GET_INPUT_MODE (2)
  
 
=== Подфункция 3 - получить состояние управляющих клавиш. ===
 
=== Подфункция 3 - получить состояние управляющих клавиш. ===
Параметры:
+
 
  * eax = 66 - номер функции
+
''Параметры:''
  * ebx = 3 - номер подфункции
+
:* eax = 66 - номер функции
Возвращаемое значение:
+
:* ebx = 3 - номер подфункции
  * eax = битовая маска:
+
 
  * бит 0 (маска 1): левый Shift нажат
+
''Возвращаемое значение:''
  * бит 1 (маска 2): правый Shift нажат
+
:* eax = битовая маска:
  * бит 2 (маска 4): левый Ctrl нажат
+
::* бит 0 (маска 1): левый Shift нажат
  * бит 3 (маска 8): правый Ctrl нажат
+
::* бит 1 (маска 2): правый Shift нажат
  * бит 4 (маска 0x10): левый Alt нажат
+
::* бит 2 (маска 4): левый Ctrl нажат
  * бит 5 (маска 0x20): правый Alt нажат
+
::* бит 3 (маска 8): правый Ctrl нажат
  * бит 6 (маска 0x40): CapsLock включён
+
::* бит 4 (маска 0x10): левый Alt нажат
  * бит 7 (маска 0x80): NumLock включён
+
::* бит 5 (маска 0x20): правый Alt нажат
  * бит 8 (маска 0x100): ScrollLock включён
+
::* бит 6 (маска 0x40): CapsLock включён
  * прочие биты сброшены
+
::* бит 7 (маска 0x80): NumLock включён
 +
::* бит 8 (маска 0x100): ScrollLock включён
 +
::* прочие биты сброшены
 +
 
 +
'''Константы для регистров:'''
 +
::eax - SF_KEYBOARD (66)
 +
::ebx - SSF_GET_CONTROL_KEYS (3)
  
 
=== Подфункция 4 - установить общесистемную "горячую клавишу". ===
 
=== Подфункция 4 - установить общесистемную "горячую клавишу". ===
 +
 
О нажатии "горячей клавиши" извещаются только приложения,
 
О нажатии "горячей клавиши" извещаются только приложения,
 
установившие её; активное приложение (к которому поступает
 
установившие её; активное приложение (к которому поступает
Line 44: Line 63:
 
Извещение заключается в посылке события с кодом 2.
 
Извещение заключается в посылке события с кодом 2.
 
Прочитать "горячую клавишу" можно так же, как и обычную, -
 
Прочитать "горячую клавишу" можно так же, как и обычную, -
функцией 2.
+
[[SysFn02/ru|функцией 2]].
Параметры:
+
 
  * eax = 66 - номер функции
+
''Параметры:''
  * ebx = 4 - номер подфункции
+
:* eax = 66 - номер функции
  * cl задаёт сканкод клавиши;
+
:* ebx = 4 - номер подфункции
    используйте cl=0 для задания комбинаций типа Ctrl+Shift
+
::* cl задаёт сканкод клавиши; используйте cl=0 для задания комбинаций типа Ctrl+Shift
  * edx = 0xXYZ задаёт возможные состояния управляющих клавиш:
+
:* edx = 0xXYZ задаёт возможные состояния управляющих клавиш:
    * Z (младшие 4 бита) задаёт состояние клавиш LShift и RShift:
+
::* Z (младшие 4 бита) задаёт состояние клавиш LShift и RShift:
      * 0 = ни одна из клавиш не должна быть нажата;
+
:::* 0 = ни одна из клавиш не должна быть нажата;
      * 1 = ровно одна из клавиш должна быть нажата;
+
:::* 1 = ровно одна из клавиш должна быть нажата;
      * 2 = обе клавиши должны быть нажаты;
+
:::* 2 = обе клавиши должны быть нажаты;
      * 3 = должна быть нажата LShift, но не RShift;
+
:::* 3 = должна быть нажата LShift, но не RShift;
      * 4 = должна быть нажата RShift, но не LShift
+
:::* 4 = должна быть нажата RShift, но не LShift
    * Y - аналогично для LCtrl и RCtrl;
+
::* Y - аналогично для LCtrl и RCtrl;
    * X - аналогично для LAlt и RAlt
+
::* X - аналогично для LAlt и RAlt
Возвращаемое значение:
+
 
  * eax=0 - успешно
+
''Возвращаемое значение:''
  * eax=1 - слишком много "горячих клавиш" (допускается максимум 256)
+
:* eax=0 - успешно
Замечания:
+
:* eax=1 - слишком много "горячих клавиш" (допускается максимум 256)
  * Горячая клавиша может срабатывать либо при нажатии,
+
 
    либо при отпускании. Сканкод отпускания клавиши на 128 больше,
+
''Замечания:''
    чем сканкод нажатия (т.е. установлен старший бит).
+
:* Горячая клавиша может срабатывать либо при нажатии, либо при отпускании. Сканкод отпускания клавиши на 128 больше, чем сканкод нажатия (т.е. установлен старший бит).
  * Несколько приложений могут установить одну и ту же комбинацию;
+
:* Несколько приложений могут установить одну и ту же комбинацию; о нажатии такой комбинации будут извещаться все такие приложения.
    о нажатии такой комбинации будут извещаться все такие приложения.
+
 
 +
'''Константы для регистров:'''
 +
::eax - SF_KEYBOARD (66)
 +
::ebx - SSF_SET_SYS_HOTKEY (4)
  
 
=== Подфункция 5 - удалить установленную "горячую клавишу". ===
 
=== Подфункция 5 - удалить установленную "горячую клавишу". ===
Параметры:
+
 
  * eax = 66 - номер функции
+
''Параметры:''
  * ebx = 5 - номер подфункции
+
:* eax = 66 - номер функции
  * cl = сканкод клавиши и edx = 0xXYZ такие же, как и в подфункции 4
+
:* ebx = 5 - номер подфункции
Возвращаемое значение:
+
:* cl = сканкод клавиши и edx = 0xXYZ такие же, как и в подфункции 4
  * eax = 0 - успешно
+
 
  * eax = 1 - нет такой горячей клавиши
+
''Возвращаемое значение:''
Замечания:
+
:* eax = 0 - успешно
  * При завершении процесса/потока удаляются все установленные им
+
:* eax = 1 - нет такой горячей клавиши
    горячие клавиши.
+
 
  * Вызов функции не влияет на другие приложения.
+
''Замечания:''
    Если другое приложение определило эту же комбинацию,
+
:* При завершении процесса/потока удаляются все установленные им горячие клавиши.
    оно по-прежнему будет получать уведомления.
+
:* Вызов функции не влияет на другие приложения. Если другое приложение определило эту же комбинацию, оно по-прежнему будет получать уведомления.
 +
 
 +
'''Константы для регистров:'''
 +
::eax - SF_KEYBOARD (66)
 +
::ebx - SSF_DEL_SYS_HOTKEY (5)
 +
 
 +
=== Подфункция 6 - заблокировать обычный ввод. ===
 +
 
 +
''Параметры:''
 +
:* eax = 66 - номер функции
 +
:* ebx = 6 - номер подфункции
 +
 
 +
''Возвращаемое значение:''
 +
:* функция не возвращает значения
 +
 
 +
''Замечания:''
 +
:* Блокируется обычный ввод данных с клавиатуры для установленных "горячих" клавиш
 +
:* Для эмуляции мыши через клавиатуру, приложение [[Mousemul/ru|MOUSEMUL]]
 +
 
 +
'''Константы для регистров:'''
 +
::eax - SF_KEYBOARD (66)
 +
::ebx - SSF_LOCK_INPUT (6)
 +
 
 +
=== Подфункция 7 - разблокировать обычный ввод. ===
 +
 
 +
''Параметры:''
 +
:* eax = 66 - номер функции
 +
:* ebx = 7 - номер подфункции
 +
 
 +
''Возвращаемое значение:''
 +
:* функция не возвращает значения
 +
 
 +
''Замечания:''
 +
:* Разблокирование результатов ф. 66.6
 +
:* Для эмуляции мыши через клавиатуру, приложение [[Mousemul/ru|MOUSEMUL]]
 +
 
 +
'''Константы для регистров:'''
 +
::eax - SF_KEYBOARD (66)
 +
::ebx - SSF_UNLOCK_INPUT (7)
 +
 
 +
{{System_functions}}
 +
[[Category: SysCalls]]

Latest revision as of 13:11, 21 January 2016

Функция 66 - работа с клавиатурой.

Режим ввода влияет на результаты чтения клавиш функцией 2. При загрузке программы для неё устанавливается ASCII-режим ввода.

Подфункция 1 - установить режим ввода с клавиатуры.

Параметры:

  • eax = 66 - номер функции
  • ebx = 1 - номер подфункции
  • ecx = режим:
    • 0 = обычный (ASCII-символы)
    • 1 = сканкоды

Возвращаемое значение:

  • функция не возвращает значения

Константы для регистров:

eax - SF_KEYBOARD (66)
ebx - SSF_SET_INPUT_MODE (1)

Подфункция 2 - получить режим ввода с клавиатуры.

Параметры:

  • eax = 66 - номер функции
  • ebx = 2 - номер подфункции

Возвращаемое значение:

  • eax = текущий режим

Константы для регистров:

eax - SF_KEYBOARD (66)
ebx - SSF_GET_INPUT_MODE (2)

Подфункция 3 - получить состояние управляющих клавиш.

Параметры:

  • eax = 66 - номер функции
  • ebx = 3 - номер подфункции

Возвращаемое значение:

  • eax = битовая маска:
  • бит 0 (маска 1): левый Shift нажат
  • бит 1 (маска 2): правый Shift нажат
  • бит 2 (маска 4): левый Ctrl нажат
  • бит 3 (маска 8): правый Ctrl нажат
  • бит 4 (маска 0x10): левый Alt нажат
  • бит 5 (маска 0x20): правый Alt нажат
  • бит 6 (маска 0x40): CapsLock включён
  • бит 7 (маска 0x80): NumLock включён
  • бит 8 (маска 0x100): ScrollLock включён
  • прочие биты сброшены

Константы для регистров:

eax - SF_KEYBOARD (66)
ebx - SSF_GET_CONTROL_KEYS (3)

Подфункция 4 - установить общесистемную "горячую клавишу".

О нажатии "горячей клавиши" извещаются только приложения, установившие её; активное приложение (к которому поступает весь нормальный ввод) таких клавиш не получает. Извещение заключается в посылке события с кодом 2. Прочитать "горячую клавишу" можно так же, как и обычную, - функцией 2.

Параметры:

  • eax = 66 - номер функции
  • ebx = 4 - номер подфункции
  • cl задаёт сканкод клавиши; используйте cl=0 для задания комбинаций типа Ctrl+Shift
  • edx = 0xXYZ задаёт возможные состояния управляющих клавиш:
  • Z (младшие 4 бита) задаёт состояние клавиш LShift и RShift:
  • 0 = ни одна из клавиш не должна быть нажата;
  • 1 = ровно одна из клавиш должна быть нажата;
  • 2 = обе клавиши должны быть нажаты;
  • 3 = должна быть нажата LShift, но не RShift;
  • 4 = должна быть нажата RShift, но не LShift
  • Y - аналогично для LCtrl и RCtrl;
  • X - аналогично для LAlt и RAlt

Возвращаемое значение:

  • eax=0 - успешно
  • eax=1 - слишком много "горячих клавиш" (допускается максимум 256)

Замечания:

  • Горячая клавиша может срабатывать либо при нажатии, либо при отпускании. Сканкод отпускания клавиши на 128 больше, чем сканкод нажатия (т.е. установлен старший бит).
  • Несколько приложений могут установить одну и ту же комбинацию; о нажатии такой комбинации будут извещаться все такие приложения.

Константы для регистров:

eax - SF_KEYBOARD (66)
ebx - SSF_SET_SYS_HOTKEY (4)

Подфункция 5 - удалить установленную "горячую клавишу".

Параметры:

  • eax = 66 - номер функции
  • ebx = 5 - номер подфункции
  • cl = сканкод клавиши и edx = 0xXYZ такие же, как и в подфункции 4

Возвращаемое значение:

  • eax = 0 - успешно
  • eax = 1 - нет такой горячей клавиши

Замечания:

  • При завершении процесса/потока удаляются все установленные им горячие клавиши.
  • Вызов функции не влияет на другие приложения. Если другое приложение определило эту же комбинацию, оно по-прежнему будет получать уведомления.

Константы для регистров:

eax - SF_KEYBOARD (66)
ebx - SSF_DEL_SYS_HOTKEY (5)

Подфункция 6 - заблокировать обычный ввод.

Параметры:

  • eax = 66 - номер функции
  • ebx = 6 - номер подфункции

Возвращаемое значение:

  • функция не возвращает значения

Замечания:

  • Блокируется обычный ввод данных с клавиатуры для установленных "горячих" клавиш
  • Для эмуляции мыши через клавиатуру, приложение MOUSEMUL

Константы для регистров:

eax - SF_KEYBOARD (66)
ebx - SSF_LOCK_INPUT (6)

Подфункция 7 - разблокировать обычный ввод.

Параметры:

  • eax = 66 - номер функции
  • ebx = 7 - номер подфункции

Возвращаемое значение:

  • функция не возвращает значения

Замечания:

  • Разблокирование результатов ф. 66.6
  • Для эмуляции мыши через клавиатуру, приложение MOUSEMUL

Константы для регистров:

eax - SF_KEYBOARD (66)
ebx - SSF_UNLOCK_INPUT (7)