Zu dieser Karteikarte gibt es einen kompletten Satz an Karteikarten. Kostenlos!
113
Explain the Bresenham / Midpoint algorithm for line drawing!
A line with integer-valued endpoints
should be rasterized. W.l.o.g., we assume
and
(we can rotate / flip our pixel grid to fulfill these conditions).
The line is rasterized by starting with a point
on the line at
, and successively shifting
to the right
,
or to the top right
.
This decision is made based on whether the line passes above or below the midpoint
data:image/s3,"s3://crabby-images/9b98c/9b98cf8c483bdf7b329a48db29b8dd60c53b1018" alt=""
between
and
.
This condition can be checked by deriving an implicit representation of the line
. By taking
, we can define a normal to
as
data:image/s3,"s3://crabby-images/c87f7/c87f719d2b4d93046faca184b1020f0445d1567e" alt=""
and thus derive the implicit representation
.
In order to decide whether to go East or Northeast, we introduce a decision variable, which is initially
.
If
, we go East:
Update
.
Update
.
If
, we go Northeast:
Update
.
Update
.
Values for
can be doubled, thus using only integer arithmetic.
data:image/s3,"s3://crabby-images/814a9/814a9d00dc9a3e7555f7367834e5daade921745f" alt=""
data:image/s3,"s3://crabby-images/1eeef/1eeef7aa80a614b96089dad058695ca5a654f860" alt=""
data:image/s3,"s3://crabby-images/461ed/461ed34066aabc39083422be2ee7c478c3745ccc" alt=""
The line is rasterized by starting with a point
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/30db3/30db3dd5098b508c3284556f49fc96f39b5f3223" alt=""
or to the top right
data:image/s3,"s3://crabby-images/2d1fd/2d1fd725efef0698903947bf0800bb4f906a3f3d" alt=""
This decision is made based on whether the line passes above or below the midpoint
data:image/s3,"s3://crabby-images/9b98c/9b98cf8c483bdf7b329a48db29b8dd60c53b1018" alt=""
between
data:image/s3,"s3://crabby-images/d883d/d883dc0e8a916dddc4f337a041bf5fd06e81bb32" alt=""
data:image/s3,"s3://crabby-images/cb813/cb81341d081ce1bcd921b774870785547af1cd06" alt=""
This condition can be checked by deriving an implicit representation of the line
data:image/s3,"s3://crabby-images/039a5/039a5f90d68fad6b7937d00f722d5d24ebf7e6e9" alt=""
data:image/s3,"s3://crabby-images/e6a8d/e6a8d83c8b38c92efb2c493c70c104217aec3603" alt=""
data:image/s3,"s3://crabby-images/039a5/039a5f90d68fad6b7937d00f722d5d24ebf7e6e9" alt=""
data:image/s3,"s3://crabby-images/c87f7/c87f719d2b4d93046faca184b1020f0445d1567e" alt=""
and thus derive the implicit representation
data:image/s3,"s3://crabby-images/dfc73/dfc73c0fb1244b32111d9209500f0e8e0f51aa56" alt=""
In order to decide whether to go East or Northeast, we introduce a decision variable, which is initially
data:image/s3,"s3://crabby-images/069ad/069ad1342946e02e8dc629ec5d1712287423be59" alt=""
If
data:image/s3,"s3://crabby-images/fcf2a/fcf2a1a0291c4696aaa911147a68bbf0b0c9885d" alt=""
Update
data:image/s3,"s3://crabby-images/366fc/366fc345dd646f2e4334ea175e8574765e216f8c" alt=""
Update
data:image/s3,"s3://crabby-images/85888/858887bc15bf7117c10c8b705ba43a9606783c43" alt=""
If
data:image/s3,"s3://crabby-images/88253/88253f47a309ecdff966292e98f242b2798e5e98" alt=""
Update
data:image/s3,"s3://crabby-images/e0f13/e0f13b65441712743835c2c34d6e92a7d1642328" alt=""
Update
data:image/s3,"s3://crabby-images/2c91a/2c91ac20fb0266dcdd63bfd6a402fc7d02b62c44" alt=""
Values for
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/c64c7/c64c7f61abb9e2d96a6c69beff1bd79eb8bfc4e8" alt=""
Karteninfo:
Autor: janisborn
Oberthema: Informatik
Thema: Computergrafik
Schule / Uni: RWTH Aachen
Ort: Aachen
Veröffentlicht: 18.05.2022