mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-08 20:12:01 +03:00
update atari frontend for invalidate window API change
This commit is contained in:
parent
6833f526f6
commit
b102950650
@ -385,34 +385,41 @@ static void atari_window_reformat(struct gui_window *gw)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gui_window_redraw_window(struct gui_window *gw)
|
|
||||||
{
|
|
||||||
//CMP_BROWSER b;
|
|
||||||
GRECT rect;
|
|
||||||
if (gw == NULL)
|
|
||||||
return;
|
|
||||||
//b = gw->browser;
|
|
||||||
window_get_grect(gw->root, BROWSER_AREA_CONTENT, &rect);
|
|
||||||
window_schedule_redraw_grect(gw->root, &rect);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void gui_window_update_box(struct gui_window *gw, const struct rect *rect)
|
/**
|
||||||
|
* Invalidates an area of an atari browser window
|
||||||
|
*
|
||||||
|
* \param gw gui_window
|
||||||
|
* \param rect area to redraw or NULL for the entire window area
|
||||||
|
* \return NSERROR_OK on success or appropriate error code
|
||||||
|
*/
|
||||||
|
static nserror
|
||||||
|
atari_window_invalidate_area(struct gui_window *gw,
|
||||||
|
const struct rect *rect)
|
||||||
{
|
{
|
||||||
GRECT area;
|
GRECT area;
|
||||||
struct gemtk_wm_scroll_info_s *slid;
|
|
||||||
|
|
||||||
if (gw == NULL)
|
if (gw == NULL) {
|
||||||
return;
|
return NSERROR_BAD_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
|
window_get_grect(gw->root, BROWSER_AREA_CONTENT, &area);
|
||||||
|
|
||||||
|
if (rect != NULL) {
|
||||||
|
struct gemtk_wm_scroll_info_s *slid;
|
||||||
|
|
||||||
slid = gemtk_wm_get_scroll_info(gw->root->win);
|
slid = gemtk_wm_get_scroll_info(gw->root->win);
|
||||||
|
|
||||||
window_get_grect(gw->root, BROWSER_AREA_CONTENT, &area);
|
|
||||||
area.g_x += rect->x0 - (slid->x_pos * slid->x_unit_px);
|
area.g_x += rect->x0 - (slid->x_pos * slid->x_unit_px);
|
||||||
area.g_y += rect->y0 - (slid->y_pos * slid->y_unit_px);
|
area.g_y += rect->y0 - (slid->y_pos * slid->y_unit_px);
|
||||||
area.g_w = rect->x1 - rect->x0;
|
area.g_w = rect->x1 - rect->x0;
|
||||||
area.g_h = rect->y1 - rect->y0;
|
area.g_h = rect->y1 - rect->y0;
|
||||||
|
}
|
||||||
|
|
||||||
//dbg_grect("update box", &area);
|
//dbg_grect("update box", &area);
|
||||||
window_schedule_redraw_grect(gw->root, &area);
|
window_schedule_redraw_grect(gw->root, &area);
|
||||||
|
|
||||||
|
return NSERROR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool gui_window_get_scroll(struct gui_window *w, int *sx, int *sy)
|
bool gui_window_get_scroll(struct gui_window *w, int *sx, int *sy)
|
||||||
@ -680,7 +687,7 @@ static void gui_window_new_content(struct gui_window *w)
|
|||||||
slid->x_pos = 0;
|
slid->x_pos = 0;
|
||||||
slid->y_pos = 0;
|
slid->y_pos = 0;
|
||||||
gemtk_wm_update_slider(w->root->win, GEMTK_WM_VH_SLIDER);
|
gemtk_wm_update_slider(w->root->win, GEMTK_WM_VH_SLIDER);
|
||||||
gui_window_redraw_window(w);
|
atari_window_invalidate_area(w, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1051,8 +1058,7 @@ static void gui_init(int argc, char** argv)
|
|||||||
static struct gui_window_table atari_window_table = {
|
static struct gui_window_table atari_window_table = {
|
||||||
.create = gui_window_create,
|
.create = gui_window_create,
|
||||||
.destroy = gui_window_destroy,
|
.destroy = gui_window_destroy,
|
||||||
.redraw = gui_window_redraw_window,
|
.invalidate = atari_window_invalidate_area,
|
||||||
.update = gui_window_update_box,
|
|
||||||
.get_scroll = gui_window_get_scroll,
|
.get_scroll = gui_window_get_scroll,
|
||||||
.set_scroll = gui_window_set_scroll,
|
.set_scroll = gui_window_set_scroll,
|
||||||
.get_dimensions = gui_window_get_dimensions,
|
.get_dimensions = gui_window_get_dimensions,
|
||||||
|
Loading…
Reference in New Issue
Block a user