Show text

This commit is contained in:
daa84 2017-08-22 12:27:59 +03:00
parent c8da929681
commit b6e16cc969
2 changed files with 28 additions and 18 deletions

View File

@ -1,21 +1,27 @@
use sys::pango::*; use sys::pango::*;
use pango; use pango;
use pango::prelude::*;
use cairo; use cairo;
use pangocairo::CairoContextExt; use pangocairo::CairoContextExt;
use std::ffi::CString; use std::ffi::CString;
pub fn render(ctx: &cairo::Context) { pub fn render(ctx: &cairo::Context, font_desc: pango::FontDescription) {
let pango_context = ctx.create_pango_context(); let pango_context = ctx.create_pango_context();
pango_context.set_font_description(&font_desc);
let text = "TEST String".to_owned().into_bytes(); let text = "TEST String".to_owned().into_bytes();
let len = text.len(); let len = text.len();
let text = CString::new(text).unwrap(); let text = CString::new(text).unwrap();
let attr_list = pango::AttrList::new(); let attr_list = pango::AttrList::new();
ctx.move_to(0.0, 50.0);
let items = pango_itemize(&pango_context, &text, 0, len, &attr_list); let items = pango_itemize(&pango_context, &text, 0, len, &attr_list);
for item in items { for item in items {
let mut glyphs = pango::GlyphString::new(); let mut glyphs = pango::GlyphString::new();
let analysis = item.analysis(); let analysis = item.analysis();
pango_shape(&text, len, &analysis, &mut glyphs); pango_shape(&text, len, &analysis, &mut glyphs);
let (ink, logical) = glyphs.extents(&analysis.font()); let font = analysis.font();
let (ink, logical) = glyphs.extents(&font);
ctx.show_glyph_string(&font, &glyphs);
} }
} }

View File

@ -455,7 +455,6 @@ impl Shell {
let ref_state = self.state.clone(); let ref_state = self.state.clone();
state.im_context.connect_commit(move |_, ch| { state.im_context.connect_commit(move |_, ch| {
println!("commit");
ref_state.borrow().im_commit(ch) ref_state.borrow().im_commit(ch)
}); });
@ -530,7 +529,6 @@ impl Deref for Shell {
fn gtk_focus_in(state: &mut State) -> Inhibit { fn gtk_focus_in(state: &mut State) -> Inhibit {
state.im_context.focus_in(); state.im_context.focus_in();
println!("focus in");
state.cursor.as_mut().unwrap().enter_focus(); state.cursor.as_mut().unwrap().enter_focus();
let point = state.model.cur_point(); let point = state.model.cur_point();
state.on_redraw(&RepaintMode::Area(point)); state.on_redraw(&RepaintMode::Area(point));
@ -539,7 +537,6 @@ fn gtk_focus_in(state: &mut State) -> Inhibit {
fn gtk_focus_out(state: &mut State) -> Inhibit { fn gtk_focus_out(state: &mut State) -> Inhibit {
state.im_context.focus_out(); state.im_context.focus_out();
println!("focus out");
state.cursor.as_mut().unwrap().leave_focus(); state.cursor.as_mut().unwrap().leave_focus();
let point = state.model.cur_point(); let point = state.model.cur_point();
state.on_redraw(&RepaintMode::Area(point)); state.on_redraw(&RepaintMode::Area(point));
@ -623,26 +620,33 @@ fn update_line_metrics(state_arc: &Arc<UiMutex<State>>, ctx: &cairo::Context) {
} }
fn gtk_draw(state_arc: &Arc<UiMutex<State>>, ctx: &cairo::Context) -> Inhibit { fn gtk_draw(state_arc: &Arc<UiMutex<State>>, ctx: &cairo::Context) -> Inhibit {
render::render(ctx); //update_line_metrics(state_arc, ctx);
update_line_metrics(state_arc, ctx);
if state_arc.borrow_mut().request_nvim_resize { //if state_arc.borrow_mut().request_nvim_resize {
try_nvim_resize(state_arc); // try_nvim_resize(state_arc);
} //}
init_nvim(state_arc); //init_nvim(state_arc);
//let mut state = state_arc.borrow_mut();
//if state.nvim.borrow().is_initialized() {
// draw(&*state, ctx);
// request_window_resize(&mut *state);
//} else if state.nvim.borrow().is_initializing() {
// draw_initializing(&*state, ctx);
//}
let mut state = state_arc.borrow_mut(); let mut state = state_arc.borrow_mut();
if state.nvim.borrow().is_initialized() { render(&*state, ctx);
draw(&*state, ctx);
request_window_resize(&mut *state);
} else if state.nvim.borrow().is_initializing() {
draw_initializing(&*state, ctx);
}
Inhibit(false) Inhibit(false)
} }
fn render(state: &State, ctx: &cairo::Context) {
let font_desc = state.create_pango_font();
render::render(ctx, font_desc);
}
fn show_nvim_start_error(err: nvim::NvimInitError, state_arc: Arc<UiMutex<State>>) { fn show_nvim_start_error(err: nvim::NvimInitError, state_arc: Arc<UiMutex<State>>) {
let source = err.source(); let source = err.source();
let cmd = err.cmd().unwrap().to_owned(); let cmd = err.cmd().unwrap().to_owned();