Нихт ферштейн: учим пингвина понимать мультимедийные клавиши. Нихт ферштейн: учим пингвина понимать мультимедийные клавиши Скан коды клавиш клавиатуры dinovo

Номер клавиши, посылаемый клавиатурным процессором, однозначно зависит от схемы клавиатурной матрицы, но не от обозначений, нанесенных на поверхность клавиш. Этот номер называется скан-кодом (Scan Code). Слово scan ("сканирование"), подчеркивает тот факт, что клавиатурный компьютер сканирует клавиатуру для поиска нажатой клавиши.

КодAscii нажатой клавиши

Обычно программе нужен не порядковый номер нажатой клавиши, а код, соответствующий обозначению на этой клавише (код ASCII).

Код ASCII не связан напрямую со скан-кодом, так как одной и той же клавише могут соответствовать несколько значений кода ASCII в зависимости от состояния других клавиш. Например, клавиша с обозначением «1» используется еще и для ввода символа «!» (если она была нажата вместе с клавишей).

Поэтому все преобразования скан-кода в код ASCII выполняются программно. Как правило, в операционной системе MS-DOS эти преобразования выполняют модули BIOS. Для использования символов кириллицы эти модули расширяются клавиатурными драйверами, как входящими в состав локализованных версийMS-DOS, так и созданными в виде отдельных программ.

Режим автоповтора

Если нажать на клавишу и не отпускать ее, клавиатура перейдет в режим автоповтора. При этом в компьютер автоматически через некоторый период времени, называемый периодом автоповтора, посылается код нажатой клавиши. Режим автоповтора облегчает ввод с клавиатуры большого количества одинаковых символов.

Следует отметить, что клавиатура содержит внутренний 16-байтовый буфер, через который она осуществляет обмен данными с компьютером.

Типы клавиатур

До недавнего времени существовали три различных типа клавиатуры. Это клавиатура для компьютеров IBM PC/XT, 84-клавишная клавиатура для IBM PC/AT и 101-клавишная (расширенная) клавиатура для IBMPC/AT. Некоторые клавиатуры имеют переключатель режима работы (XT/AT), расположенный на нижней крышке. Он должен быть установлен в правильное положение.

После того как операционная система Microsoft Windows получила широкое распространение, специально для нее был создан новый тип клавиатуры. К обычной клавиатуре типа IBMPC/AT были добавлены две кнопки, первая из которых дублирует вызов менюStart, выполняемый при помощи левой клавиши мыши, а вторая – вызов того же меню при помощи правой клавиши мыши.

Порты для работы с клавиатурой

Назначение портов, предназначенных для работы с клавиатурой, зависят от типа компьютера.

КомпьютерIbm pc/xt

Для работы с клавиатурой типа IBM PC/XT используются порты с адресами 60h и 61h.

Порт 60h доступен только для чтения. После выполнения этой операции он содержит скан-код последней нажатой клавиши.

Порт 61h доступен как для чтения, так и для записи. Он управляет не только клавиатурой, но и другими устройствами компьютера, например, работой встроенного динамика. Если в старший бит порта 61h записать значение 1, клавиатура будет заблокирована, если 0 - разблокирована.

Так как порт 61h управляет не только клавиатурой, при изменении содержимого старшего бита необходимо сохранить состояние остальных битов этого порта. Для этого можно сначала выполнить чтение содержимого порта в регистр, изменить состояние старшего бита, затем выполнить запись нового значения в порт.

Заняться устройством подобного рода меня побудил тот факт, что большая часть простых для повторения геймортовских устройств не позволяла реализовать достаточное количество кнопок управления. Игровой порт PC изначально вообще расчитан максимум на четыре кнопки. Всевозможные расширения также не обладают желаемой гибкостью. К примеру, популярное среди самодельщиков расширение CH Flightstick Pro позволяет реализовать до 14-ти кнопок, но при этом одновременно нельзя использовать две любые кнопки - о полетах на таких устройствах в играх, в которых приходится постоянно «крутить головой» - в тех же птичках, можно забыть. Некоторые расширения используют исключительно цифровой интерфейс - данные о нажатых кнопках и отклонении ручки передаются по цифровым линиям геймпорта, которые изначально предназначались для передачи данных о четырех «стандартных» кнопках. Я даже считаю такие расширения в чем-то избыточными. Да и преобразование аналоговых данных в цифровые усложняет конструкцию джойстика. Кроме того, не всякая игра захочет понять что за монстр к ней «присосался». А клава - вот она, во всей своей 102-х клавишной красе! Кроме того, масла в огонь подливали подписчики RU.GAME.FLIGHT, время от времени вопрошавшие «а как бы мне клаву приручить и с джоем скрестить?» и уходившие ни с чем.

Короче говоря, задача устройства - «сидеть» на шине между клавиатурой и PC и имитировать нажатие клавиш на клавиатуре, в соответствии с нажатыми кнопками устройства.

Итак, я засел за разработку. До этого у меня был опыт работы с различными микропроцессорами и микроконтроллерами. В общем - пальцы от уха до уха. И я наивно полагал, что вот, сейчас я возьму доки, сделаю RTFM и через неделю буду на белом коне. Вся загвоздка оказалась в том, что документации о протоколе передачи данных между клавиатурой и контроллером я не смог найти ни в Интернете, ни в соответствующих конференциях Фидо. Пришлось брать осцилограф и несколько недель заниматься разбором времянок и попытками их повторить. Поэтому большая часть изложенной ниже информации является результатом моих умозаключений и не подтверждена документально. Если я в чем-то заблуждаюсь - рад буду выслушать комментарии по адресу rashpil at ukr dot net .

Основные принципы передачи данных

Все нижеследующее справедливо для PS/2 и AT-клавиатур, которые отличаются только исполнением разъема (могут подключаться через переходник).

Между клавиатурой и контроллером, расположенным на материнской плате компьютера (далее - просто «контроллером»), осуществляется двусторонний обмен данными. Контроллер передает различные команды (например - изменение состояния светодиодов или скорости автоповтора). Клавиатура передает скан-коды нажатых клавиш (скан-код - условное обозначение клавиши, не стоит путать с ASCII-кодами).

Скан-коды

Клавиша Скан-код Клавиша Скан-код Клавиша Скан-код Клавиша Скан-код
1 16 2 1E 3 26 4 25
5 2E 6 36 7 3D 8 3E
9 46 0 45 - 4E + 55
Backspace 66 Tab 0D Q 15 W 1D
E 24 R 2D T 2C Y 35
U 3C I 43 O 44 P 4d
[ 54 ] 5B Enter 5A Ctrl(L) 14
A 1C S 1B D 23 F 2B
G 34 H 33 J 3B K 42
L 4B ; 4C " 52 ` 0E
Shift(L) 12 \ 61 Z 1A X 22
C 21 V 2A B 32 N 31
M 3A , 41 . 49 / 4A
Shift(R) 59 Alt(L) 11 Space 29 Caps Lock 58
Esc 76 F1 05 F2 06 F3 04
F4 0C F5 03 F6 0B F7 83
F8 0A F9 01 F10 09 F11 78
F12 07 Scroll Lock 7E * 7C Num Lock 77
7 6C 8 75 9 7D - 7B
4 6B 5 73 6 74 + 5A
1 69 2 72 3 7A 0 70
. 71 Alr(R) E0-11 Ctrl(R) E0-14 Print Screen E0-12-E0-7C
Insert E0-70 Delete E0-71 Left E0-6B Home E0-6C
End E0-69 Up E0-75 Down E0-72 PageUp E0-7D
PageDown E0-7A Right E0-74 Enter E0-5A / E0-4A

Примечание: на самом деле AT-клавиатура имеет три различных набора сканкодов. Я привел только значения для набора № 2 - дефолтного.

При нажатии на клавишу клавиатура передает контроллеру скан-код этой клавиши. При отпускании - сначала префикс 0F0h, а потом скан-код отпущенной клавиши.

Комбинации клавиш с Shift, Alt и Ctrl передаются как последовательность двух скан-кодов. С точки зрения контроллера эти клавиши ничем не отличаются от всех остальных. Точно так же на аппаратном уровне не различаются режими Num Lock и Caps Lock - они различаются на программном уровне программой, которая обслуживает прерывания от клавиатуры.

Коротко хочу остановиться на реализации режима автоповтора. Как правило функции автоповтора возлагаются на саму клавиатуру - через определенное время, если клавиша не отпущена, то клавиатура посылает еще один точно такой же скан-код. Если в это время нажать еще одну клавишу, то к контроллеру «полетит» уже другой скан-код и будет считаться, что нажата только одна клавиша. В играх эта проблема решена элементарно - клавиша считается нажатой, пока не прийдет соответствующий скан-код с префиксом 0F0h. Поэтому я не стал реализовывать функции автоповтора в принципе.

Кроме приведенных выше скан-кодов, клавиатура может возвращать некоторые служебные команды. Но эти команды, равно как и команды, выдаваемые контроллером, не представляют в данном случае практической ценности. Поэтому на них останавливаться не буду.

Описание протокола обмена

Обмен данными между клавиатурой и контроллером осуществляется асинхронно по последовательному протоколу. Суть асинхронной передачи состоит в том, что данные передаются только тогда, когда есть что передавать - нажата/отпущена клавиша на клавиатуре и нужно выдать соответствующий скан-код или контроллеру нужно выдать команду клавиатуре.

Для обмена данными служат две линии - KBData и KBSync. При передаче скан-кодов клавиатура выставляет очередной разряд данных на линии KBData и подтверждает передачу переводом из «1» в «0» сигнала на линии KBSync. При приеме данных от контроллера клавиатура считывает разряд данных с линии KBData и выдает подтверждение приема переводом из «1» в «0» сигнала на линии KBSync. Контроллер может сигнализировать о своей неготовности передавать/принимать данные низким уровнем на линии KBSync. Все остальное время, когда нет данных для передачи, обе линии имеют высокий уровень сигнала. Частота следования импульсов линии KBSync составляет около 10-25КГц.

Данные передаются в таком порядке: один стартовый бит - «0», восемь бит данных, бит четности (сумма всех разрядов +1), один стоповый бит - «1». После приема каждого байта данных контроллер выставляет низкий уровень на линии KBSync, сигнализируя тем самым, что занят обработкой принятых данных и не готов принимать следующие. Это можно считать подтверждением приема. Клавиатура подтверждает каждый байт принимаемой команды выдачей кода 0FAh. При возникновении ошибки при передаче, контроллер может потребовать повторить передачу последнего байта, выдачей команды 0FEh. Клавиатура же ведет себя по-другому - просто игнорирует ошибки. Я не вижу в этом ничего фатального - если ваша система дает частые сбои, то ей не место на рабочем столе.

Скорее всего, мои объяснения были слишком запутаны, поэтому постараюсь проиллюстрировать их несколькими временными диаграммами.

Общий вид передачи данных от клавиатуры (S1 - стартовый бит; S2 - стоповый бит; D0-D7 - данные; P - бит четности; W - обработка принятых данных)

Пример передачи байта 74h - клавиша «6» на нумпаде. В этом примере при инициации передачи клавиатурой контроллер сигнализирует о своей неготовности принимать данные и клавиатура ожидает освобождения линии KBSync

Аппаратная реализация

Теперь я перейду непосредственно к описанию реализации устройства в «железе».

Устройство включается в разрыв сигналов KBSync и KBData и пропускает через себя сигналы от/к клавиатуре, опрашивает состояние четырех кнопок и выдает соответствующие скан-коды, имитируя тем самым работу клавиатуры.

Основу устройства составляет однокристальный микроконтроллер AT89C2051. Микроконтроллер AT89C2051 фирмы Atmel принадлежит к семейству MCS-51 (отечественный аналог - МК-51). Основное отличие AT89C2051 от i8051 - пониженное энергопотреблениее, сокращенное до 15-ти количество линий ввода-вывода, отсутствие возможности использовать внешнюю память. Более подробную информацию по AT89C2051 и i8051 можно найти на www.atmel.com и www.intel.com . Вместо AT89C2051 можно использовать AT89C51, i8051 (КР1816ВЕ51) или i8031 (КР1816ВЕ31) с внешним ПЗУ. Но два последних варианта из-за своего повышеного энергопотребления могут привести к перегоранию предохранителя контроллера клавиатуры.

На микроконтроллерах фирмы Atmel после основного обозначения указывается максимальная частота тактового генератора в мегагерцах. Я советую ставить микроконтроллер расчитанный на частоту 24МГц и кварц с частотой повыше - 16-20МГц.

Принципиальная схема. (R1-R4 - 47K; R5 - 10K; C1, C2 - 18пФ; C3 - 1мкФ; D1 - AT89C2051; BQ1 - кварц 12-24МГц)

Линия P1.4 используется как выход разрешения опроса кнопок. Это - задел для будущих расширений, - линии P1.4-P1.7 будут использованы для выдачи адреса строки для опроса нажатых кнопок (до 16-ти строк по 4-ре кнопки). «0» на линии P1.0-P1.3 означает, что нажата соответствующая кнопка.

Элементы C3 и R5 реализовывают схему генерации сигнала сброса при подаче питания.

Линии KBData со стороны клавиатуры и контроллера подаются на входы P3.2 (INT0) и P3.3 (INT1). Таким образом попытка инициировать передачу данных со стороны клавиатуры или контроллера вызывает соответствующее прерывание. Подпрограммы обслуживания этих прерываний просто транслируют сигналы, соответствующие передаче одного байта, через микроконтроллер. В то время, когда микроконтроллер не занят передачей данных, происходит опрос линий P1.0-P1.4, обработка полученых данных и выдача соответствующих скан-кодов контроллеру. В данной версии приоритет отдается данным, передаваемым самим устройством. Поэтому данные от клавиатуры иногда могут теряться.

Завершая этот раздел, приведу распиновку разъемов AT- и PS/2-клавиатуры.

Сигнал -KBReset - необязательный сигнал. Некоторые контроллеры могут использовать его для сброса клавиатуры.

Текст микропрограммы

Я привожу исходный текст микропрограммы для микроконтроллера AT89C2051 в надежде на то, что пытливый читатель сможет меня поправить или адаптировать программу для работы с другим типом микроконтроллера.

Org 0 sjmp start org 3 jmp from_keyboard ; INT0 org 13h jmp to_keyboard ; INT1 start mov a,#5 ; установка типа прерываний mov tcon,a ; INT0 и INT1 по фронту - mov a,#0 ; переход из "1" в "0" mov ip,a mov a,#85h mov ie,a mov a,#0ffh ; по адресу 06h хранится последний mov 6,a ; обработанный код clr p1.4 ; разрешение опроса loop mov a,p1 ; считывается состояние кнопок anl a,#15 ; - младшие четыре разряда порта P1 ; D0 - вверх; D1 - вправо; D2 - вниз; D3 - влево mov dptr,#hat_table ; считанные данные о четырех кнопках movc a,@a+dptr ; расширяются до восьми направлений; D0 - вверх; D1 - вправо; D2 - вниз; D3 - влево; D4 - вправо-вверх; D5 - вправо-вниз; D6 - влево-вниз; D7 - влево-вверх mov r2,a ; сохранение данных mov r0,a xrl a,6 ; если новые данные не отличаются от jz loop ; полученных в предыдущем цикле - повторяем опрос mov r1,#8 ; цикл для восьми разрядов loop3 jnb acc.7,loop2 ; "1" - было изменение push acc mov a,r1 mov dptr,#key_table-1 ; извлекаем соответствующий скан-код movc a,@a+dptr push acc mov a,r0 ; ресистр R0 - признак нажатия/отпускания rlc a ; эмулируемой клавиши mov r0,a ; "1" - "клавиша" была отпущена pop acc mov acc.7,c ; если D7=1 - скан-коду будет предшествовать 0f0h acall send_key ; выдача скан-кода pop acc sjmp loop2a loop2 push acc mov a,r0 rlc a mov r0,a pop acc loop2a rl a djnz 1,loop3 mov 6,r2 sjmp loop send_key mov ie,#80h ; прерывания запрещены acall send2comp ; посылка скан-кода mov ie,#85h ; прерывания разрешены ret send2comp jnb acc.7,send ; при необходимости первым выдается 0f0h push acc mov a,#0f0h acall send pop acc clr acc.7 mov b,#200 l9 nop djnz b,l9 send push 1 push 0 clr p3.3 ; P3.3 - KBData mov b,#6 ; выдача стартового бита l10 nop djnz b,l10 clr p3.5 mov b,#15 l2 nop djnz b,l2 setb p3.5 mov b,#6 l3 nop djnz b,l3 mov r0,#8 ; выдача восьми бит данных и подсчет четности mov r1,#1 byte_loop xrl 1h,a rrc a mov p3.3,c mov b,#6 l6 nop djnz b,l6 clr p3.5 mov b,#15 l4 nop djnz b,l4 setb p3.5 mov b,#6 l5 nop djnz b,l5 djnz r0,byte_loop mov a,r1 mov c,acc.0 mov p3.3,c ; выдача разряда четности mov b,#6 l8 nop djnz b,l8 clr p3.5 mov b,#15 l12 nop djnz b,l12 setb p3.5 mov b,#6 l13 nop djnz b,l13 setb p3.3 ; выдача стопового бита mov b,#6 l7 nop djnz b,l7 clr p3.5 mov b,#15 l11 nop djnz b,l11 setb p3.5 mov b,#200 l14 nop djnz b,l14 setb p3.5 pop 0 pop 1 ret from_keyboard ; передача одного байта к контроллеру mov ie,#80h push psw push acc push b mov b,#2 in6 jnb p3.4,in8 djnz b,in6 sjmp in7 in8 mov b,#10 in1 mov a,p3 rl a orl a,#11010111b mov p3,a jnb p3.4,in1 in2 mov a,p3 rl a orl a,#11010111b mov p3,a jb p3.4,in2 djnz b,in1 in3 mov a,p3 rl a orl a,#11010111b mov p3,a jnb p3.4,in3 mov p3,#0ffh in4 jb p3.5,in4 in5 jnb p3.3,in7 clr p3.4 jnb p3.5,in5 in7 mov p3,#0ffh pop b pop acc pop psw mov tcon,#5 mov ie,#85h reti to_keyboard ; передача одного байта к клавиатуре mov ie,#80h push psw push acc push b mov b,#5 out61 jb p3.5,out7 djnz b,out61 setb p3.4 setb p3.2 out62 jnb p3.5,out62 out6 mov c,p3.4 mov p3.5,c mov c,p3.3 mov p3.2,c jb p3.4,out6 out8 mov b,#10 out1 mov c,p3.4 mov p3.5,c mov c,p3.3 mov p3.2,c jnb p3.4,out1 out2 mov c,p3.4 mov p3.5,c mov c,p3.3 mov p3.2,c jb p3.4,out2 djnz b,out1 out3 mov c,p3.4 mov p3.5,c mov c,p3.2 mov p3.3,c jnb p3.2,out3 out7 mov p3,#0ffh pop b pop acc pop psw mov tcon,#5 mov ie,#85h reti hat_table ; таблица для расширения данных считанных с порта P1 ; индекс в таблице - четырехразрядный двоичный код; данные - состояние восьми эмулируемых клавиш; "0" - клавиша нажата db 0ffh ; влево+вправо+вверх+вниз=запрещенная комбинация db 0ffh ; влево+вправо+вниз=запрещенная комбинация db 0ffh ; влево+вверх+вниз=запрещенная комбинация db 0bfh ; влево+вниз=влево-вниз db 0ffh ; влево+вправо+вверх=запрещенная комбинация db 0ffh ; влево+вправо=запрещенная комбинация db 07fh ; влево+вверх=влево-вверх db 0f7h ; влево db 0ffh ; вправо+вверх+вниз=запрещенная комбинация db 0dfh ; вниз+вправо=вниз-вправо db 0ffh ; вверх+вниз=запрещенная комбинация db 0fbh ; вниз db 0efh ; вправо+вверх=вправо-вверх db 0fdh ; вправо db 0feh ; вверх db 0ffh ; нет нажатых кнопок key_table ; таблица скан-кодов db 75h ; numpad 8 db 74h ; numpad 6 db 72h ; numpad 2 db 6bh ; numpad 4 db 7dh ; numpad 9 db 7ah ; numpad 3 db 69h ; numpad 1 db 6ch ; numpad 7

В архиве tools.zip вы найдете две программы: a51.exe - асемблер, hex2bin - конвертер hex-файлов, которые получаются на выходе асемблера, в двоичный формат, пригодный для прошивки ПЗУ микроконтроллера программатором.

Сборка и устранение неполадок

Собрать устройство по приведенной выше схеме можно на макетнице, плате вытравленной в домашних условиях или изготовленной промышленным способом. Под микроконтроллер следует поставить панельку. Лучше всего оставить место на плате под 2-3 16-выводных DIP-корпуса - они будут добавлены в последующих версиях.

Далее, после внесения желаемых изменений, ассемблируется исходный текст микропрограммы - программой a51.exe. Для прошивки программатором полученный hex-файл переводится в двоичный образ программой hex2bin.exe.

Собрав полностью устройство, подключаем его к клавиатуре и компьютеру. Три... Два... Один... Поехали!.. Правильно собранное из заведомо исправных компонентов устройство должно заработать сразу. Если нет - проверьте правильность монтажа, наличие питания на микроконтроллере. Осцилографом проверьте, запустился ли тактовый генератор и приходит ли импульс высокого уровня на вход RST при включении питания. При нажатии клавиш на клавиатуре импульсы на линиях P3.3 и P3.5 должны повторять с некоторой задержкой импульсы на линиях P3.2 и P3.4 соответственно. При нажатии/отпускании кнопок устройства на линиях P3.3 и P3.5 должны также появляться ипульсы. Если это не поможет - напишите мне (rashpil at aport dot ru ) багрепорт, указав модель и тип (AT, PS/2) своей клавиатуры, материнской платы/мультикарты, использованого микроконтроллера и частоту использованого кварцевого резонатора. Я постарался протестировать устройство с максимальным числом доступных мне материнских плат и клавиатур - неполадок выявлено не было. В моем случае использован кварц 14.2МГц.

Known bugs

Текущая версия микропрограммы содержит такие недоработки:

  • Не отслеживаются двухбайтовые скан-коды. Это приводит к тому, что иногда, при использовании одновременно хатки и клавиатуры, клавиши клавиатуры «зависают» в нажатом состоянии или воспринимаются неверно;
  • Иногда неверно передаются данные от контроллера к клавиатуре. Это может выражаться, например, в том, что не меняют свое состояние светодиоды, при нажатии клавиш Num Lock, Caps Lock, Scroll Lock;
  • Дребезг контактов кнопок хатки. Пока что это не стало фатальным для меня в играх.

Планы на будущее

Вот краткий список того, что я хотел бы реализовать в последующих версиях:

  • Мелкие багфиксы - более корректная обработка сигналов; отслеживание двухбайтовых скан-кодов;
  • Подключение матрицы 16x4 - поддержка до 64-х кнопок или двух хаток и до 56-ти кнопок;
  • Поддержка до 16-ти различных раскладок скан-кодов, сохраненных в ПЗУ микроконтроллера;
  • Подключение микросхемы NVRAM с возможностью сохранения и перепрограммирования «на лету» до 32-х раскладок скан-кодов.

Заключение

Я постарался изложить все данные, необходимые для понимания принципа функционирования моего устройства. Это описание не претендует на стопроцентную техническую точность. Если я в чем-то заблуждаюсь - пожалуйста изложите мне свою версию событий. Если вы сможете внести в мою схему и/или микропрограмму улучшения и дополнения, если у вас есть идеи относительно дальнейшего развития схемы - также сообщите мне об этом. Кроме того, жду информации от умельцев, которые смогли повторить или адаптировать это устройство под другие типы микроконтроллеров.

Владимир "Рашпиль" Климус (rashpil at ukr dot net )

Скорее всего на вашем телефоне уже установлен по умолчанию сканер QR-кода, вы можете легко с его помощью просканировать первый QR-код. Сделать это очень легко. Просто следуйте нашей инструкции.

1. Откройте устройство чтения QR-кода на своем телефоне.

2. Держите устройство над QR-кодом так, чтобы он был хорошо виден на экране вашего смартфона.

Если вы правильно держите смартфон над QR-кодом, то в таком случае произойдет следующее:

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

3. Нажмите указанную кнопку, если потребуется.

Супер! Ваш смартфон считывает код и переходить по заданной ссылке, что не всегда происходит мгновенно. На большинстве устройств это может занять несколько секунд.

Вы начнете видеть QR-коды повсюду. Они используются для обучения, информирования, объяснения и для многих других вещей. Находите их и сканируете! QR-коды сэкономят вам много времени и усилий.

Как сканировать QR-коды на Android

А теперь мы расскажем вам, как использовать приложение сканирования для QR-кодов на Android.

Кратко:
1. Откройте Play Маркет .
2. Поиск считывателя QR-кода .
3. Выберите QR Code Reader (через Scan).
4. Нажмите «Установить» .
5. Откройте программу чтения QR-кода .
7. Направьте камеру на QR-код.
8. Нажмите «ОК» .

Шаг 1 . Откройте Play Маркет на Android. Это значок в приложении или на главном экране.

Шаг 2. Введите считыватель QR-кода в поисковике. Появится список приложений для чтения QR-кода.

  • Эта статья объясняет, как использовать QR-код Reader, но вы можете выбрать то, приложение, которое вам понравится. Просто не забудьте прочитать о приложении перед загрузкой.
  • Шаги должны быть одинаковыми для всех приложений чтения QR-кода.

Шаг 3. Нажмите QR Code Reader, разработанный Scan. Имя разработчика указано ниже каждого приложения. Возможно, вам придется прокрутить страницу вниз, чтобы найти приложение, сделанное Scan.

Шаг 4. Нажмите « Установить» . Появится всплывающее окно с просьбой предоставить разрешение для доступа к информации на вашем Android.

Шаг 5. Нажмите «Принять» . QR-код Reader теперь будет установлен на вашем Android-устройстве.

    • Когда приложение будет загружено, кнопка «Установить» смениться на «Открыть», и у вас появится новый значок в приложении.

Шаг 6. Откройте QR Code Reader. Это значок, который похож на QR-код в приложении. Откроется приложение, которое выглядит как стандартный экран камеры.

Шаг 7. Выровняйте QR-код в кадре камеры. Немного похоже на то, как вы делаете фотографии, за исключением того, что вам не нужно нажимать какие-либо кнопки. Когда сканер штрих кодов прочитает код, появится всплывающее окно с URL-адресом в коде.


Шаг 8. Нажмите «ОК», чтобы открыть веб-сайт. Это запускает ваш веб-браузер по умолчанию и перемещается по URL-адресу в QR-коде.