GuiLite/core/src/wave_ctrl.cpp

239 lines
5.7 KiB
C++
Raw Normal View History

2017-12-06 21:43:47 +08:00
#include "../core_include/api.h"
#include "../core_include/rect.h"
#include "../core_include/cmd_target.h"
#include "../core_include/wnd.h"
#include "../core_include/wave_buffer.h"
#include "../core_include/surface.h"
2018-10-04 14:30:29 +08:00
#include "../core_include/resource.h"
2017-12-06 21:43:47 +08:00
#include "../core_include/word.h"
#include "../core_include/wave_ctrl.h"
#include <stdlib.h>
#include <string.h>
#define CORRECT(x, high_limit, low_limit) {\
x = (x > high_limit) ? high_limit : x;\
x = (x < low_limit) ? low_limit : x;\
}while(0)
#define WAVE_CURSOR_WIDTH 8
#define WAVE_LINE_WIDTH 1
2019-01-16 13:24:09 +08:00
#define WAVE_MARGIN 5
2017-12-06 21:43:47 +08:00
c_wave_ctrl::c_wave_ctrl()
{
m_wave = NULL;
m_bg_fb = NULL;
m_wave_name_font = m_wave_unit_font = NULL;
2017-12-06 21:43:47 +08:00
m_wave_name = m_wave_unit = 0;
m_max_data = 500;
m_min_data = 0;
m_wave_speed = 1;
m_wave_data_rate = 0;
m_wave_refresh_rate = 1000;
2017-12-06 21:43:47 +08:00
m_frame_len_map_index = 0;
2018-11-01 10:35:37 +08:00
m_wave_name_color = m_wave_unit_color = m_wave_color = GL_RGB(255,0,0);
m_back_color = GL_RGB(0,0,0);
2017-12-06 21:43:47 +08:00
}
void c_wave_ctrl::on_init_children()
{
c_rect rect;
get_screen_rect(rect);
2019-01-16 13:24:09 +08:00
m_wave_left = rect.m_left + WAVE_MARGIN;
m_wave_right = rect.m_right - WAVE_MARGIN;
m_wave_top = rect.m_top + WAVE_MARGIN;
m_wave_bottom = rect.m_bottom - WAVE_MARGIN;
2017-12-06 21:43:47 +08:00
m_wave_cursor = m_wave_left;
2018-11-01 10:35:37 +08:00
m_bg_fb = (unsigned int*)calloc(rect.Width() * rect.Height(), 4);
2017-12-06 21:43:47 +08:00
}
2019-01-17 10:55:12 +08:00
void c_wave_ctrl::set_max_min(short max_data, short min_data)
2017-12-06 21:43:47 +08:00
{
m_max_data = max_data;
m_min_data = min_data;
}
void c_wave_ctrl::set_wave_in_out_rate(unsigned int data_rate, unsigned int refresh_rate)
2017-12-06 21:43:47 +08:00
{
m_wave_data_rate = data_rate;
m_wave_refresh_rate = refresh_rate;
int read_times_per_second = m_wave_speed * 1000 / m_wave_refresh_rate;
2017-12-06 21:43:47 +08:00
memset(m_frame_len_map, 0, sizeof(m_frame_len_map));
for (unsigned int i = 1; i < sizeof(m_frame_len_map) + 1; i++)
{
m_frame_len_map[i-1] = data_rate * i / read_times_per_second - data_rate * (i-1) / read_times_per_second;
2017-12-06 21:43:47 +08:00
}
m_frame_len_map_index = 0;
}
void c_wave_ctrl::set_wave_speed(unsigned int speed)
{
m_wave_speed = speed;
set_wave_in_out_rate(m_wave_data_rate, m_wave_refresh_rate);
2017-12-06 21:43:47 +08:00
}
void c_wave_ctrl::clear_data()
{
if(m_wave == NULL)
{
ASSERT(FALSE);
return;
}
m_wave->clear_data();
}
bool c_wave_ctrl::is_data_enough()
{
if(m_wave == NULL)
{
ASSERT(FALSE);
return false;
}
2019-01-16 13:24:09 +08:00
return (m_wave->get_cnt() - m_frame_len_map[m_frame_len_map_index] * m_wave_speed);
2017-12-06 21:43:47 +08:00
}
void c_wave_ctrl::refresh_wave(unsigned char frame)
{
if(m_wave == NULL)
{
ASSERT(FALSE);
return;
}
2019-01-17 14:39:18 +08:00
short max, min, mid;
for(short offset = 0; offset < m_wave_speed; offset++)
2017-12-06 21:43:47 +08:00
{
//get wave value
mid = m_wave->read_wave_data_by_frame(max, min,
m_frame_len_map[m_frame_len_map_index++],
2019-01-17 14:39:18 +08:00
frame, offset);
2017-12-06 21:43:47 +08:00
m_frame_len_map_index %= sizeof(m_frame_len_map);
2019-01-17 10:55:12 +08:00
2017-12-06 21:43:47 +08:00
//map to wave ctrl
int y_min,y_max;
if(m_max_data == m_min_data)
{
ASSERT(FALSE);
}
2019-01-17 10:55:12 +08:00
y_max = m_wave_bottom + WAVE_LINE_WIDTH - (m_wave_bottom - m_wave_top)*(min - m_min_data)/(m_max_data - m_min_data);
y_min = m_wave_bottom - WAVE_LINE_WIDTH - (m_wave_bottom - m_wave_top)*(max - m_min_data)/(m_max_data - m_min_data);
2017-12-06 21:43:47 +08:00
mid = m_wave_bottom - (m_wave_bottom - m_wave_top)*(mid - m_min_data)/(m_max_data - m_min_data);
CORRECT(y_min, m_wave_bottom, m_wave_top);
CORRECT(y_max, m_wave_bottom, m_wave_top);
CORRECT(mid, m_wave_bottom, m_wave_top);
2019-01-15 17:23:12 +08:00
if (m_wave_cursor > m_wave_right)
2017-12-06 21:43:47 +08:00
{
2019-01-15 17:23:12 +08:00
m_wave_cursor = m_wave_left;
2017-12-06 21:43:47 +08:00
}
2019-01-15 17:23:12 +08:00
draw_smooth_vline(y_min, y_max, mid, m_wave_color);
restore_background();
m_wave_cursor++;
2017-12-06 21:43:47 +08:00
}
}
void c_wave_ctrl::draw_smooth_vline(int y_min, int y_max, int mid, unsigned int rgb)
{
int dy = y_max - y_min;
2018-11-01 10:35:37 +08:00
short r = GL_RGB_R(rgb);
short g = GL_RGB_G(rgb);
short b = GL_RGB_B(rgb);
2018-11-09 15:01:48 +08:00
int index = (dy >> 1) + 2;
2017-12-06 21:43:47 +08:00
int y;
2018-11-01 10:35:37 +08:00
draw_pixel(m_wave_cursor, mid, rgb);
2017-12-06 21:43:47 +08:00
if (dy < 1)
{
return;
}
unsigned char cur_r,cur_g,cur_b;
unsigned int cur_rgb;
2018-11-09 15:01:48 +08:00
for (int i = 1; i <= (dy >> 1) + 1; ++i )
2017-12-06 21:43:47 +08:00
{
if ( (mid + i) <= y_max )
{
y = mid + i;
2018-11-09 15:01:48 +08:00
cur_r = r * (index - i) / index;
cur_g = g * (index - i) / index;
cur_b = b * (index - i) / index;
2018-11-01 10:35:37 +08:00
cur_rgb = GL_RGB(cur_r, cur_g, cur_b);
draw_pixel(m_wave_cursor, y, cur_rgb);
2017-12-06 21:43:47 +08:00
}
if ( (mid - i) >= y_min )
{
y = mid - i;
2018-11-09 15:01:48 +08:00
cur_r = r * (index - i) / index;
cur_g = g * (index - i) / index;
cur_b = b * (index - i) / index;
2018-11-01 10:35:37 +08:00
cur_rgb = GL_RGB(cur_r, cur_g, cur_b);
draw_pixel(m_wave_cursor, y, cur_rgb);
2017-12-06 21:43:47 +08:00
}
}
}
void c_wave_ctrl::on_paint()
{
c_rect rect;
get_screen_rect(rect);
fill_rect(rect.m_left, rect.m_top, rect.m_right, rect.m_bottom, m_back_color);
//show name
c_word::draw_string(m_surface, m_z_order, m_wave_name, m_wave_left + 10, rect.m_top, m_wave_name_font, m_wave_name_color, GL_ARGB(0, 0, 0, 0), ALIGN_LEFT);
2017-12-06 21:43:47 +08:00
//show unit
c_word::draw_string(m_surface, m_z_order, m_wave_unit, m_wave_left + 60, rect.m_top, m_wave_unit_font, m_wave_unit_color, GL_ARGB(0, 0, 0, 0), ALIGN_LEFT);
2017-12-06 21:43:47 +08:00
2018-11-01 10:35:37 +08:00
save_background();
2017-12-06 21:43:47 +08:00
}
void c_wave_ctrl::clear_wave(void)
{
fill_rect(m_wave_left, m_wave_top, m_wave_right, m_wave_bottom, m_back_color);
m_wave_cursor = m_wave_left;
}
2018-11-01 10:35:37 +08:00
void c_wave_ctrl::restore_background()
2017-12-06 21:43:47 +08:00
{
int x = m_wave_cursor + WAVE_CURSOR_WIDTH;
if (x > m_wave_right)
{
x -= (m_wave_right - m_wave_left + 1);
}
c_rect rect;
get_screen_rect(rect);
register int width = rect.Width();
register int top = rect.m_top;
register int left = rect.m_left;
for (int y_pos = (m_wave_top - 1); y_pos <= (m_wave_bottom + 1); y_pos++)
{
2019-01-10 15:05:08 +08:00
(m_bg_fb) ? draw_pixel(x, y_pos, m_bg_fb[(y_pos - top) * width + (x - left)]) : draw_pixel(x, y_pos, 0);
2017-12-06 21:43:47 +08:00
}
}
2018-11-01 10:35:37 +08:00
void c_wave_ctrl::save_background()
2017-12-06 21:43:47 +08:00
{
2019-01-10 15:05:08 +08:00
if (!m_bg_fb)
{
return;
}
2017-12-06 21:43:47 +08:00
c_rect rect;
get_screen_rect(rect);
2018-11-01 10:35:37 +08:00
register unsigned int* p_des = m_bg_fb;
2017-12-06 21:43:47 +08:00
for (int y = rect.m_top; y <= rect.m_bottom; y++)
{
for (int x = rect.m_left; x <= rect.m_right; x++)
{
*p_des++ = m_surface->get_pixel(x, y, m_z_order);
}
}
2017-12-15 22:49:45 +08:00
}