minicrossterm/examples/cursor/mod.rs

120 lines
3.1 KiB
Rust
Raw Normal View History

2018-07-02 06:43:43 +10:00
//!
//! Examples of actions that could be performed with te cursor.
//!
extern crate crossterm;
use self::crossterm::cursor::{cursor, TerminalCursor};
use self::crossterm::Screen;
/// Set the cursor to position X: 10, Y: 5 in the terminal.
2018-07-02 06:43:43 +10:00
pub fn goto() {
// Get the cursor
let mut cursor = cursor();
// Set the cursor to position X: 10, Y: 5 in the terminal
2018-07-02 06:43:43 +10:00
cursor.goto(10, 5);
}
/// get the cursor position
2018-07-02 06:43:43 +10:00
pub fn pos() {
// Get the cursor
let mut cursor = cursor();
// get the cursor position.
let (x, y) = cursor.pos();
}
/// Move the cursor 3 up | demonstration.
2018-07-02 06:43:43 +10:00
pub fn move_up() {
// Get the cursor
let mut cursor = cursor();
2018-07-19 06:32:17 +10: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);
}
/// Move the cursor 3 to the right | demonstration.
2018-07-02 06:43:43 +10:00
pub fn move_right() {
let mut cursor = cursor();
// Move the cursor to position 3 times to the right in the terminal
cursor.move_right(3);
}
/// Move the cursor 3 down | demonstration.
2018-07-02 06:43:43 +10:00
pub fn move_down() {
let mut cursor = cursor();
// Move the cursor to position 3 times to the down in the terminal
cursor.move_down(3);
}
/// Move the cursor 3 to the left | demonstration.
2018-07-02 06:43:43 +10:00
pub fn move_left() {
let mut cursor = cursor();
// Move the cursor to position 3 times to the left in the terminal
cursor.move_left(3);
}
///// Print character at X: 10 Y: 5 | demonstration.
//pub fn print() {
// let context = Context::new();
//
// // To print an some displayable content on an certain position.
//
// // Get the cursor
// let mut cursor = cursor(&context);
// // Set the cursor to position X: 10, Y: 5 in the terminal
// cursor.goto(10, 5);
// // Print the @ symbol at position X: 10, Y: 5 in the terminal
// print!("@");
// // Rust is line buffered inorder to print at an certain position we need to clear the buffer first.
// use std;
// use std::io::Write;
// std::io::stdout().flush();
//
// /* Because the above method is a little to much code,
// you can use the `print()` method for printing an value at an certain position in the terminal.
//
// Crossterm provides method chaining so that the above points can be inlined.
// */
//
// cursor.goto(10, 5).print("@");
//}
/// Save and reset cursor position | demonstration..
2018-07-02 06:43:43 +10:00
pub fn safe_and_reset_position() {
let mut cursor = cursor();
// Goto X: 5 Y: 5
2018-07-02 06:43:43 +10:00
cursor.goto(5, 5);
// Safe cursor position: X: 5 Y: 5
cursor.save_position();
// Goto X: 5 Y: 20
2018-07-02 06:43:43 +10:00
cursor.goto(5, 20);
// Print at X: 5 Y: 20.
println!("Yea!");
// Reset back to X: 5 Y: 5.
cursor.reset_position();
// Print Back at X: 5 Y: 5.
println!("Back");
println!()
}
/// Hide cursor display | demonstration.
2018-07-02 06:43:43 +10:00
pub fn hide_cursor() {
let mut cursor = cursor();
cursor.hide();
}
/// Show cursor display | demonstration.
2018-07-02 06:43:43 +10:00
pub fn show_cursor() {
let mut cursor = cursor();
cursor.show();
}
/// Show cursor display, only works on certain terminals.| demonstration
2018-07-02 06:43:43 +10:00
pub fn blink_cursor() {
let mut cursor = cursor();
2018-06-27 04:56:34 +10:00
cursor.blink(false);
cursor.blink(false);
}