개발중인 어플리케이션 프로젝트(.apk)를 라이브러리 모듈(.aar)로 변경해야 할 경우 설정방법을 알아보도록 하자.
프로젝트 이름은 'mytest'일 경우 다음과 같은 순서로 설정을 변경하도록 하자.
불필요한 소스 파일 제거
라이브러리 파일에 필요한 소스코드를 제외하고 나머지 파일들은 모두 제거하도록 한다.
AndroidManifest.xml 수정
application요소와 앱 관련 설정을 제거하고, 라이브러리에서 필요한 설정만 남겨둡니다.
예를 들어, 권한이나 기본 설정 등을 유지할 수 있습니다.
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.mytest">
<!-- 필요한 권한 및 기타 설정을 여기에 추가 -->
<!-- 예: INTERNET 권한 -->
<uses-permission android:name="android.permission.INTERNET" />
<!-- 필요하다면 다른 권한도 추가 가능 -->
<!-- 라이브러리에서 제공하는 특정 기능을 위한 설정 -->
<!-- 예: 서비스나 리시버 등 -->
<!--
<application>
<service android:name=".MyService" />
<receiver android:name=".MyReceiver">
<intent-filter>
<action android:name="com.example.mytest.SOME_ACTION" />
</intent-filter>
</receiver>
</application>
-->
</manifest>
'build.gradle.kts' (Project: MyTest)
// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
alias(libs.plugins.android.application) apply false
// 라이브러리 플러그인 추가
alias(libs.plugins.android.library) apply false
alias(libs.plugins.jetbrains.kotlin.android) apply false
}
| AD Length | AD Type | Manufacturer ID | Beacon ID | Major | Minor | TX Power |
iBeacon
| AD Length | AD Type | Manufacturer ID | iBeacon Prefix | UUID | Major | Minor | TX Power |
참고사항 :
Beacon과 iBeacon은 Advertisement Data의 AD Type으로 일반적으로 0xFF(Manufacturer Specific Data)를 사용합니다. 이 AD Type은 제조사에 특화된 데이터를 나타내며, Beacon과 iBeacon은 자체적인 프로토콜을 사용하여 이 부분에 정보를 담습니다.
따라서 Beacon이나 iBeacon으로 방송될 때, Advertisement Data의 AD Type이 0xFF로 설정되는 것이 일반적입니다. 그리고 이 AD Type 뒤에 이어지는 데이터 부분에는 Beacon이나 iBeacon에 대한 고유한 정보가 포함됩니다.
이러한 설정은 Beacon 또는 iBeacon의 프로토콜 스펙에 따라 다를 수 있으므로, 구체적인 Beacon 또는 iBeacon의 문서나 스펙을 참고하여야 합니다. Beacon과 iBeacon은 자체적으로 프로토콜을 정의하고 있기 때문에, 이러한 세부 사항은 제조사 또는 표준에 따라 다르게 정의될 수 있습니다.
BLE Advertising Payload format을 raw data로 부터 분리 추출하는 방법을 알아보겠다.
raw data로 부터 payload 포맷에 대한 이해에 도움이 되길 바란다.
Flags, Manufacturer Specify Data, TX Power Level, Slave Connection Interval Range (BLE 5.0미만), Service UUIDs (Complete UUID 128 bit), Device Name, Service Data, Beacon Adv. Data, iBeacon Adv. Data 등의 포맷을 알아 보겠다.
——————————————————————————————————————————
Flags
02 01 06
——————————————————————————————————————————
AD length : 0x02 (2)
AD Type : 0x01 (1)
- 0x01 : Flags
AD data : 0x06
- 0x06 ( 0000 0110 B )
- Bit 0 : LE Limited Discoverable Mode NO
- Bit 1 : LE General Discoverable Mode YES
- Bit 2 : BR / EDR Not Supported YES
- Bit 3 : Simultaneous LE and BR/EDR to Same Device Capable NO
- Bit 4 : Simultaneous LE and BR/EDR to Same Device Capable (Host) NO
- Bit 5 : Reserved
- Bit 6 : Reserved
- Bit 7 : Reserved
——————————————————————————————————————————
Manufacturer Specific Data
1B FF 59 00 01 C0 11 11 11 11 CC 64 F0 0A 0B 0C 0D 0E 0F 10 11 12 13 14 15 16 17 18
——————————————————————————————————————————
AD length : 0x1B (27)
AD Type : 0xFF (255)
- 0xFF : Manufacturer Specific Data
AD data :
Company Id :
- 0x0059 (89)
Manufacturer Specific Data :
- 0x01C0111111CC64F00A0B0C0D0E0F101112131415161718
- Header of Manufacturer Payload (0) : 0x01 (1)
- MAC Address (1-7) : 0xCC, 0x11, 0x11, 0x11, 0x11, 0xC0
- Battery Value in % (8) : 0x64 (100) %
- Measured RSSI Value (9) : 0xF0 (240)
- Other Value (10-24) : 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18
TX Power Level
Length
Data Type
TX Power Level
0x02 (2)
0x0A (10)
0xFC (-4 dBm)
——————————————————————————————————————————
Tx Power Level
02 0A FC
——————————————————————————————————————————
AD length : 0x02 (2)
AD Type : 0x0A (10)
- 0x0A : Tx Power Level
AD data : 0xFC (-4 dBm)
- 0xFC ( 1111 1100 B )
- 부호 있는 8비트 정수이므로 2의 보수를 취해 값을 구한다.
- 11111100을 반전하면 00000011. 그리고 1을 더하면 00000100. 즉, 값은 -4가 된다.
Slave Connection Interval Range
Length
Data Type
Minimum
Maximum
0x05 (5)
0x12 (18)
0x0006 (7.5ms)
0x0014 (25ms)
——————————————————————————————————————————
Slave Connection Interval Range
05 12 06 00 14 00
——————————————————————————————————————————
AD length : 0x05 (5)
AD Type : 0x12 (18)
- 0x12 : Slave Connection Interval Range
AD data :
- BLE 5.0 미만 버전에서 사용 됨. BLE 5.0 이상에서는 Advertising ID로 변경 됨.
- Slave Connection Interval은 BLE(Bluetooth Low Energy)에서 두 장치 간의 연결 주기를 나타내는 값입니다.
- Connection Interval은 두 연속적인 연결 사이의 시간 간격을 말하며, 이를 설정함으로써 연결의 성능과 전력 소비를 조절할 수 있습니다.
- 최소 값과 최대 값은 16진수로 표현된 값이며, 단위는 1.25ms입니다.
- Connection Interval Min/Max (ms)=16진수 값×1.25
Minimum :
- 0x0006 (6)
- 6 x 1.25 = 7.5 ms
Maximum :
- 0x0014 (20)
- 20 x 1.25 = 25 ms
Service UUIDs (Complete UUID 128 bit)
Length
Data Type
UUID
0x11 (17)
0x07 (7)
0x6E400001-B5A3-F393-E0A9-E50E24DCCA9E
——————————————————————————————————————————
Complete List of 128-bit Service Class UUIDs
11 07 9E CA DC 24 0E E5 A9 E0 93 F3 A3 B5 01 00 40 6E
——————————————————————————————————————————
AD length : 0x11 (17)
AD Type : 0x07 (7)
- 0x12 : Complete List of 128-bit Service Class UUIDs
AD data :
- 0x6E400001-B5A3-F393-E0A9-E50E24DCCA9E
Complete Local Name
Length
Data Type
Complete Local Name
0x0C (12)
0x09 (9)
Nordic_UART (0x4E6F726469635F55415254)
——————————————————————————————————————————
Complete Local Name
0C 09 4E 6F 72 64 69 63 5F 55 41 52 54
——————————————————————————————————————————
AD length : 0x0C (12)
AD Type : 0x09 (9)
- 0x09 : Complete Local Name
AD data :
- Nordic_UART (0x4E6F726469635F55415254)
Beacon Adv. Data
Length
Data Type
Beacon Adv. Data
0x1A (26)
0xFF (255)
0x004C 000215 112233445566778899AABBCCDD
——————————————————————————————————————————
Beacon Adv. Data
| AD Length | AD Type | Manufacturer ID | Beacon ID | Major | Minor | TX Power |
1A FF 00 4C 00 02 15 11 22 33 44 55 66 77 88 99 AA BB CC DD
——————————————————————————————————————————
AD length : 0x1A (26)
AD Type : 0xFF (255)
- 0xFF : Manufacturer Specific Data
AD data :
Manufacturer :
- 0x004C (Beacon을 제조한 회사의 ID)
Beacon ID :
- 0x000215 (Beacon을 식별하는 고유 ID)
Beacon Data :
- 0x112233445566778899AABBCCDD (Beacon 고유 데이터)
- Beacon Data의 세부 사항은 제조사 또는 표준에 따라 다르게 정의될 수 있다.
- 일반적으로 Major, Minor, TX Power를 사용한다.
——————————————————————————————————————————
iBeacon Adv. Data
| AD Length | AD Type | Manufacturer ID | iBeacon Prefix | UUID | Major | Minor | TX Power |
1F FF 4C 00 02 15 E2C56DB5DFFB48D2B060D0F5A71096E0 0001 0002 C5
——————————————————————————————————————————
AD length : 0x1A (26)
AD Type : 0xFF (255)
- 0xFF : Manufacturer Specific Data
AD data :
Manufacturer :
- 0x4C (Beacon을 제조한 회사의 ID)
iBeacon Prefix :
- 0x000215 (Apple이 iBeacon을 식별하기 위한 특별한 값)
UUID :
- 0xE2C56DB5DFFB48D2B060D0F5A71096E0 (16바이트의 Universally Unique Identifier)
Major :
- 0x0001 (주요 범주를 식별하는 값)
Minor :
- 0x0002 (Major 범주 내에서 세부 항목을 식별하는 값)
TX Power :
- 0xC5 (전송 전력을 나타내는 값)
※ Flags, Service Data, Complete Local Name
Flags
Length
Data Type
Service Data
0x02 (2)
0x01 (1)
0x06
Service Data
Length
Data Type
Service Data
0x05 (5)
0x16 (22)
0x6E2ADB02
Complete Local Name
Length
Data Type
Service Data
0x0B (11)
0x09 (9)
0x50205420383034394638
——————————————————————————————————————————
Flags
02 01 06
——————————————————————————————————————————
AD length : 0x02 (2)
AD Type : 0x01 (1)
- 0x01 : Flags
AD data : 0x06
- 0x06 ( 0000 0110 B )
- Bit 0 : LE Limited Discoverable Mode NO
- Bit 1 : LE General Discoverable Mode YES
- Bit 2 : BR / EDR Not Supported YES
- Bit 3 : Simultaneous LE and BR/EDR to Same Device Capable NO
- Bit 4 : Simultaneous LE and BR/EDR to Same Device Capable (Host) NO
- Bit 5 : Reserved
- Bit 6 : Reserved
- Bit 7 : Reserved
——————————————————————————————————————————
Service Data 16-bit UUID
05 16 6E 2A DB 02
——————————————————————————————————————————
AD length : 0x05 (5)
AD Type : 0x16 (22)
- 0x16 : Service Data 16-bit UUID
AD data :
- 0x6E2ADB02
- ServiceData의 값은 해당 서비스의 사양에 따라 정의된다. (사용자 설정 포맷)
- ServiceData UUID를 포함할 경우 [CBUUID: Data] 포맷으로 만들기도 한다.
——————————————————————————————————————————
Complete Local Name
0B 09 50 20 54 20 38 30 34 39 46 38
——————————————————————————————————————————
AD length : 0x0B (11)
AD Type : 0x09 (9)
- 0x09 : Complete Local Name
AD data :
- 0x50205420383034394638
- ASCII 문자열로 변환하면 "P T 8 0 4 9 F 8" 이다.