Skip to main content

Giới thiệu công cụ FLEX để debug mọi thông tin ngay trên simulator hoặc thiết bị iOS

Chào các bạn hôm nay mình xin giới thiệu đến các bạn 1 tool dùng để debug mọi thông tin như cấu trúc, vị trí, thuộc tính của những đối tượng trong 1 màn hình, có thể xem system logs, network, caches, file browser... trực tiếp ngay trên simulator / thiết bị iOS, mà không cần dùng XCode. Khi bạn thiết lập tool này, bạn có thể biết được mọi hành vi mà người lập trình đang làm trên ứng dụng này mà không cần phải coi code.

Công cụ này có tên là FLEX ( là từ viết tắt của Flipboard Explorer). Công cụ này rất dễ cài đặt và sử dụng, bạn chỉ nên sử dụng tool này cho chế độ Debug thôi. Mình sẽ giới thiệu sơ qua những chức năng chính của tool này như sau:

1. Có thể thay đổi vị trí của đối tượng:

Hình bên dưới đây minh họa cách công cụ này có thể tương tác những đối tượng trên màn hình như chọn và thay đổi vị trí của đối tượng trên màn hình. Bạn bạn chạy simulator thì nhấn phím "f" để mở thanh công cụ hoặc có thể tạo 1 button là "FLEX" để hiển thị thanh công cụ lên (code hiển thị sẽ đề cập bên dưới) và thao tác như sau:

2. Xem thuộc tính và những biến ivar của đối tượng:

Bạn vào màn hình chính của FLEX, và chọn chức năng như UICatalog Classes, AppDelegate, UINavigationController, [UIApplication keyWindow]:

3. Thay đổi thuộc tính và biến ivar của đối tượng:

Ví dụ mình có thể thay đổi nội dung font, color của label.

4. Quản lý lịch sử khi sử dụng network:

Bạn dùng chức năng này để xem ứng dụng này đã tải về những file nào và dùng bao nhiêu dung lượng rồi.

5. Xem nội dung đã được in ra bằng NSLog:

6. Xem được những files trong thư mục của ứng dụng:

7. Xem dữ liệu caches:

8. Xem những đối tượng trong bộ nhớ Heap:

9. Xem những giá trị trong NSUserDefault:

10. Xem những thư viện trong system:


Ngoài ra còn nhiều chức năng khác nữa các bạn có thể sử dụng và khám phá thêm.

Cách cài đặt thư viện:

Bạn cài đặt FLEX chỉ thiết lập cho chế độ Debug và thông qua cocoapods như sau:
pod 'FLEX', '~> 2.0', :configurations => ['Debug']
FLEX bắt buộc iOS từ 7.0 trở lên.

Sau khi cài thư viện thành công, bạn vào phần build settings của project và nhấn nút "Add User-Defined Setting" để thêm đoạn config:
bạn thêm key "EXCLUDED_SOURCE_FILE_NAMES" với giá trị ở chế độ Release như "FLEX*":
Các bước thiết lập trên để khi build bản Release nó sẽ bỏ qua những file trong framework FLEX.

Cách sử dụng thư viện FLEX:

Nếu bạn muốn mở tool này trên device thì bắt buộc phải thiết lập 1 button để mở tool FLEX lên như những ví dụ ở trên thì để ở màn hình Home, nếu ứng dụng của bạn có màn hình setting thì có thể để trong đó cũng được.
Code gọi tool FLEX lên khá đơn giản như sau:
[[FLEXManager sharedManager] showExplorer];

Và khi viết code bạn nên để nó trong Macro của Debug như sau:
#if DEBUG
#import "FLEXManager.h"
#endif

...

- (void)handleSixFingerQuadrupleTap:(UITapGestureRecognizer *)tapRecognizer
{
#if DEBUG
if (tapRecognizer.state == UIGestureRecognizerStateRecognized) {
// This could also live in a handler for a keyboard shortcut, debug menu item, etc.
[[FLEXManager sharedManager] showExplorer];
}
#endif
}
Nếu ứng dụng của bạn viết bằng ngôn ngữ Swift thì phải vào màn hình build setting và tìm từ khóa "Swift Compiler", thêm giá trị "-D DEBUG" vào phần Debug như sau:
Nguồn tham khảo tại đây.

Nếu bạn chạy trên Simulator thì có những phím tắt để bạn có thể mở thanh công cụ lên một cách nhanh chóng như:
- Nhấn phím "?" để mở màn hình hướng dẫn các phím tắt.
- Nhấn phím "f" để mở/tắt thanh công cụ.
- Nhấn phím "g" để mở màn hình globals.
- Nhấn phím "m" để thực hiện hành động di chuyển đối tượng.
- Nhấn phím "n" để vào màn hình xem lịch sử network.
.... Các bạn có thể xem thêm tại màn hình shortcuts.
Bạn có thể tải ví dụ demo tại đây.

Comments

Popular posts from this blog

Phân biệt biến kiểu Property, Public, Protected, Private trong ngôn ngữ Objective C

- Theo kinh nghiệm làm việc của mình với các bạn trong nhóm khi lập trình Objective-C và cũng đọc qua code của những project cũ. Ít khi nào mọi người để ý và khai báo đúng với ý đồ của từng đối tượng, và vi phạm quy tắc tính đóng gói, tính bảo mật thông tin của đối tượng trong lập trình hướng đối tượng (Tham khảo lý thuyết Lập trình hướng đối tượng tại trang Wiki ). - Theo ngôn ngữ lập trình Java, người ta khuyến khích mỗi khi dùng biến kiểu public thì nên đặt 1 biến private và hỗ trợ những hàm getter/setter để truy suất biến private đó.     + Nguyên nhân họ nói là đảm bảo tính đóng gói, và nếu sau này có thay đổi gì trên biến đó bạn có thể sửa được dễ dàng, chi tiết về vấn đề này ở đây .     + Nói tóm tại thì nguyên nhân chính là có thể kiểm soát được truy xuất đến giá trị của 1 đối tượng từ bên ngoài, có thể dễ dàng mở rộng code bằng cách override lại những hàm getter/setter. - Các bạn có thể áp dụng nguyên tắc đó từ bên Java qua ngôn ngữ lập trình Object...

(Kinh nghiệm) Auto layout và Size classes trong iOS - Phần 1

Trước đây khi viết những ứng dụng chạy trên nhiều màn hình hoặc hỗ trợ màn hình xoay ngang, xoay dọc mọi người hay dùng code để có thể chỉnh được những vị trí cũng như kích thước của những đối tượng. Hoặc có thể dùng Autosizing để tự động canh chỉnh những đối tượng nhưng không tối ưu và tiện lợi cho lắm, hình minh hoạ ở dưới: Vì thế từ lúc Apple phát hành ra iPhone 5, iPhone 5s với kích thước màn hình là 4 inch, làm phát sinh thêm vấn đề " Làm thế nào ta có thể thiết kế giao diện có thể chạy được trên nhiều màn hình? " mà không làm thay đổi nhiều code để có thể dễ dàng bảo trì ứng dụng. Apple mới phát triển chức năng Auto Layout và Size Classes để thực hiện nhiệm vụ này. Nếu bạn đã quen dùng Autosizing để thiết kế giao diện thì bạn có thể vẫn sử dụng chúng. Nhưng tuỳ theo từng dự án mà khách hàng hay người PM hoặc leader của bạn muốn bạn dùng công nghệ mới Auto Layout và Size Classes   để làm layout trên iOS mà không cần dùng bất cứ đoạn code nào và chỉ viết trên 1 storyboard...

(Căn bản) Bài 1: Hướng dẫn tạo tài khoản Apple ID và iTune không cần thẻ Visa hoặc MasterCard

Nếu bạn muốn lập trình trên iOs hoặc trên MacOs thì bạn nên có tài khoản Apple ID và tài khoản iTune. Sẽ hữa ích cho bạn khi cài đặt và nân cấp chương trình XCode. Nhưng khó khăn ở chỗ nếu bạn không có thẻ Visa hoặc Master Card, mà vẫn muốn có tài khoản để có thể cài ứng dụng trên AppStore. Sau đây mình xin hướng dẫn cách tạo tài khoản mà không cần những thẻ đó và có thể tạo tài khoản trên những store ở các nước khác. Đầu tiên bạn mở chương trình iTune lên và vào tab "App Store", sau đó bạn kiếm chương trình nào Free và nhấn vào đó nó sẽ hiển thị ra màn hình như sau:    Khi đang ở màn hình này bạn nhấn vào chữ "Free" bên dưới hình sẽ hiển thị ô cho bạn nhập Apple ID và Password.Vì bạn chưa có nên hãy nhấn vào nút "Create Apple ID" để tạo tài khoản. Sau khi bạn nhấn vào nút "Create Apple ID" bạn sẽ qua màn hình như bên dưới. Tại đây bạn có thể chuyển AppStore của các nước (Vì có những chương trình chỉ cài được trên từng AppStore mỗi nước thôi) hi...