Commit cursor changes
This commit is contained in:
parent
c458f90740
commit
7eb721bfcc
@ -16,6 +16,7 @@ mod ui_model;
|
|||||||
mod ui;
|
mod ui;
|
||||||
mod input;
|
mod input;
|
||||||
mod settings;
|
mod settings;
|
||||||
|
mod cursor;
|
||||||
|
|
||||||
use std::thread;
|
use std::thread;
|
||||||
use std::env;
|
use std::env;
|
||||||
|
19
src/shell.rs
19
src/shell.rs
@ -18,6 +18,7 @@ use ui_model::{UiModel, Cell, Attrs, Color, ModelRect, COLOR_BLACK, COLOR_WHITE,
|
|||||||
use nvim::{RedrawEvents, GuiApi, RepaintMode};
|
use nvim::{RedrawEvents, GuiApi, RepaintMode};
|
||||||
use input::{convert_key, keyval_to_input_string};
|
use input::{convert_key, keyval_to_input_string};
|
||||||
use ui::{UI, Ui, SET};
|
use ui::{UI, Ui, SET};
|
||||||
|
use cursor::Cursor;
|
||||||
|
|
||||||
const DEFAULT_FONT_NAME: &'static str = "DejaVu Sans Mono 12";
|
const DEFAULT_FONT_NAME: &'static str = "DejaVu Sans Mono 12";
|
||||||
|
|
||||||
@ -58,6 +59,7 @@ pub struct Shell {
|
|||||||
mouse_pressed: bool,
|
mouse_pressed: bool,
|
||||||
font_desc: FontDescription,
|
font_desc: FontDescription,
|
||||||
resize_timer: Option<glib::SourceId>,
|
resize_timer: Option<glib::SourceId>,
|
||||||
|
cursor: Cursor,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Shell {
|
impl Shell {
|
||||||
@ -77,6 +79,7 @@ impl Shell {
|
|||||||
mouse_pressed: false,
|
mouse_pressed: false,
|
||||||
font_desc: FontDescription::from_string(DEFAULT_FONT_NAME),
|
font_desc: FontDescription::from_string(DEFAULT_FONT_NAME),
|
||||||
resize_timer: None,
|
resize_timer: None,
|
||||||
|
cursor: Cursor::new(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,7 +122,7 @@ impl Shell {
|
|||||||
self.font_desc = FontDescription::from_string(desc);
|
self.font_desc = FontDescription::from_string(desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn colors<'a>(&'a self, cell: &'a Cell) -> (&'a Color, &'a Color) {
|
pub fn colors<'a>(&'a self, cell: &'a Cell) -> (&'a Color, &'a Color) {
|
||||||
let bg = if let Some(ref bg) = cell.attrs.background {
|
let bg = if let Some(ref bg) = cell.attrs.background {
|
||||||
bg
|
bg
|
||||||
} else {
|
} else {
|
||||||
@ -335,20 +338,8 @@ fn draw(shell: &Shell, ctx: &cairo::Context) {
|
|||||||
let (bg, fg) = shell.colors(cell);
|
let (bg, fg) = shell.colors(cell);
|
||||||
|
|
||||||
if row == line_idx && col == col_idx {
|
if row == line_idx && col == col_idx {
|
||||||
ctx.set_source_rgba(1.0 - bg.0, 1.0 - bg.1, 1.0 - bg.2, 0.5);
|
shell.cursor.draw(ctx, shell, char_width, line_height, line_y, double_width, bg);
|
||||||
|
|
||||||
let cursor_width = if shell.mode == NvimMode::Insert {
|
|
||||||
char_width / 5.0
|
|
||||||
} else {
|
|
||||||
if double_width {
|
|
||||||
char_width * 2.0
|
|
||||||
} else {
|
|
||||||
char_width
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
ctx.rectangle(current_point.0, line_y, cursor_width, line_height);
|
|
||||||
ctx.fill();
|
|
||||||
ctx.move_to(current_point.0, current_point.1);
|
ctx.move_to(current_point.0, current_point.1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user