0:00:01.434,0:00:07.073 Sau khi tìm hiểu về những khái niệm cơ bản của vòng lặp, ta cùng tiếp tục học cách tạo một bức vẽ lặp sao cho được đẹp như bức này, 0:00:07.073,0:00:09.849 Balloon Hopper đang bay trên bầu trời xanh. 0:00:09.849,0:00:16.401 Trong khi viết chương trình từ đầu, tôi muốn các bạn suy ngẫm xem mình sẽ tự thực hiện bằng cách nào, vì các bạn sẽ phải tự thân vận động sớm thôi. 0:00:16.401,0:00:20.207 Trước hết, ta nên chia chương trình thành nhiều bước. 0:00:20.207,0:00:27.485 Ta sẽ bắt đầu bằng cách vẽ những quả bóng này, tất cả đều là một hình e-lip lặp đi lặp lại, nghe giống như một vòng lặp nhỉ. 0:00:27.485,0:00:33.774 Sau đó ta sẽ vẽ những đường thẳng này, và cuối cùng ta thêm Balloon Hopper. 0:00:33.774,0:00:37.963 Được rồi, ta đang có một slate trống. Có vẻ khá đáng sợ đấy. 0:00:37.963,0:00:43.869 Đôi khi, thêm nền vào cũng giúp mọi thứ trở nên thân thiện hơn một chút đấy, để làm quen tốt hơn thôi mà. 0:00:43.869,0:00:49.933 Bây giờ, vì ta đang muốn vẽ một vòng lặp, suy nghĩ đầu tiên của ta phải là những câu hỏi vòng lặp mà ta đã đề cập từ bài trước. 0:00:49.933,0:00:56.933 Lần này chúng ta sẽ làm nhanh thôi, vì vậy nếu các bạn cần xem lại, hãy quay trở lại bài “Intro to While Loops”. 0:00:56.933,0:01:01.393 Câu hỏi đầu tiên là: “Ta muốn lặp cái gì?” 0:01:01.393,0:01:06.441 Ta cùng thử vẽ quả bóng đầu tiên nhé. Vì ta muốn lặp lại những quả bóng đó mà. 0:01:06.441,0:01:15.066 Các bạn có thể vẽ như này, có thể như này nữa, và, các bạn biết đấy, chắc là hơi nhỏ, hơi lệch một chút nhỉ. 0:01:15.066,0:01:17.169 ta di chuyển một chút nhé. 0:01:17.169,0:01:25.183 Đây mới chỉ là một phần của lập trình thôi, trong đó ta thử, rồi nhận ra đó không phải cái ta muốn, rồi ta thử lại và dần dần sẽ được như ý. 0:01:25.183,0:01:33.870 Được rồi, bây giờ chắc ta phải tô màu nhỉ? Khi cân nhắc các bước ta đã không tính đến điều này, nên ta có thể coi đó là một phần của bước vẽ bóng của được. 0:01:33.870,0:01:40.898 Được chứ? Tiếp theo, ta phải nghĩ mình muốn thay đổi quả bóng này chính xác đến đâu trong vòng lặp. 0:01:40.898,0:01:47.733 Chúng ta cần vẽ quả bóng ngang màn hình phải không nào? Ta cần vẽ ở đây, ở đây, và ở đây, 0:01:47.733,0:01:51.013 vậy nên ta sẽ lệnh cho máy tính thực hiện, vì tôi vẽ dở tệ. 0:01:51.013,0:01:58.391 Ta có thể làm việc đso bằng cách thay đổi chữ số đầu tiên, như các bạn đã biết đso là vị trí x: vị trí nghiêng. 0:01:58.391,0:02:02.767 Nhưng, ý tôi là, nhìn nhạt nhẽo quá phải không? Trông chẳng đẹp như bức tranh lúc đầu gì hết. 0:02:02.767,0:02:11.108 Vì vậy, thay vào đó, giả sử ta gọi đây là x, cho vị trí x, và ta sẽ tạo một biến như bài học trước. 0:02:11.108,0:02:15.912 Và bây giờ, ta sẽ thay đổi biến đó trong vòng lặp, vì vậy ta sẽ sử dụng vòng lặp while, 0:02:15.912,0:02:22.136 rồi trong vòng lặp đó ta đặt x thay đổi cho mỗi lần lặp, giả sử theo 20 đơn vị. 0:02:22.136,0:02:27.398 Nếu ta chỉ đưa hình e-lip đó vào trong vòng lặp, hãy thật cẩn thận để không đưa cả hàm khai biến vào trong, 0:02:27.398,0:02:30.209 vì sau đó ta sẽ chỉ nghĩ đến vấn đề có thể nằm ở đâu. 0:02:30.209,0:02:34.375 Thực ra nếu các bạn thấy tò mò, thì cũng đáng để tự mày mò đấy. 0:02:34.375,0:02:39.392 Được rồi, như vậy câu hỏi lặp thứ ba của chúng ta là: “Ta muốn lặp trong bao lâu?” 0:02:39.392,0:02:43.818 Ta có thể nghĩ rằng sẽ chỉ lặp cho tới khi nào kín màn hình mới thôi. 0:02:43.818,0:02:46.647 Như vậy chắc hẳn cho tới khi x nhỏ hơn 400. 0:02:46.647,0:02:51.163 Cũng hay đấy vì chúng ta đang có gì đó trên tranh rồi đúng không? Nhưng không giống những gì ta đã tưởng tượng cho lắm. 0:02:51.163,0:02:55.839 Vì vậy chúng ta sẽ rà lại một lượt, và dần dần cải thiện để đạt được như những gì ta đã tưởng tượng, giống như trước đây vậy. 0:02:55.839,0:02:59.400 Trước hết, các e-lip đang bị dính hết vào nhau rồi. Ta xử lý trước nhé. 0:02:59.400,0:03:02.409 Được rồi, vậy là dễ thở hơn một chút rồi. 0:03:02.409,0:03:09.317 Nhưng các bạn biết đấy, có thể chúng vẫn cách hơi xa cạnh màn hình, vậy nên nếu ta thay đổi điểm cuối, ta có thể bắt đầu làm biến mất 0:03:09.317,0:03:16.507 những hình e-lip xuất hiện ở đây, vì ta đã đặt khi x tới vị trí này thì sẽ ngừng vẽ. 0:03:16.507,0:03:19.385 Và đó cũng chính là nội dung của phần này trong vòng lặp while. 0:03:19.385,0:03:24.945 Được rồi chứ? Ta cũng có thể nói rằng “có thể ta muốn thay đổi các hình e-lip một chút”, ta muốn di chuyển toàn bộ lùi xuống dưới, 0:03:24.945,0:03:34.018 hay thay đổi lại kích thước một chút, và điều hay ho của vòng lặp while là ta có thể cùng lúc thực hiện tất cả. 0:03:34.018,0:03:36.896 Được rồi. Quá hoàn hảo. 0:03:36.896,0:03:42.024 Bây giờ ta hãy quan sát những quả bóng này, nếu thêm ít dây vào thì sẽ đẹp hơn đấy. Nếu muốn ta có thể thêm, 0:03:42.024,0:03:43.892 không thì chúng sẽ bay mất đấy. 0:03:43.892,0:03:50.573 Như vậy với mỗi quả bóng ta sẽ cần một đường thẳng. Hãy nghĩ rằng ta muốn đường thẳng đó xuất phát từ tâm của mỗi quả bóng, 0:03:50.573,0:03:55.912 để mọi thứ dễ dàng hơn thôi, và tất cả đều buông xuống cùng một điểm, như thế này. 0:03:55.912,0:03:59.430 Vậy làm cách nào ta có thể khiến chương trình thực hiện thao tác đó, thay vì phải vẽ tay? 0:03:59.430,0:04:05.000 Ta có thể nghĩ như sau, nếu muốn lặp thứ gì đó, chắc chắn ta phải đưa vào vòng lặp while, vì vậy chúng ta cũng tạo đường thẳng đó đã. 0:04:05.000,0:04:10.702 Nếu muốn đặt đường thẳng vào trung tâm hình e-lip, thì ta phải bắt đầu tại hai tọa độ này, làm thế cũng được. 0:04:10.702,0:04:16.618 Và ta có thể cho chúng kết thúc, các bạn biết đấy, ở đâu cũng được. Cũng khá sát đó chứ! 0:04:16.618,0:04:23.655 Nhưng, một lần nữa, nó vẫn chưa hoàn thiện – hẳn các bạn sẽ cảm nhận được chủ đề - vì vậy ta cần phải chỉnh sửa lại. Trước tiên hãy chỉnh lại cái thứ xấu xí này đã. 0:04:23.655,0:04:29.813 Những chiếc dây buộc bóng mà ta vừa vẽ đang chồng chéo lên bóng bay, không hợp lý một chút nào luôn. 0:04:29.813,0:04:35.249 Ta phải điều chỉnh sao cho hình e-lip có thể che được đường thẳng, ta có thể thực hiện điều đó bằng cách thay đổi thứ tự. 0:04:35.249,0:04:38.764 Hẳn các bạn sẽ nhận thấy những gì mình đã học đang dần hiện ra trước mắt. 0:04:38.764,0:04:45.315 Được rồi, như này là tốt rồi, nhưng có lẽ ta sẽ thay đổi cả màu của những đường thẳng đó nữa, vậy ta thực hiện như thế nào nếu thực sự phải tự viết chương trình này? 0:04:45.315,0:04:47.224 Ta có thể tham khảo tài liệu. 0:04:47.224,0:04:50.474 Hoặc ta có thể xem video tư liệu nếu không biết cách xem tài liệu. 0:04:50.474,0:04:54.924 Ta có thể sử dụng stroke () để tô màu cho những đường thẳng đó, 0:04:54.924,0:05:00.253 và có lẽ tô màu, tôi không biết nữa, màu này chăng? 0:05:00.253,0:05:10.152 Cũng đẹp đấy. Cuối cùng, tất cả những gì ta phải làm là vẽ Hopper. Và ta chỉ cần đưa vào dưới định dạng ảnh, như thế này, 0:05:10.152,0:05:16.536 các bạn có thể tham khảo tài liệu mà tôi đã sử dụng để thực hiện thao tác, chỉ cần di chuyển xung quanh thôi để cô ấy trông như đang giữ mấy quả bóng bay 0:05:16.536,0:05:18.229 và lơ lửng trên trời cao. 0:05:18.229,0:05:26.534 Và thế là xong! Chúng ta đã thành công! Các bạn có thể thử trang trí bóng bay, hay nghĩ đến việc thêm một số thứ vào vòng lặp này để khiến những quả bóng bay đó hay ho hơn, 0:05:26.534,0:00:00.000 thậm chí các bạn có thể sử dụng vòng lặp cho bức vẽ tiếp theo của mình.