2018-07-02 06:43:43 +10:00
|
|
|
//!
|
2019-06-22 02:10:46 +10:00
|
|
|
//! Examples of actions that could be performed with the cursor.
|
2018-01-18 09:06:45 +11:00
|
|
|
//!
|
|
|
|
|
2019-09-19 03:31:12 +10:00
|
|
|
#![allow(dead_code)]
|
2019-01-28 07:16:14 +11:00
|
|
|
|
2019-09-19 03:31:12 +10:00
|
|
|
use crossterm::{cursor, Result};
|
2018-01-18 09:06:45 +11:00
|
|
|
|
|
|
|
/// Set the cursor to position X: 10, Y: 5 in the terminal.
|
2019-09-19 03:31:12 +10:00
|
|
|
fn goto() -> Result<()> {
|
2018-01-18 09:06:45 +11:00
|
|
|
// Get the cursor
|
2019-01-01 05:55:48 +11:00
|
|
|
let cursor = cursor();
|
2018-01-18 09:06:45 +11:00
|
|
|
// Set the cursor to position X: 10, Y: 5 in the terminal
|
2019-04-13 22:44:31 +10:00
|
|
|
cursor.goto(10, 5)?;
|
|
|
|
|
|
|
|
Ok(())
|
2018-01-18 09:06:45 +11:00
|
|
|
}
|
|
|
|
|
2018-06-17 04:10:51 +10:00
|
|
|
/// get the cursor position
|
2019-09-19 03:31:12 +10:00
|
|
|
fn pos() {
|
2018-06-17 04:10:51 +10:00
|
|
|
// Get the cursor
|
2019-01-01 05:55:48 +11:00
|
|
|
let cursor = cursor();
|
2018-06-17 04:10:51 +10:00
|
|
|
// get the cursor position.
|
2018-10-08 04:15:17 +11:00
|
|
|
let (x, y) = cursor.pos();
|
2019-01-01 05:55:48 +11:00
|
|
|
|
|
|
|
println!("{} {}", x, y);
|
2018-06-17 04:10:51 +10:00
|
|
|
}
|
|
|
|
|
2018-01-18 09:06:45 +11:00
|
|
|
/// Move the cursor 3 up | demonstration.
|
2019-09-19 03:31:12 +10:00
|
|
|
fn move_up() {
|
2018-01-18 09:06:45 +11:00
|
|
|
// Get the cursor
|
2018-11-15 02:53:27 +11:00
|
|
|
let mut cursor = cursor();
|
2018-07-19 06:32:17 +10:00
|
|
|
|
2018-01-18 09:06:45 +11:00
|
|
|
// Move the cursor to position 3 times to the up in the terminal
|
2018-07-19 06:32:17 +10:00
|
|
|
cursor.move_up(10);
|
2018-01-18 09:06:45 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Move the cursor 3 to the right | demonstration.
|
2019-09-19 03:31:12 +10:00
|
|
|
fn move_right() {
|
2018-11-15 02:53:27 +11:00
|
|
|
let mut cursor = cursor();
|
2018-01-18 09:06:45 +11:00
|
|
|
// Move the cursor to position 3 times to the right in the terminal
|
|
|
|
cursor.move_right(3);
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Move the cursor 3 down | demonstration.
|
2019-09-19 03:31:12 +10:00
|
|
|
fn move_down() {
|
2018-11-15 02:53:27 +11:00
|
|
|
let mut cursor = cursor();
|
2018-01-18 09:06:45 +11:00
|
|
|
// Move the cursor to position 3 times to the down in the terminal
|
|
|
|
cursor.move_down(3);
|
|
|
|
}
|
|
|
|
|
2018-01-31 07:20:11 +11:00
|
|
|
/// Save and reset cursor position | demonstration..
|
2019-09-19 03:31:12 +10:00
|
|
|
fn save_and_reset_position() -> Result<()> {
|
2019-01-01 05:55:48 +11:00
|
|
|
let cursor = cursor();
|
2018-08-15 05:40:07 +10:00
|
|
|
|
2018-01-28 04:26:08 +11:00
|
|
|
// Goto X: 5 Y: 5
|
2019-04-13 22:44:31 +10:00
|
|
|
cursor.goto(5, 5)?;
|
2018-01-28 04:26:08 +11:00
|
|
|
// Safe cursor position: X: 5 Y: 5
|
2019-04-13 22:44:31 +10:00
|
|
|
cursor.save_position()?;
|
2018-01-28 04:26:08 +11:00
|
|
|
// Goto X: 5 Y: 20
|
2019-04-13 22:44:31 +10:00
|
|
|
cursor.goto(5, 20)?;
|
2018-01-28 04:26:08 +11:00
|
|
|
// Print at X: 5 Y: 20.
|
2018-01-31 07:20:11 +11:00
|
|
|
println!("Yea!");
|
2018-01-28 04:26:08 +11:00
|
|
|
// Reset back to X: 5 Y: 5.
|
2019-04-13 22:44:31 +10:00
|
|
|
cursor.reset_position()?;
|
2018-01-28 04:26:08 +11:00
|
|
|
// Print Back at X: 5 Y: 5.
|
2018-01-31 07:20:11 +11:00
|
|
|
println!("Back");
|
2018-01-28 04:26:08 +11:00
|
|
|
|
2019-04-13 22:44:31 +10:00
|
|
|
println!();
|
|
|
|
|
|
|
|
Ok(())
|
2018-01-26 04:26:08 +11:00
|
|
|
}
|
|
|
|
|
2018-06-24 03:48:22 +10:00
|
|
|
/// Hide cursor display | demonstration.
|
2019-09-19 03:31:12 +10:00
|
|
|
fn hide_cursor() -> Result<()> {
|
2019-01-01 05:55:48 +11:00
|
|
|
let cursor = cursor();
|
2019-09-19 03:31:12 +10:00
|
|
|
cursor.hide()
|
2018-06-24 03:48:22 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Show cursor display | demonstration.
|
2019-09-19 03:31:12 +10:00
|
|
|
fn show_cursor() -> Result<()> {
|
2019-01-01 05:55:48 +11:00
|
|
|
let cursor = cursor();
|
2019-09-19 03:31:12 +10:00
|
|
|
cursor.show()
|
2018-06-24 03:48:22 +10:00
|
|
|
}
|
|
|
|
|
2018-07-02 06:40:07 +10:00
|
|
|
/// Show cursor display, only works on certain terminals.| demonstration
|
2019-09-19 03:31:12 +10:00
|
|
|
fn blink_cursor(enable: bool) -> Result<()> {
|
2019-01-01 05:55:48 +11:00
|
|
|
let cursor = cursor();
|
2019-09-19 03:31:12 +10:00
|
|
|
cursor.blink(enable)
|
2018-06-27 04:56:34 +10:00
|
|
|
}
|
2019-01-28 07:16:14 +11:00
|
|
|
|
2019-09-17 18:50:39 +10:00
|
|
|
// cargo run --example cursor
|
2019-09-19 03:31:12 +10:00
|
|
|
fn main() -> Result<()> {
|
|
|
|
println!("Going to show cursor...");
|
|
|
|
show_cursor()?;
|
|
|
|
println!("Going to enable blinking cursor & sleep for 5s...");
|
|
|
|
blink_cursor(true)?;
|
|
|
|
std::thread::sleep(std::time::Duration::from_secs(5));
|
|
|
|
println!("Going to disable blinking cursor...");
|
|
|
|
blink_cursor(false)
|
2019-01-28 07:16:14 +11:00
|
|
|
}
|