React Native BLE Serial with HM-10

한글 버전 : https://goo.gl/IHwMCJ

Let’s summarize the connection between Android and iOS Bluetooth.

Currently, the hardware part is complete, but the bluetooth module is not recognized by iOS devices.

Bluetooth is currently up to version 5, but iOS only supports BLE version (version 4). Current module (product) that converts serial signal to Bluetooth supports only V2.

Since the serial signal (TX / RX) comes out from the product, you can simply change it to the BLE signal, but the problem becomes complicated because the serial protocol has been expelled since version 4 (BLE).

About Bluetooth : https://en.wikipedia.org/wiki/Bluetooth

In summary, every chip maker has to create a workaround to support SPP(Serial Port Service) and a corresponding implementation on each mobile platform. And mobile developer need to implement according to the guideline provided by the chip manufacturer, or the makers of the module using the chip implement and provide to the developers. Anyway the implementation seems to require knowledge of the firmware.

BLE chip etc

Eventually, we searched for the BLE-UART module and narrowed it down to the provider which supports mobile source code (or library), some of which only provided Android.

So, I wanted the most used modules, and eventually I found a cheap, heavily used module called HM-10. There was one in the office. I will test it with the module next week, both iOS and Android sources.

iOS sourcecode : https://github.com/hoiberg/HM10-BluetoothSerial-iOS

One disappointing thing is that I thought it would be easy to link with the react-native-bluetooth-serial module, but I have to connect directly with the native.

2017. 2. 4

I replaced current V2 version with the HM-10 module, no problem with connection and packet receiving on iOS. The above source code was used and tested without any problems.

Next, we need to test Android, which is not urgent.

The source code link : https://github.com/danasf/hm10-android-arduino

2017. 2. 13 추가.

__ to be continued

React Native Tip

리액트 네이티브로 개발을 하면서, 리액티브 개발이 정말 편하다는 것을 느끼지만, 그동안 객체지향이나 MVC 패턴을 워낙 오래 사용했던지라 가끔 벽에 부딪히는 것은 어쩔 수 없는 듯 하다.

그동안 제일 어려웠던 건, 리덕스와 비지니스 로직을 연결하는 방법이었던 것 같은데, 매번 비즈니스 로직을 독립된 클래스로 만들어서 싱글톤으로 사용했더랬다. 여기에 대해서는  좀 더 고민을 하고 결론이 나면 나중에 정리하고 싶다.

❤ 18 업뎃> 오늘 기준으로 (개발 3개월 차 ㅎㅎ) 위에 대해 부연하자면.. Realm DB 스키마와 그 클래시 관련 로직을 담는 모델 클래스를 제외하고는 모든 로직이 리듀서로 들어갔고, 그게 그렇게 나쁘게 보이지는 않다는 겁니다. 하지만, 아직도 코드가 어글리 한데, 이에 대한 원인은.

‘한 액션 처리를 여러 리듀서 파일에서 가능하다는 것’

을 그동안 몰랐었던 데 대부분 있습니다. 자바 스크립트 언어 자체에 대한 깊이가 없으니, import, export 도 새롭고 시행착오도 많았고, 그 대표적인 케이스가 어떤 액션이 있을 때 이를 꼭 한군데서 처리해야될 것 같은 편견이었던 것 같습니다.

별것 아닌 이 부분을 알고나니 모델 클래스를 따로 만들려는 마음보다는 리듀서를 깔끔하게 정리하고자 하는 의욕이 더 강해지는 걸 느낄 수 있었습니다.

</3 18 업뎃> // 리액트 코딩을 하다보니.. 글도 이렇게 쓰게 되더라는 ..ㅎㅎ

이 글에서는 이보다는 간단한, 컴퍼넌트에 기본 값을 주는 방법에 대해 오늘 내린 결론을 정리한다.

컴퍼넌트에 기본 값을 준다.

React Native BLE Serial 구현하기

영문 버전 : https://goo.gl/R58pFo

안드로이드와 iOS 블루투스 연결에 대해서 정리해 봅니다.

현재 하드웨어는 완성된 상태고, 앱에서 블루투스 연결을 시도하는 상태에서 기기 인식을 못하는 증상이 발견되어 해결하는 과정입니다.

블루투스는 현재 버전 5 까지 나와 있습니다만, iOS에서는 BLE 버전(버전 4)만 지원하는데 현재 하드웨어에 시리얼 신호를 블루투스로 변환하는 모듈(제품 페이지)이 V2 입니다.

블루투스 버전 : https://en.wikipedia.org/wiki/Bluetooth

제품에서는 시리얼 신호 (TX/RX)가 나오므로 이를 단순히 BLE 신호로 바꿔주면 되지만, BLE 즉, 버전4에서부터 시리얼 프로토콜이 빠졌기 때문에 문제가 복잡해 집니다.

요약하면 BLE 칩 제조사마다 이를 지원하기 위한 우회로를 만들고 모바일에서는 이에 상응하는 구현을 해야 하는 겁니다. 결국 칩 제조사가 내놓은 가이드라인을 따라 직접 구현하던가, 칩을 이용하여 모듈을 만드는 업체들에서 구현해서 배포하던가 하는데, 이 내용은 펌웨어에 대한 지식이 필요해 보입니다.

블루투스 칩 관련 참고 자료

결국 BLE – UART 모듈을 검색하고, 이 중에서 모바일 쪽 소스코드(혹은 라이브러리)를 제공하는 업체로 좁히게 되는데, 어떤 업체는 안드로이드만 제공하는 경우도 있었습니다.

그래서, 가장 많이 사용하는 모듈을 수배했고, 결국 HM-10 이라는 싸고, 많이 쓰이는 모듈을 발견했습니다. 마침 사무실에도 하나 있었구요.  다음 주에 모듈을 장착하면 테스트 해 볼 예정이고, iOS 소스, 안드로이드 소스 모두 있습니다.

iOS sourcecode : https://github.com/hoiberg/HM10-BluetoothSerial-iOS

한가지 아쉬운 점은 react-native-bluetooth-serial 모듈을 쓰면 쉽게 링크될 것이라고 생각했는데, 직접 네이티브와 연결해야 한다는 것인데요, 이참에 공부해야겠습니다.

2017. 2. 4 여기까지

기존 V2 버전을 HM-10 모듈로 교체하니 iOS 에서 패킷이 잘 들어오네요. 위의 소스코드가 바로 설치되어 문제 없이 테스트 했습니다.

다음은 안드로이드를 테스트 해야하는데, 이건 나중에 해도 되니 일단 소스코드 링크만.

https://github.com/danasf/hm10-android-arduino

2017. 2. 13 추가.

 

__ to be continued..