From df054d3775a6d7a5558e45c28f32f84fc7eba279 Mon Sep 17 00:00:00 2001 From: Alex Date: Wed, 5 Sep 2018 14:14:41 +0200 Subject: [PATCH] Fixed offset calculation for wide keys --- sources/input-history.cpp | 2 +- sources/input-source.cpp | 14 ++++++++++---- 2 files changed, 11 insertions(+), 5 deletions(-) diff --git a/sources/input-history.cpp b/sources/input-history.cpp index 9860ec41..02dbe8d4 100644 --- a/sources/input-history.cpp +++ b/sources/input-history.cpp @@ -490,7 +490,7 @@ obs_properties_t * get_properties_for_history(void * data) obs_property_list_add_int(mode_list, T_OVERLAY_MODE_TEXT, 0); obs_property_list_add_int(mode_list, T_OVERLAY_MODE_ICON, 1); obs_property_set_modified_callback(mode_list, mode_changed); - blog(LOG_INFO, "ADDED HISTORY MODE LIST"); + // Key name file std::string filter_img = util_file_filter(T_FILTER_IMAGE_FILES, "*.jpg *.png *.bmp"); std::string filter_text = util_file_filter(T_FILTER_TEXT_FILES, "*.ini"); diff --git a/sources/input-source.cpp b/sources/input-source.cpp index 3690e0fc..7e6a8b0d 100644 --- a/sources/input-source.cpp +++ b/sources/input-source.cpp @@ -132,6 +132,8 @@ inline void InputSource::Render(gs_effect_t *effect) y = m_layout.m_btn_h * k->row + (m_layout.m_key_space_v * k->row); draw_key(effect, k, x, y); } + + } else if (m_layout.m_type == TYPE_MOUSE) { @@ -291,8 +293,8 @@ void InputSource::load_layout() k.texture_v = (uint16_t) (v_cord - 1); tempw = util_read_int(key_width); temph = util_read_int(key_height); - k.w = tempw * m_layout.m_btn_w; - k.h = temph * m_layout.m_btn_h; + k.w = tempw * m_layout.m_btn_w + m_layout.m_key_space_h * (tempw - 1); + k.h = temph * m_layout.m_btn_h + m_layout.m_key_space_v * (temph - 1); k.m_key_code = util_read_hex(key_order); k.m_pressed = false; k.row = util_read_int(key_row); @@ -302,6 +304,7 @@ void InputSource::load_layout() { k.x_offset = (uint16_t) ((k.w + m_layout.m_key_space_h * (tempw - 1)) / 2 - k.w / 2); + k.w -= k.x_offset; index += tempw; } else @@ -311,12 +314,12 @@ void InputSource::load_layout() } m_layout.m_keys.emplace_back(k); - u_cord += k.w + 3; + u_cord += tempw * m_layout.m_btn_w + (tempw * 3); } m_layout.m_h = m_layout.m_rows * m_layout.m_btn_h + m_layout.m_key_space_v * m_layout.m_rows; m_layout.m_w = (m_layout.m_cols * m_layout.m_btn_w + m_layout.m_key_space_h * - (m_layout.m_cols - 1)); + (m_layout.m_cols - 1)); } else if (m_layout.m_type == TYPE_MOUSE) { @@ -536,7 +539,10 @@ void InputSource::load_layout() m_layout.m_is_loaded = false; } } + +#ifndef _DEBUG if (cfg->get_bool("debug")) +#endif { blog(LOG_INFO, "------ input-overlay DEBUG"); cfg->dump_structure();