Tô màu theo dòng quét (scan line)

Một phần của tài liệu Chương 1: Giới thiệu thuật toán vẽ và tô các đường cơ bản (Trang 38 - 42)

Phương pháp này sẽ xác định phần giao của các dòng quét kế tiếp nhau với

đường biên của vùng tô. Sau đó, sẽ tiến hành tô màu các điểm thuộc phần giao này. Phương pháp này thường được dùng để tô màu đa giác lồi , lõm hay đa giác tự

cắt, đường tròn, ellipse, và một sốđường cong đơn giản khác.

Các bước chính của thuật toán

- Tìm ymin, ymax lần lượt là giá trị nhỏ nhất, lớn nhất của tập các tung độ của các

đỉnh của đa giác đã cho.

- Ứng với mỗi dòng quét y = k với k thay đổi từ ymin đến ymax, lặp :

. Tìm tất cả các hoành độ giao điểm của dòng quét y = k với các cạnh của đa giác.

. Sắp xếp các hoành độ giao điểm theo thứ tự tăng dần : x0 ,x1 ,..., xn ,...

. Tô màu các đoạn thẳng trên đường thẳng y = k lần lượt được giới hạn bởi các cặp (x0, x1), ( x1 ,x2 ), ....(xem hình 2.6).

Hình 2.6 : Tô đa giác bằng giải thuật scan -line.

Các vấn đề cần lưu ý:

- Hạn chếđụơc số cạnh cần tìm giao điểm ứng với mỗi dòng quét vì ứng với mỗi dòng quét không phải lúc nào cũng giao điểm với các cạnh của đa giác.

- Xác định nhanh hoàn độ giao điểm vì nếu lặp lại thao tác tìm giao điểm của cạnh đa giác với mỗi dòng quét sẽ tốn rất nhiều thời gian.

- Giải quyết trường hợp số giao điểm đi qua đỉnh đơn điệu thì tính số giao điểm là 1 hay đi qua đỉnh cực trị.thì tính số giao điểm là 0 (hoặc 2).

Tổ chức cấu trúc dữ liệu và thuật toán

- Danh sách các cạnh (Edge Table - ET) : chứa toàn bộ các cạnh của đa giác (loại các cạnh song song với trục Ox) được sắp theo thứ tự tăng dần của trục y. Xem hình 2.5 ta có thể sắp xếp các cạnh trong ET là : AB, AI, HG, BC, GF, DC, EF (loại IH và DE) - Danh sách các cạnh đang kích họat (Active Edge Table - AET) : chứa các cạnh của

đa giác có thể cắt ứng với dòng quét hiện hành, các cạnh này được sắp theo thứ tự tăng dần của hoành độ giao điểm của hoành độ giao điểm giữa cạnh và dòng quét.

- Khi dòng quét đi từ ymin đến ymax, các cạnh thoảđiều kiện sẽđược chuyển từ ET sang AET. Nghĩa là, khi dòng quét y=k bắt đầu cắt một cạnh, khi đó k ≥ ymin, cạnh này sẽđược chuyển từ ET sang AET. Khi dòng quét không còn cắt cạnh này nữa, khi

đó, k > ymax, cạnh này sẽ bị loại khỏi AET. Khi không còn cạnh nào trong ET hay AET thì quá trình tô màu kết thúc ( xem hình 2.5).

B D E F G I H A yH+1 yH ymin C P ymax

Hình 2.7 : Tô đa giác bằng giải thuật scan -line.

- Để tìm giao điểm giữa cạnh đa giác và dòng quét, ta có nhận xét sau :

y = k+1 y = k xk x k+1 x k+1 - x k = m 1 ( (k+1) - k ) = m 1 hay x k+1 = x k + m 1 Trong đó m là hệ số góc của cạnh.

Lưu đồ thuật toán scan - line

Begin

Tạo danh sách tất cả các cạnh (ET) của đa giác.

i < ymax

Tìm hoành độ giao điểm và sắp xếp theo thứ

tựtăng dần

End

No

Yes

Tô mẫu các đoạn giao được tạo bởi từng cặp hoành độkếtiếp nhau Cập nhật lại thông tin của các cạnh để sử dụng cho dòng quét kếtiếp i = ymin Cập nhật danh sách các cạnh kích họat AET i = i + 1

Một phần của tài liệu Chương 1: Giới thiệu thuật toán vẽ và tô các đường cơ bản (Trang 38 - 42)

Tải bản đầy đủ (PDF)

(159 trang)