Arduino:Знакомство с Arduino/Знакомство с Arduino GSM Shield

Материал из Онлайн справочника
Перейти к навигации Перейти к поиску

{{#setlogo:ArduinoCommunityLogo.png}}

Перевод: Максим Кузьмин (Cubewriter) Контакты:</br>* Skype: cubewriter</br>* E-mail: cubewriter@gmail.com</br>* Максим Кузьмин на freelance.ru
Проверка/Оформление/Редактирование: Мякишев Е.А.


Знакомство с Arduino GSM Shield[1]

Модуль Arduino GSM Shield, подсоединенный к плате Arduino, позволяет подключаться к интернету, получать/отправлять SMS, а также делать голосовые звонки. На программном уровне все это обеспечивается при помощи библиотеки GSM.

С платой Arduino Uno модуль может работать сразу после распаковки, но для работы с Mega, Mega ADK, Yun и Leonardo ему потребуется небольшая модификация. Модель Due в данный момент не поддерживается.

Библиотека GSM идет в комплекте с IDE Arduino версией 1.0.4 и выше.

Что такое GSM

GSM – это международный стандарт для мобильной связи. Аббревиатура расшифровывается как Global System for Mobile Communications, что можно перевести как «глобальная система для мобильных коммуникаций». Кроме того, стандарт GSM иногда называют 2G, т.к. это, по сути, сотовая связь второго поколения.

Чтобы Arduino могла получить GPRS-доступ к интернету, а также делать запросы к веб-страницам и обслуживать их, вам нужно узнать у своего мобильного оператора APN (от Access Point Name, т.е. «имя точки доступа»), а также имя пользователя и пароль. Более подробно об этом читайте ниже, в разделе «Подключение к интернету».

Помимо прочего, GSM-модуль поддерживает входящие и исходящие голосовые звонки, стандарт Simple Message System (т.е. SMS или текстовые сообщения) и коммуникацию через GPRS.

То есть GSM-модуль Arduino – это, по сути, GSM-модем. С точки зрения мобильного оператора это обычный мобильный телефон. С точки зрения Arduino это просто модем.

Что такое GPRS

GPRS (от General Packet Radio Service, что можно перевести как «пакетная радиосвязь общего пользования») – это технология обмена пакетами. Он может обеспечивать скорость передачи данных в пределах 56-114 кбит/сек (в идеале).

На GPRS полагается множество технологий, среди которых есть, к примеру, стандарт SMS. Кроме того, посредством GSM-модуля можно осуществлять передачу данных и с помощью этого получать доступ в интернет. Так же, как библиотеки Ethernet и WiFi, библиотека GSM позволяет Arduino выступать в качестве клиента или сервера, использующего http-вызовы для получения и отправки веб-страниц.

Требования мобильного оператора

Чтобы получить доступ к сети, вы должны быть абонентом оператора мобильной связи (либо по контракту, либо по предоплате), иметь GSM-совместимый девайс вроде GSM-модуля Arduino или мобильного телефона, а также быть обладателем SIM-карты (от Subscriber Identity Module, что значит «модуль идентификации абонента»). SIM-карта предоставляется мобильным оператором, и в ней содержится информация вроде телефонного номера. Кроме того, на ней может храниться ограниченное число контактов и SMS-сообщений.

Чтобы использовать GPRS-доступ в интернет и чтобы Arduino могла запрашивать/обслуживать веб-страницы, вам нужно узнать у оператора APN, а также имя пользователя и пароль. Более подробно об этом читайте ниже – в разделе «Подключение к интернету».

SIM-карты

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

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

Кроме того, у вас есть возможность сбросить забытый или потерянный PIN-код, и это делается с помощью PUK-кода (от Pin Unlock Code, что значит «код для разблокировки PIN-кода). Этот PUK-код тоже указан в документации, идущей в комплекте с SIM-картой.

О том, как управлять PIN-кодом при помощи GSM-модуля и библиотеки GSM, читайте в этой статье. «Симки» бывают разных размеров, но GSM-модуль поддерживает лишь формат mini-SIM (25 мм в длину, 15 мм в ширину).

SIM-карта Telefonica/Movilforum

В комплекте с GSM-модулем Arduino также идет «симка» от Telefonica/Movilforum, которая хорошо подходит для M2M-приложений, т.е. для приложений, где коммуникация будет осуществляться по принципу «машина-машина». Впрочем, использовать именно эту карту необязательно. Можно пользоваться любой «симкой», которая работает в вашем регионе.

Карта от Movilforum включает в себя роуминговый тарифный план, и его можно использовать в любой поддерживаемой GSM-сети. Эта «симка» обеспечивает покрытие в американских и европейских странах, а в каких именно – читайте на этой странице официального сайта Movilforum.

Активация SIM-карты обрабатывается Movilforum. Подробные инструкции о том, как зарегистрировать и активировать карту в режиме онлайн и как пополнить ее счет, читайте в небольшой брошюре, идущей в комплекте с GSM-модулем. Во время активации «симка» должна быть вставлена в GSM-модуль, подключенный к питанию и плате Arduino.

Эта SIM-карта поставляется без PIN-кода, но его можно установить, и делается это при помощи класса GSMPin из библиотеки GSM.

Для приема и отправки голосовых звонков эту «симку» использовать нельзя.

Принимать и отправлять SMS-сообщения можно только от SIM-карт из сети Movilforum.

Кроме того, при использовании этой карты нельзя создавать сервер, который будет принимать входящие запросы из интернета общего пользования. Однако вы сможете получать входящие запросы от других SIM-карт из сети Movilforum.

Если вы хотите использовать голосовую и другие функции GSM-модуля, вам понадобится «симка» от другого оператора связи. У разных операторов разные подходы к использованию SIM-карт, и чтобы узнать, какие типы соединений они поддерживают, лучше обратитесь к ним напрямую.

Подключение GSM-модуля

Если вы используете Arduino Uno, следуйте инструкциям, описанным ниже. Если вы используете Arduino Mega, Mega ADK, Yun или Leonardo, следуйте этим инструкциям. Модель Arduino Due в данный момент не поддерживается.

Чтобы использовать GSM-модуль, к нему нужно подключить SIM-карту, и для этого у него есть соответствующий коннектор. Сдвиньте металлический ползунок этого коннектора от края GSM-модуля, а затем поднимите лоток для «симки».

OpenSIMHolder 1.jpg

Вставьте SIM-карту в пластиковый держатель таким образом, чтобы металлические контакты смотрели в сторону GSM-модуля, а вырез на карте был выше ползунка.

InsertSIM 2.jpg

Всуньте «симку» внутрь лотка на всю длину.

SlideSIMIn 3.jpg

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

SIMOnShield 4.jpg

Когда SIM-карта будет подключена, присоедините GSM-модуль к Arduino.

GSM UNO stacked 5.jpg

Чтобы загрузить скетч на плату, подключите ее к компьютеру при помощи USB-кабеля. Теперь при помощи IDE Arduino загрузите нужный скетч. После загрузки плату от компьютера можно отключить, а затем запитать от внешнего источника питания.

GSMPinUse.jpg

Цифровые контакты 2, 3 и 7 зарезервированы для коммуникации между Arduino и модемом, вследствие чего для скетчей использоваться не могут. На контактах 2 и 3 происходит коммуникация между модемом и Arduino, которая обрабатывается библиотекой Software Serial. Контакт 7 зарезервирован для сброса модема.

Когда на GSM-модуле загорается желтый статусный светодиод, это значит, что он запитан, и вы можете подключиться к сети.

GSM-модуль, помимо прочего, поставляется еще и в версии для разработчиков, и чтобы включить эту модель, вам нужно будет какое-то время нажимать на кнопку Power. Если у вас старая версия GSM-модуля, и она не включается автоматически, вы можете припаять перемычку к контакту CTRL/D7, расположенному на обратной стороне модуля. Благодаря этому GSM-модуль будет включаться всякий раз, когда начнет получать питание подключенная к нему Arduino.

GSM Pin7 bridged.jpg

Этот Shield-модуль должен работать в любом месте в пределах GSM-покрытия. Покупая модуль, убедитесь, что там, где вы планируете его использовать, это покрытие есть.

Библиотека GSM

Библиотека GSM обрабатывает коммуникацию между Arduino и GSM-модулем. Большая часть функций этой библиотеки – для управления обмена данными, а также SMS- и голосовой коммуникации. Кроме того, в ней имеются классы для управления информацией о модеме и PIN-коде «симки». Более подробную информацию и несколько скетчей-примеров можно найти тут.

Проверка модема и сетевого соединения

Задача этого скетча – проверка IMEI-номера модема. Этот номер уникален для каждого модема и используется для идентификации девайсов, которым разрешено подключаться к той или иной GSM-сети. Получив у модема этот номер, Arduino передаст через последовательный порт информацию об операторе связи, к которому подключен модем, а также о мощности сигнала в сети.

 1 // импортируем библиотеку GSM:
 2 #include <GSM.h>
 3 
 4 // PIN-код:
 5 #define PINNUMBER ""
 6 
 7 // инициализируем экземпляр библиотеки:
 8 GSM gsmAccess(true);     // задаем параметр «true» – для отладки
 9 GSMScanner scannerNetworks;
10 GSMModem modemTest;
11 
12 // Переменная для хранения данных:
13 String IMEI = "";
14 
15 // Статусное сообщение, которое будет передаваться через монитор порта:
16 String errortext = "ERROR";  //  "ОШИБКА"
17 
18 void setup()
19 {
20   // инициализируем последовательную коммуникацию:
21   Serial.begin(9600);
22   Serial.println("GSM networks scanner");  //  "Сканер GSM-сетей"
23   scannerNetworks.begin();
24 
25   // Состояние соединения:
26   boolean notConnected = true;
27 
28   // Запускаем GSM-модуль.
29   // Если у вашей «симки» есть PIN, впишите его в begin(), но не в голом виде, а в кавычках:
30   while(notConnected)
31   {
32     if(gsmAccess.begin(PINNUMBER)==GSM_READY)
33       notConnected = false;
34     else
35     {
36       Serial.println("Not connected");  //  "Нет соединения"
37       delay(1000);
38     }
39   }
40 
41   // Получаем параметры модема. 
42   // IMEI – это уникальный номер модема:
43   Serial.print("Modem IMEI: ");  //  "IMEI-номер модема: "
44   IMEI = modemTest.getIMEI();
45   IMEI.replace("\n","");
46   if(IMEI != NULL)
47     Serial.println(IMEI);
48 
49   // Оператор, подключенный в данный момент:
50   Serial.print("Current carrier: ");  //  "Текущий оператор: "
51   Serial.println(scannerNetworks.getCurrentCarrier());
52 
53   // Возвращаем данные о мощности сигнала и BER.
54   // Мощность сигнала – в диапазоне 0-31. 31 значит свыше 51 дБм.
55   // BER (от Bit Error Rate) – это коэффициент битовых ошибок.
56   // Диапазон значений - 0-7. 99 – неопределяемое значение.
57   Serial.print("Signal Strength: ");  //  "Мощность сигнала: "
58   Serial.print(scannerNetworks.getSignalStrength());
59   Serial.println(" [0-31]");
60 }
61 
62 void loop()
63 {
64   // Сканируем существующие сети, а затем отображаем список найденных сетей:
65   Serial.println("Scanning available networks. May take some seconds.");  //  "Сканирование доступных сетей. Может занять некоторое время."
66 
67   Serial.println(scannerNetworks.readNetworks());
68 
69     // Оператор, подключенный в данный момент:
70   Serial.print("Current carrier: ");  //  "Текущий оператор"
71 
72   Serial.println(scannerNetworks.getCurrentCarrier());
73 
74   // Возвращаем данные о мощности сигнала и BER.
75   // Мощность сигнала – в диапазоне 0-31. 31 значит свыше 51 дБм.
76   // BER (от Bit Error Rate) – это коэффициент битовых ошибок.
77   // Диапазон - 0-7. 99 – неопределяемое значение.
78   Serial.print("Signal Strength: ");    //  "Мощность сигнала: "
79   Serial.print(scannerNetworks.getSignalStrength());
80   Serial.println(" [0-31]");
81 
82 }

Отправка SMS-сообщения

Подключившись к сети при помощи скетча выше, вы можете протестировать и другие функции модуля. Этот скетч подключится к GSM-сети и отправит на указанный вами номер SMS-сообщение:

 1 #include <GSM.h>
 2 
 3 #define PINNUMBER ""
 4 
 5 // инициализируем экземпляр библиотеки:
 6 GSM gsmAccess; // задаем параметр «true» – для отладки
 7 GSM_SMS sms;
 8 
 9 // Символьный массив для номера, на который будет отправлено SMS.
10 // Меняем «12125551212» на номер, который нужен:
11 char remoteNumber[20]= "12125551212";  
12 
13 // Символьный массив для сообщения:
14 char txtMsg[200]="Test";
15 
16 void setup()
17 {
18   // инициализируем последовательную коммуникацию:
19   Serial.begin(9600);
20 
21   Serial.println("SMS Messages Sender");  //  "Отправщик SMS-сообщений"
22 
23   // Состояние соединения:
24   boolean notConnected = true;
25 
26   // Запускаем GSM-модуль.
27   // Если у «симки» есть PIN, впишите его в кавычках в begin():
28   while(notConnected)
29   {
30     if(gsmAccess.begin(PINNUMBER)==GSM_READY)
31       notConnected = false;
32     else
33     {
34       Serial.println("Not connected");  //  "Нет соединения"
35       delay(1000);
36     }
37   }
38   Serial.println("GSM initialized");  //  "GSM-связь инициализирована"
39   sendSMS();
40 }
41 
42 void loop()
43 {
44 // здесь ничего
45 }
46 
47 void sendSMS(){
48 
49   Serial.print("Message to mobile number: ");  //  "Сообщение будет отправлено на номер: "
50   Serial.println(remoteNumber);
51 
52   // Текст SMS:
53   Serial.println("SENDING");  //  "ОТПРАВКА"
54   Serial.println();
55   Serial.println("Message:");  //  "Сообщение:"
56   Serial.println(txtMsg);
57 
58   // Отправляем сообщение:
59   sms.beginSMS(remoteNumber);
60   sms.print(txtMsg);
61   sms.endSMS(); 
62   Serial.println("\nCOMPLETE!\n");    //  "\nГОТОВО!\n"
63 }

Подключение к интернету

Чтобы подключиться к интернету, вам понадобится, помимо SIM-карты и тарифного плана, еще и информация об APN – это то, что есть у каждого оператора связи. Это имя точки доступа, которая служит мостом между сотовой сетью и интернетом. Иногда для доступа к этой точке нужны имя пользователя и пароль. К примеру, Movilforum’овский APN – это sm2ms.movilforum.es, но ни имени пользователя, ни пароля у него нет.

Скетч ниже подключается к «arduino.cc/latest.txt» и выводит содержимое на монитор порта.

Примечание: Некоторые операторы блокируют входящий IP-трафик. Однако скетчи, использующие класс GSMClient (вроде скетча, описанного ниже), должны работать безо всяких проблем.

 1 // подключаем библиотеку GSM:
 2 #include <GSM.h>
 3 
 4 // PIN-код (если нужно):
 5 #define PINNUMBER ""
 6 
 7 // Информация об APN от вашего оператора связи:
 8 #define GPRS_APN       "GPRS_APN" // замените "GPRS_APN" на свой APN
 9 #define GPRS_LOGIN     "login"    // замените "login" на свой логин
10 #define GPRS_PASSWORD  "password" // замените "password" на свой пароль
11 
12 // инициализируем необходимые объекты из библиотеки GSM:
13 GSMClient client;
14 GPRS gprs;
15 GSM gsmAccess;
16 
17 // Этот скетч-пример загружает содержимое URL’а "http://arduino.cc/latest.txt"
18 
19 char server[] = "arduino.cc"; // название сайта
20 char path[] = "/latest.txt"; // путь
21 int port = 80; // порт, 80 для HTTP
22 
23 void setup()
24 {
25   // инициализируем последовательную коммуникацию:
26   Serial.begin(9600);
27   Serial.println("Starting Arduino web client.");  //  "Запуск веб-клиента Arduino."
28   // состояние соединения:
29   boolean notConnected = true;
30 
31   // Запускаем GSM-модуль.
32   // Указываем PIN-код «симки» как параметр в функции gsmAccess.begin():
33   while(notConnected)
34   {
35     if((gsmAccess.begin(PINNUMBER)==GSM_READY) &
36         (gprs.attachGPRS(GPRS_APN, GPRS_LOGIN, GPRS_PASSWORD)==GPRS_READY))
37       notConnected = false;
38     else
39     {
40       Serial.println("Not connected");  //  "Нет соединения"
41       delay(1000);
42     }
43   }
44 
45   Serial.println("connecting...");  //  "Подключение..."
46 
47   // Если подключение есть, сообщаем об этом на монитор порта:
48   if (client.connect(server, port))
49   {
50     Serial.println("connected");  //  "Подключено"
51     // Делаем HTTP-запрос:
52     client.print("GET ");
53     client.print(path);
54     client.println(" HTTP/1.0");
55     client.println();
56   } 
57   else
58   {
59     // Если соединения с сервером нет:
60     Serial.println("connection failed");    //  "Подключение не удалось"
61   }
62 }
63 
64 void loop()
65 {
66   // Если от сервера доступны какие-то байты,
67   // считываем их и выводим на монитор порта:
68   if (client.available())
69   {
70     char c = client.read();
71     Serial.print(c);
72   }
73 
74   // Если сервер отключен, останавливаем работу клиента:
75   if (!client.available() && !client.connected())
76   {
77     Serial.println();
78     Serial.println("disconnecting.");  //  "Отключение."
79     client.stop();
80 
81     // вечно ничего не делаем:
82     for(;;)
83       ;
84   }
85 }

Голосовые звонки

При помощи GSM-модуля, помимо прочего, можно делать голосовые звонки. Однако для того, чтобы говорить и слышать собеседника по сторону провода, вам понадобятся дополнительные устройства – микрофон и динамики.

GSMShieldSpeakerMicHoles.jpg

На нижней стороне GSM-модуля есть отверстия с надписями M1P и M1N. Это контакты для входящего звукового потока со знаками «плюс» и «минус» – они предназначены для микрофона. Так же есть отверстия S1P и S1N, и это контакты для исходящего звукового потока со знаками «плюс» и «минус» – для динамика.

Здесь, в документации к модему, на 43 странице показан пример цепи, подключенной к наушникам:

GSMShieldMicSpeakerCircuit 1.png
GSMShieldVoiceSpeakerWiring 2.jpg
GSMShieldVoiceSpeakerBreadboard 3.jpg

Скетч, описанный ниже, предназначен для совершения голосовых звонков. Используя монитор порта, вы можете ввести номер, на который будет совершен звонок, либо отменить его. Когда увидите сообщение «READY», это значит, что пора вводить номер телефона. Убедитесь, что монитор порта настроен таким образом, чтобы при нажатии на  ↵ Enter вводился символ новой строки.

 1 #include <GSM.h>
 2 
 3 // PIN-код:
 4 #define PINNUMBER ""
 5 
 6 // инициализируем объекты библиотеки GSM, используемые в этом скетче:
 7 GSM gsmAccess;  // задаем параметр «true» – для отладки
 8 GSMVoiceCall vcs;
 9 
10 String remoteNumber = "";  // номер, на который будем звонить
11 char charbuffer[20];
12 
13 void setup()
14 {
15 
16   // инициализируем последовательную коммуникацию:
17   Serial.begin(9600); 
18 
19   Serial.println("Make Voice Call");  //  "Делаем голосовой звонок"
20 
21   // Состояние соединения:
22   boolean notConnected = true;
23 
24   // Запускаем GSM-модуль.
25   // Если у карты есть PIN, указываем его в кавычках в функции begin():
26   while(notConnected)
27   {
28     if(gsmAccess.begin(PINNUMBER)==GSM_READY)
29       notConnected = false;
30     else
31     {
32       Serial.println("Not connected");  //  "Нет соединения"
33       delay(1000);
34     }
35   }
36 
37   Serial.println("GSM initialized.");  //  "GSM-связь инициализирована"
38   Serial.println("Enter phone number to call.");    //  "Введите номер для звонка."
39 
40 }
41 
42 void loop()
43 {
44 
45   // добавляем в строку все присланные символы:
46   while (Serial.available() > 0)
47   {
48     char inChar = Serial.read();
49     // если это символ новой строки, это значит, что пора делать звонок:
50     if (inChar == '\n')
51     {
52       // убедитесь, что номер не слишком длинный:
53       if (remoteNumber.length() < 20)
54       {
55         // показываем номер, на который будем звонить:
56         Serial.print("Calling to : ");  //  "Звоним на: "
57         Serial.println(remoteNumber);
58         Serial.println();
59 
60         // Звоним на указанный номер:
61         remoteNumber.toCharArray(charbuffer, 20);
62 
63 
64         // Проверяем, взяли ли на том конце трубку:
65         if(vcs.voiceCall(charbuffer))
66         {
67           Serial.println("Call Established. Enter line to end");  //  "Есть связь. Введите Enter, чтобы завершить звонок"
68           // Ждем, не нажмет ли пользователь Enter:
69           while(Serial.read()!='\n' && (vcs.getvoiceCallStatus()==TALKING));          
70           // ...и вешаем трубку:
71           vcs.hangCall();
72         }
73         Serial.println("Call Finished");  //  "Звонок завершен"
74         remoteNumber="";
75         Serial.println("Enter phone number to call.");  //  "Введите номер для звонка"
76       } 
77       else
78       {
79         Serial.println("That's too long for a phone number. I'm forgetting it");  //  "Слишком длинный номер. Трудновато запомнить"
80         remoteNumber = "";
81       }
82     } 
83     else
84     {
85       // добавляем к сообщению последний символ, чтобы отправить:
86       if(inChar!='\r')
87         remoteNumber += inChar;
88     }
89   } 
90 }

Что дальше

Теперь, когда мы протестировали базовый функционал GSM-модуля, можете кликнуть сюда – чтобы получше узнать об API библиотеки GSM и попробовать другие примеры.

См.также

Внешние ссылки