Metadata-Version: 2.4
Name: oiadb
Version: 0.6.2
Summary: ADB Python wrapper library with enhanced functionality, image recognition and multiplatform support
Home-page: https://github.com/tiendung102k3/oiadb
Author: Tien Dung
Author-email: example@example.com
Project-URL: Bug Reports, https://github.com/tiendung102k3/oiadb/issues
Project-URL: Source, https://github.com/tiendung102k3/oiadb
Keywords: adb,android,debug,bridge,automation,testing,image recognition,opencv,uiautomator,multiplatform,windows,linux,macos,termux
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Software Development :: Testing
Classifier: Topic :: Software Development :: Libraries
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: POSIX :: Linux
Classifier: Operating System :: MacOS :: MacOS X
Requires-Python: >=3.6
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: requests>=2.20
Provides-Extra: image
Requires-Dist: opencv-python>=4.5.0; extra == "image"
Requires-Dist: numpy>=1.19.0; extra == "image"
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: keywords
Dynamic: license-file
Dynamic: project-url
Dynamic: provides-extra
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

# OI ADB

Thư viện Python wrapper cho Android Debug Bridge (ADB) với chức năng nhận diện hình ảnh sử dụng OpenCV, tính năng dump XML với hỗ trợ trợ năng, và hỗ trợ đa nền tảng (Windows, Linux, macOS, Termux).

## Giới thiệu

OI ADB là một thư viện Python giúp tương tác với thiết bị Android thông qua ADB (Android Debug Bridge). Thư viện này được thiết kế để đơn giản hóa việc sử dụng các lệnh ADB trong các ứng dụng Python, tự động hóa kiểm thử, và quản lý thiết bị Android. 

Phiên bản mới nhất bổ sung:
- **Hỗ trợ đa nền tảng**: Hoạt động mượt mà trên Windows, Linux, macOS và Termux
- **Tự động phát hiện và cài đặt ADB**: Không cần cài đặt ADB thủ công
- **Chức năng nhận diện hình ảnh** mạnh mẽ sử dụng OpenCV, cho phép tìm kiếm và tương tác với các phần tử trên màn hình dựa trên hình ảnh mẫu thay vì tọa độ cố định
- **Tính năng dump XML** với local server, cho phép truy xuất và phân tích cấu trúc UI nhanh chóng
- **Hỗ trợ trợ năng (accessibility)** để tương tác với ứng dụng Android một cách hiệu quả hơn

## Cấu trúc thư viện

Dưới đây là sơ đồ cấu trúc của thư viện OIADB:

![Cấu trúc thư viện OIADB](docs/images/package_structure.png)

Thư viện được tổ chức thành các module chính:
- **MyADB**: Lớp chính để tương tác với ADB
- **commands**: Chứa các lệnh chuyên biệt như tương tác, quản lý ứng dụng, thao tác file
- **utils**: Các tiện ích và công cụ hỗ trợ, bao gồm hỗ trợ đa nền tảng
- **exceptions**: Định nghĩa các ngoại lệ đặc biệt của thư viện

## Quy trình nhận diện hình ảnh

Một trong những tính năng nổi bật của OIADB là khả năng nhận diện và tương tác với các phần tử trên màn hình dựa trên hình ảnh. Dưới đây là quy trình hoạt động của tính năng này:

![Quy trình nhận diện hình ảnh](docs/images/image_recognition_workflow.png)

Quy trình bao gồm các bước:
1. **Input Image**: Hình ảnh mẫu cần tìm kiếm
2. **Screen Capture**: Chụp màn hình thiết bị hiện tại
3. **Image Processing**: Tiền xử lý hình ảnh (chuyển đổi grayscale, thay đổi kích thước, chuẩn hóa)
4. **Template Matching**: Sử dụng thuật toán so khớp mẫu của OpenCV
5. **Match Detection**: Xác định tọa độ của các vị trí khớp tốt nhất
6. **Device Interaction**: Thực hiện các thao tác như nhấn, vuốt tại vị trí đã xác định

## Tính năng XML Dump và Trợ Năng

Tính năng mới nhất của OIADB là khả năng dump XML của giao diện người dùng Android và tương tác thông qua API trợ năng. Dưới đây là kiến trúc của tính năng này:

![Kiến trúc XML Dump](docs/images/xml_dump_architecture.png)

Kiến trúc bao gồm:
- **Local Server**: HTTP server chạy trên thiết bị Android
- **XML Parser**: Bộ phân tích XML với khả năng lọc nhanh
- **Parameter Handler**: Xử lý các tham số truy vấn
- **API Endpoints**: Các điểm cuối API (/get_xml, /find_elements, /accessibility_actions)
- **Accessibility API**: Tích hợp với API trợ năng của Android

Quy trình xử lý của tính năng XML Dump:

![Quy trình XML Dump](docs/images/xml_dump_workflow.png)

Quy trình bao gồm ba luồng chính:
1. **XML Dump Flow**: Truy xuất và lọc cấu trúc XML
2. **Find Elements Flow**: Tìm kiếm các phần tử UI dựa trên tiêu chí
3. **Accessibility Flow**: Thực hiện các hành động trợ năng

## Hỗ trợ đa nền tảng

OIADB hiện hỗ trợ đầy đủ các nền tảng sau:

- **Windows**: Hỗ trợ đầy đủ, bao gồm tự động cài đặt ADB
- **Linux**: Hỗ trợ đầy đủ, bao gồm tự động cài đặt ADB
- **macOS**: Hỗ trợ đầy đủ, bao gồm tự động cài đặt ADB
- **Termux (Android)**: Hỗ trợ đặc biệt, tự động cài đặt ADB thông qua package manager

Thư viện tự động phát hiện nền tảng và điều chỉnh hành vi phù hợp, đảm bảo trải nghiệm nhất quán trên tất cả các hệ điều hành.

## Yêu cầu

- Python 3.6 trở lên
- **Không cần cài đặt ADB thủ công**: Thư viện sẽ tự động tải xuống và cài đặt ADB nếu cần
- **Lưu ý:** Thư viện sẽ tự động cài đặt và quản lý `oiadb-server.apk` trên thiết bị Android của bạn.
- **Tùy chọn (cho nhận dạng ảnh):** OpenCV và NumPy (cần cài đặt riêng, xem phần Cài đặt).

## Cài đặt

### Cài đặt cơ bản

```bash
pip install oiadb
```

Hoặc cài đặt từ mã nguồn:

```bash
git clone https://github.com/tiendung102k3/oiadb
cd oiadb
pip install -e .
```

### Cài đặt với hỗ trợ nhận diện hình ảnh

```bash
pip install oiadb[image]
```

### Cài đặt trên Termux

```bash
pkg install python
pip install oiadb
```

## Cách sử dụng

### Khởi tạo

```python
from oiadb import MyADB

# Khởi tạo với thiết bị mặc định
adb = MyADB()

# Hoặc chỉ định thiết bị cụ thể
adb = MyADB(device_id="emulator-5554")

# Tắt tự động cài đặt ADB (nếu bạn đã cài đặt ADB)
adb = MyADB(auto_install_adb=False)
```

### Các thao tác cơ bản

```python
# Liệt kê các thiết bị đã kết nối
devices = adb.get_devices()
print(devices)

# Cài đặt ứng dụng
adb.install_app("/path/to/app.apk")

# Gỡ cài đặt ứng dụng
adb.uninstall_app("com.example.app")

# Khởi động lại thiết bị
adb.reboot_device()
```

### Tương tác với thiết bị

```python
from oiadb.commands import interaction

# Nhấn vào tọa độ màn hình
interaction.tap(500, 500)

# Vuốt màn hình
interaction.swipe(100, 500, 600, 500)

# Nhập văn bản
interaction.text_input("Hello World")

# Nhấn phím Home
interaction.home()
```

### Tương tác dựa trên nhận diện hình ảnh

```python
from oiadb.commands import image_interaction

# Tìm và nhấp vào hình ảnh
image_interaction.tap_image("/path/to/button.png", threshold=0.8)

# Đợi hình ảnh xuất hiện và nhấp vào
image_interaction.wait_and_tap_image("/path/to/button.png", timeout=10)

# Kiểm tra xem hình ảnh có xuất hiện không
if image_interaction.is_image_present("/path/to/element.png"):
    print("Hình ảnh xuất hiện trên màn hình")

# Kéo từ hình ảnh này đến hình ảnh khác
image_interaction.drag_image_to_image("/path/to/source.png", "/path/to/target.png")
```

### Sử dụng XML Dump và Trợ Năng

```python
from oiadb.commands import xml_dump

# Khởi động server XML dump
server, server_thread = xml_dump.start_xml_server(port=8000)

# Lấy XML dump của giao diện hiện tại
xml_content = xml_dump.get_xml_dump()

# Tìm phần tử với nhiều tiêu chí
buttons = xml_dump.find_elements_by_criteria({
    "class": "android.widget.Button",
    "value": "Login",
    "threshold": 0.7
})

# Thực hiện hành động trợ năng
xml_dump.perform_accessibility_action(
    "click", 
    {"id": "button_login"}
)

# Dừng server khi hoàn tất
xml_dump.stop_xml_server(server)
```

### Quản lý file

```python
from oiadb.commands import file_ops

# Đẩy file từ máy tính lên thiết bị
file_ops.push("/path/on/computer", "/path/on/device")

# Lấy file từ thiết bị về máy tính
file_ops.pull("/path/on/device", "/path/on/computer")
```

### Xem log

```python
from oiadb.commands import logs

# Xem logcat
logcat_output = logs.logcat()
print(logcat_output)

# Tạo báo cáo lỗi
bugreport = logs.bugreport()
```

## Hướng dẫn đa nền tảng

### Windows

1. **Cài đặt Python**: Tải và cài đặt Python từ [python.org](https://www.python.org/downloads/windows/)
2. **Cài đặt OIADB**:
   ```
   pip install oiadb[image]
   ```
3. **Sử dụng**:
   ```python
   from oiadb import MyADB
   adb = MyADB()  # Tự động tải và cài đặt ADB nếu cần
   ```

### Linux

1. **Cài đặt Python và các gói phụ thuộc**:
   ```
   sudo apt-get update
   sudo apt-get install python3 python3-pip python3-dev
   ```
2. **Cài đặt OIADB**:
   ```
   pip3 install oiadb[image]
   ```
3. **Sử dụng**:
   ```python
   from oiadb import MyADB
   adb = MyADB()  # Tự động tải và cài đặt ADB nếu cần
   ```

### macOS

1. **Cài đặt Python**: Sử dụng Homebrew hoặc tải từ [python.org](https://www.python.org/downloads/macos/)
   ```
   brew install python
   ```
2. **Cài đặt OIADB**:
   ```
   pip3 install oiadb[image]
   ```
3. **Sử dụng**:
   ```python
   from oiadb import MyADB
   adb = MyADB()  # Tự động tải và cài đặt ADB nếu cần
   ```

### Termux (Android)

1. **Cài đặt Termux**: Tải từ [F-Droid](https://f-droid.org/packages/com.termux/)
2. **Cài đặt Python và các gói phụ thuộc**:
   ```
   pkg update
   pkg install python clang python-dev
   ```
3. **Cài đặt OIADB**:
   ```
   pip install oiadb
   ```
4. **Sử dụng**:
   ```python
   from oiadb import MyADB
   adb = MyADB()  # Tự động cài đặt ADB thông qua package manager
   ```

## Xử lý sự cố đa nền tảng

### Vấn đề chung

- **ADB không tự động cài đặt**: Đảm bảo bạn có quyền ghi vào thư mục cài đặt. Trên Linux/macOS, có thể cần chạy với sudo.
- **Lỗi kết nối thiết bị**: Đảm bảo USB debugging đã được bật trên thiết bị Android và thiết bị đã được cấp quyền.

### Windows

- **Lỗi đường dẫn**: Nếu gặp lỗi về đường dẫn, hãy sử dụng dấu gạch chéo ngược kép (`\\`) hoặc dấu gạch chéo thuận (`/`).
- **ADB không hoạt động**: Kiểm tra xem Windows Defender hoặc phần mềm antivirus có chặn ADB không.

### Linux

- **Quyền USB**: Nếu không thể kết nối thiết bị, thêm quy tắc udev:
  ```
  sudo nano /etc/udev/rules.d/51-android.rules
  # Thêm: SUBSYSTEM=="usb", ATTR{idVendor}=="XXXX", MODE="0666"
  sudo udevadm control --reload-rules
  ```

### Termux

- **Quyền truy cập**: Đảm bảo Termux có quyền truy cập bộ nhớ: `termux-setup-storage`
- **ADB không hoạt động**: Trên Termux, ADB có thể cần quyền root để thực hiện một số thao tác.

## Tài liệu API

### Lớp MyADB

Lớp chính để tương tác với ADB.

- `__init__(device_id=None, cache_enabled=True, timeout=30, adb_path=None, auto_start_server=True, auto_install_adb=True)`: Khởi tạo đối tượng ADB với các tùy chọn
- `run(command)`: Chạy lệnh ADB tùy chỉnh
- `get_devices()`: Liệt kê các thiết bị đã kết nối
- `reboot_device()`: Khởi động lại thiết bị
- `install_app(apk_path)`: Cài đặt ứng dụng từ file APK
- `uninstall_app(package_name)`: Gỡ cài đặt ứng dụng
- `push_file(local_path, remote_path)`: Đẩy file lên thiết bị
- `pull_file(remote_path, local_path)`: Lấy file từ thiết bị
- `get_device_info()`: Lấy thông tin thiết bị

### Module commands

Các module lệnh chuyên biệt:

- `app_info`: Lấy thông tin ứng dụng
- `apps`: Quản lý ứng dụng
- `basic`: Các lệnh ADB cơ bản
- `connect`: Kết nối thiết bị qua mạng
- `device_actions`: Các hành động thiết bị
- `device_info`: Thông tin thiết bị
- `file_ops`: Thao tác file
- `interaction`: Tương tác với thiết bị
- `image_interaction`: Tương tác dựa trên nhận diện hình ảnh
- `xml_dump`: Dump XML và tương tác qua trợ năng
- `logs`: Xem log thiết bị
- `permissions`: Quản lý quyền

### Module utils

Các tiện ích hỗ trợ:

- `platform_utils`: Hỗ trợ đa nền tảng
- `adb_manager`: Quản lý cài đặt và cấu hình ADB
- `advanced`: Các tiện ích nâng cao
- `image_recognition`: Nhận diện hình ảnh

### Tài liệu bổ sung
Đọc tài liệu [tại đây](https://github.com/tiendung102k3/oiadb/tree/main/docs)
Để biết thêm chi tiết về chức năng nhận diện hình ảnh, vui lòng xem [image_recognition_documentation.md](https://github.com/tiendung102k3/oiadb/blob/main/image_recognition_documentation.md).
Để biết thêm chi tiết về tính năng XML dump và trợ năng, vui lòng xem [xml_dump_documentation.md](https://github.com/tiendung102k3/oiadb/blob/main/xml_dump_documentation.md).

## Đóng góp

Đóng góp luôn được chào đón! Vui lòng tạo issue hoặc pull request trên GitHub.

## Giấy phép

MIT License

## Liên hệ hợp tác

Email: monstertattoovn696@gmail.com
