- vừa được xem lúc

Hành trình làm app Flutter từ con số 0 (phần 2)

0 0 14

Người đăng: Nguyễn Tiến Triển

Theo Viblo Asia

Lưu ý: Bài viết chỉ nhằm chia sẻ quá trình tự học Flutter, vì vậy sẽ có rất nhiều thứ ngốk nghếk, sai sót mong anh chị em bỏ qua và chỉ giáo!!!

1. Xác định ý tưởng, mục tiêu.

Giai đoạn khởi đầu của 1 dự án, mình nghĩ xác định được mục tiêu và hướng phát triển của sản phẩm sẽ làm là quan trọng nhất. Điều mà mình sợ nhất khi làm 1 dự án có lẽ là gặp khách hàng không hiểu rõ, và không biết họ muốn gì. Những yêu cầu rất mơ hồ như: "anh muốn 1 ứng dụng đặt đồ ăn", nhưng khi hỏi về những chức năng muốn làm, bố trí và luồng chức năng thì khách hàng lại không biết rõ. Điều đó dẫn tới việc khó thống nhất, sửa đổi nhiều lần, tốn thời gian phát triển. Ở ứng dụng tự học này mình đã đưa ra 1 flow "nhẹ nhàng và an toàn" để dễ dàng tiếp cận:

Màn hình và Chức năng:

Trang chủ

  • Hiển thị những bộ truyện thường xuyên truy cập.
  • Hiển thị những tập truyện mới nhất.
  • Hiển thị những tập truyện đang đọc.
  • Yêu thích, bỏ yêu thích

Thư viện

  • Hiển thị các cuốn sách, bộ sách.
  • Tìm kiếm các cuốn sách.
  • Yêu thích, bỏ yêu thích.

Màn yêu thích

  • Hiện thị các cuốn truyện, bộ truyện đã yêu thích
  • Bỏ yêu thích

Màn Chi tiết bộ sách

  • Hiển thị thông tin giới thiệu bộ sách và các cuốn sách trong bộ sách
  • Yêu thích, bỏ yêu thích

Màn đọc sách

  • loading khi download sách về.
  • Hiển thị sách.
  • Bookmark để lưu trang đang đọc.
  • Di chuyển đến trang mình muốn.

Thiết kế Database

Do ứng dụng offine nên nó đã đơn giản hơn rất nhiều, mình chỉ làm 2 bảng (SeriesBook là bộ sách, và book là lưu những cuốn sách) liên hết với nhau bằng khoá ngoại seriesBookId. 1.png

Cấu trúc Project

Thật ra, mình cũng không biết tổ chức 1 project như thế nào cho hợp lý vì còn chưa biết hết các chức năng trong Flutter. Mà không biết thì mình hỏi Chat GPT và nhận được 1 đề xuất basic như sau: 2.png

  • common để lưu những biến constant dùng chung cho cả app.
  • models mình lưu ModalData và BLoC (cái này liên quan đến phần gọi dữ liệu từ sqfline.)
  • mook_data để mình làm mấy cái dữ liệu.
  • screen là nơi viết các màn hình.
  • services dùng khi call API mà mình đang không dùng.
  • widget mình dùng viết mấy cái widget tái sử dụng được.

Thiết kế giao diện

Các bạn có thể tham khảo giao diện ở Link. Mình tìm mấy thứ đơn giản rồi chắp ghép nó vào app của mình :v

Simulator Screenshot - iPhone 14 Pro Max - 2023-10-11 at 11.21.22.png

Simulator Screenshot - iPhone 14 Pro Max - 2023-10-11 at 11.21.32.png

Simulator Screenshot - iPhone 14 Pro Max - 2023-10-11 at 11.20.39.png

Simulator Screenshot - iPhone 14 Pro Max - 2023-10-11 at 11.21.22.png

2. Từ 0 đến 1

Sau khi đã có đủ các vật liệu, mình bắt đầu code thứ đầu tiên:

###Phần chia độ lớn làm hình Cái này là thói quen khi làm react-native, để đảm bảo giao diện hiển thị tốt ở những màn hình khác nhau mình chia màn hình thành các phần nhỏ, khi sử dụng nó giống như các bạn dùng % màn hình vậy. 3.png

Trong file common > constants mình chia màn hình theo chiều dọc và ngang như các bạn đã thấy. Khi sử dụng nó sẽ kiểu Padding(padding:EdgeInsets.symmetric(horizontal: appConstants.minWidth * 10))

bottom_navigation

Bắt đầu làm phần này mình thấy luôn sự tiện lợi Flutter đem lại.

Mình bắt đầu với thứ cơ bản nhất đã được hướng dẫn trong document Link Không cần cấu trúc quá phức tạp( có thể với dự án to hơn sẽ cần! ) như stack.... bạn dễ dàng đọc hiểu và thực hiện được những gì đã hướng dẫn. Ok! Xong cơ bản và để màu mè hơn....

Đầu tiên, mình tạo file bottom_navigation, file này sẽ chưa bottom bar của bạn. Về cơ bản nó là sự nâng cấp của basic đã được viết trong document. 4.png

Các bạn có nghĩ là mình sẽ giải thích từng đoạn code trong file không ? Tất nhiên là không :v. Bởi mình nghĩ điều đó không cần thiết. Nếu thời gian đó các bạn bắt tay vào làm thì có lẽ sẽ hiệu quả hơn. Và vì có 1 thứ có thể giải thích code tường tận hơn mình 😃) image.png

Vâng! mình copy code và vứt vào chatGPT rồi bảo nó giải thích code cho mình (vì code này mình cũng nhờ nó viết hộ rồi chỉnh lại đó các bạn!!!).Cùng với đó mình lựa 1 cái thư viện trong 1 tá thư viện của Flutter rồi chỉnh sửa lại code trên nền basic ban đầu. Nếu không hiểu đoạn nào thì bạn cứ hỏi lại nó như bạn hỏi TechLead của bạn vậy: image.png Lưu ý: hãy dùng chatGPT để tham khảo các viết code và những điều không hiểu, hoặc dùng gen code nhưng đảm bảo là hiểu rõ code viết gì nhé các bạn! Với dự án thực tế nên tránh việc đưa code vào chatGPT vì có thể vi phạm bảo mật.

Đây là thứ mình đạt được Link. Các bạn có thể tham khảo rất nhiều mẫu ở các thư viện sau: Link. Để làm được 1 cái navigation như trong hình, nếu ở bên react-native mình chắc sẽ phải khá nhiều thời gian. Nhưng với Flutter, việc mình cần làm là chọn xem cái nào đẹp và gắn vào. Có rất nhiều thư viện bottom navigation để bạn lựa chọn: Đẹp, mượt, và dễ sử dụng. Ngoài ra, sụ đồng bộ trên cả android và iOS cũng khiến mình thấy thích thú( vì không phải fix bug thư viện nhiều như React-Native).

Hãy bắt đầu mọi thứ theo cách đơn giản nhất có thể. Và mài dũa nó thành thứ hoàn hảo!

Hết phần 2: mình sẽ chia sẻ quá trình code các màn hình, những khó khăn gặp phải vào những bài sau, cảm ơn mọi người đã đọc đến đây!!!

Bình luận

Bài viết tương tự

- vừa được xem lúc

Học Flutter từ cơ bản đến nâng cao. Phần 1: Làm quen cô nàng Flutter

Lời mở đầu. Gần đây, Flutter nổi lên và được Google PR như một xu thế của lập trình di động vậy.

0 0 281

- vừa được xem lúc

Học Flutter từ cơ bản đến nâng cao. Phần 3: Lột trần cô nàng Flutter, BuildContext là gì?

Lời mở đầu. Màn làm quen cô nàng FLutter ở Phần 1 đã gieo rắc vào đầu chúng ta quá nhiều điều bí ẩn về nàng Flutter.

0 0 213

- vừa được xem lúc

Flutter Animation: Creating medium’s clap animation in flutte Part II

Trong phần 1 mình đã giới thiệu với các bạn cơ bản về Animation trong Flutter. Score Widget Size Animation.

0 0 64

- vừa được xem lúc

Flutter - GetX - Using GetConnect to handle API request (Part 4)

Giới thiệu. Xin chào các bạn, lại là mình với series về GetX và Flutter.

0 0 359

- vừa được xem lúc

StatefulWidget và StatelessWidget trong Flutter

I. Mở đầu. Khi các bạn build một ứng dụng với Flutter thì Widgets là thứ không thể thiếu đúng không ạ. Và 2 loại Widget không thể thiếu đó là StatefullWidget và StatelessWidget.

0 0 145

- vừa được xem lúc

Tìm hiểu về Riverpod - Provider nhưng không hắn :v

Trong Flutter có rất nhiều các quản lý state: Provider, Bloc, GetX, Redux,... khó mà nói cái nào tốt hơn cái nào. Tuy nhiên nếu bạn đã làm quen với Provider thì không ngại để tìm hiểu thêm về Riverpod. Một bản nâng cấp của Provider. Nếu bạn để ý thì cái tên "Riverpod" là các chữ cái của "Provider" đ

0 0 67