Files
ab_glyph_rasterizer
addr2line
adler
andrew
approx
arrayvec
ash
extensions
experimental
ext
khr
mvk
nv
vk
atom
backtrace
bitflags
byteorder
calloop
cfg_if
colorful
conrod_core
graph
guide
input
position
widget
file_navigator
graph
primitive
bordered_rectangle.rsbuilder.rsbutton.rscanvas.rscollapsible_area.rsdrop_down_list.rsenvelope_editor.rsgrid.rsid.rslist.rslist_select.rsmatrix.rsmod.rsnumber_dialer.rsplot_path.rsrange_slider.rsrounded_rectangle.rsscroll.rsscrollbar.rsslider.rstabs.rstext_box.rstext_edit.rstitle_bar.rstoggle.rsxy_pad.rs
conrod_derive
conrod_example_shared
conrod_gfx
conrod_glium
conrod_piston
conrod_rendy
conrod_vulkano
conrod_wgpu
conrod_winit
copyless
copypasta
crossbeam
crossbeam_channel
crossbeam_deque
crossbeam_epoch
crossbeam_queue
crossbeam_utils
daggy
dlib
downcast_rs
draw_state
either
fixedbitset
float
fnv
futures
futures_channel
futures_core
futures_executor
futures_io
futures_macro
futures_sink
futures_task
futures_util
async_await
future
future
try_future
io
allow_std.rsbuf_reader.rsbuf_writer.rschain.rsclose.rscopy.rscopy_buf.rscursor.rsempty.rsfill_buf.rsflush.rsinto_sink.rslines.rsmod.rsread.rsread_exact.rsread_line.rsread_to_end.rsread_to_string.rsread_until.rsread_vectored.rsrepeat.rsseek.rssink.rssplit.rstake.rswindow.rswrite.rswrite_all.rswrite_vectored.rs
lock
sink
stream
futures_unordered
stream
buffer_unordered.rsbuffered.rscatch_unwind.rschain.rschunks.rscollect.rsconcat.rsenumerate.rsfilter.rsfilter_map.rsflatten.rsfold.rsfor_each.rsfor_each_concurrent.rsforward.rsfuse.rsinto_future.rsmap.rsmod.rsnext.rspeek.rsready_chunks.rsscan.rsselect_next_some.rsskip.rsskip_while.rssplit.rstake.rstake_until.rstake_while.rsthen.rszip.rs
try_stream
task
fxhash
getrandom
gfx
gfx_backend_empty
gfx_backend_vulkan
gfx_core
gfx_descriptor
gfx_hal
command
pso
queue
gfx_memory
gimli
read
glium
backend
glutin
buffer
context
draw_parameters
framebuffer
index
ops
program
texture
uniforms
utils
vertex
glutin
api
platform
platform_impl
glutin_egl_sys
glutin_glx_sys
graphics
glyph_cache
half
hibitset
inplace_it
input
instant
interpolation
iovec
itoa
lazy_static
lazycell
libc
unix
libloading
line_drawing
linked_hash_map
lock_api
log
maybe_uninit
memchr
memmap
memoffset
miniz_oxide
mio
deprecated
net
sys
mio_extras
naga
back
front
proc
net2
nix
net
sys
nom
bits
branch
bytes
character
combinator
multi
number
sequence
num
num_bigint
num_complex
num_cpus
num_integer
num_iter
num_rational
num_traits
object
read
once_cell
ordered_float
ordermap
osmesa_sys
owned_ttf_parser
parking_lot
parking_lot_core
percent_encoding
petgraph
algo
graph_impl
visit
pin_project
pin_project_internal
pin_project_lite
pin_utils
ppv_lite86
proc_macro2
proc_macro_hack
proc_macro_nested
quote
rand
distributions
weighted
rngs
seq
rand_chacha
rand_core
raw_window_handle
read_color
relevant
rendy
rendy_chain
rendy_command
rendy_core
rendy_descriptor
rendy_factory
rendy_frame
rendy_graph
rendy_init
rendy_memory
allocator
heaps
mapping
rendy_mesh
rendy_resource
rendy_shader
rendy_texture
rendy_wsi
rustc_demangle
rustc_hash
rusttype
ryu
same_file
scoped_tls
scopeguard
serde
de
private
ser
serde_derive
serde_json
shaderc
shaderc_sys
shared_library
slab
smallvec
smithay_client_toolkit
data_device
keyboard
pointer
shell
utils
window
smithay_clipboard
spirv_headers
stb_truetype
syn
attr.rsbigint.rsbuffer.rscustom_keyword.rscustom_punctuation.rsdata.rsderive.rsdiscouraged.rserror.rsexport.rsexpr.rsext.rsfile.rsgenerics.rsgroup.rsident.rsitem.rslib.rslifetime.rslit.rslookahead.rsmac.rsmacros.rsop.rsparse.rsparse_macro_input.rsparse_quote.rspat.rspath.rsprint.rspunctuated.rsreserved.rssealed.rsspan.rsspanned.rsstmt.rsthread.rstoken.rstt.rsty.rsverbatim.rswhitespace.rs
takeable_option
texture
thiserror
thiserror_impl
thread_profiler
time
tracing
tracing_core
ttf_parser
tables
typed_arena
unicode_xid
vecmath
viewport
vk_sys
void
vulkano
buffer
command_buffer
pool
submit
synced
validity
descriptor
descriptor_set
pipeline_layout
device
framebuffer
image
instance
memory
pipeline
graphics_pipeline
vertex
query
swapchain
sync
vulkano_shaders
walkdir
wayland_client
native_lib
wayland_commons
wayland_cursor
wayland_egl
wayland_protocols
wayland_sys
wgpu
wgpu_core
command
device
track
wgpu_types
winit
platform
platform_impl
linux
wayland
event_loop
seat
keyboard
pointer
text_input
touch
window
x11
x11
x11_clipboard
x11_dl
xcb
xcursor
xdg
xml
reader
parser
writer
>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
use {FloatNum, Point, SignedNum}; use octant::Octant; use steps::Steps; /// An implementation of the [mid-point line drawing algorithm]. /// /// The biggest difference between this algorithm and [`Bresenham`] is that it uses floating-point points. /// /// Example: /// /// ``` /// extern crate line_drawing; /// use line_drawing::Midpoint; /// /// fn main() { /// for (x, y) in Midpoint::<f32, i8>::new((0.2, 0.02), (2.8, 7.7)) { /// print!("({}, {}), ", x, y); /// } /// } /// ``` /// /// ```text /// (0, 0), (1, 1), (1, 2), (1, 3), (2, 4), (2, 5), (2, 6), (3, 7), (3, 8), /// ``` /// /// [mid-point line drawing algorithm]: http://www.mat.univie.ac.at/~kriegl/Skripten/CG/node25.html /// [`Bresenham`]: struct.bresenham.html pub struct Midpoint<I, O> { octant: Octant, point: Point<O>, a: I, b: I, k: I, end_x: O, } impl<I: FloatNum, O: SignedNum> Midpoint<I, O> { #[inline] pub fn new(start: Point<I>, end: Point<I>) -> Self { // Get the octant to use let octant = Octant::new(start, end); // Convert the points into the octant versions let start = octant.to(start); let end = octant.to(end); // Initialise the variables let a = -(end.1 - start.1); let b = end.0 - start.0; let c = start.0 * end.1 - end.0 * start.1; Self { octant, a, b, point: (O::cast(start.0.round()), O::cast(start.1.round())), k: a * (start.0.round() + I::one()) + b * (start.1.round() + I::cast(0.5)) + c, end_x: O::cast(end.0.round()), } } #[inline] pub fn steps(self) -> Steps<Point<O>, Self> { Steps::new(self) } } impl<I: FloatNum, O: SignedNum> Iterator for Midpoint<I, O> { type Item = Point<O>; #[inline] fn next(&mut self) -> Option<Self::Item> { if self.point.0 <= self.end_x { let point = self.octant.from(self.point); // Take an N step if self.k <= I::zero() { self.k += self.b; self.point.1 += O::one(); } // Take an E step self.k += self.a; self.point.0 += O::one(); Some(point) } else { None } } } #[test] fn tests() { let midpoint = |a, b| Midpoint::new(a, b).collect::<Vec<_>>(); assert_eq!( midpoint((0.0, 0.0), (-5.0, -5.0)), [(0, 0), (-1, -1), (-2, -2), (-3, -3), (-4, -4), (-5, -5)] ); assert_eq!( midpoint((0.0, 0.0), (6.0, 3.0)), [(0, 0), (1, 1), (2, 1), (3, 2), (4, 2), (5, 3), (6, 3)] ); }