@ -200,6 +200,8 @@ struct surface {
enum window_buffer_type buffer_type ;
enum window_buffer_type buffer_type ;
enum wl_output_transform buffer_transform ;
enum wl_output_transform buffer_transform ;
cairo_surface_t * cairo_surface ;
} ;
} ;
struct window {
struct window {
@ -220,8 +222,6 @@ struct window {
int transparent ;
int transparent ;
int focus_count ;
int focus_count ;
cairo_surface_t * cairo_surface ;
int resizing ;
int resizing ;
int fullscreen_method ;
int fullscreen_method ;
@ -1143,8 +1143,11 @@ display_get_pointer_image(struct display *display, int pointer)
}
}
static void
static void
surface_attach_surface ( struct surface * surface )
surface_flush ( struct surface * surface )
{
{
if ( ! surface - > cairo_surface )
return ;
if ( surface - > opaque_region ) {
if ( surface - > opaque_region ) {
wl_surface_set_opaque_region ( surface - > surface ,
wl_surface_set_opaque_region ( surface - > surface ,
surface - > opaque_region ) ;
surface - > opaque_region ) ;
@ -1161,20 +1164,9 @@ surface_attach_surface(struct surface *surface)
surface - > toysurface - > swap ( surface - > toysurface ,
surface - > toysurface - > swap ( surface - > toysurface ,
& surface - > server_allocation ) ;
& surface - > server_allocation ) ;
}
static void
window_attach_surface ( struct window * window )
{
struct display * display = window - > display ;
if ( window - > type = = TYPE_NONE ) {
window - > type = TYPE_TOPLEVEL ;
if ( display - > shell )
wl_shell_surface_set_toplevel ( window - > shell_surface ) ;
}
surface_attach_surface ( window - > main_surface ) ;
cairo_surface_destroy ( surface - > cairo_surface ) ;
surface - > cairo_surface = NULL ;
}
}
int
int
@ -1186,12 +1178,13 @@ window_has_focus(struct window *window)
static void
static void
window_flush ( struct window * window )
window_flush ( struct window * window )
{
{
if ( ! window - > cairo_surface )
if ( window - > type = = TYPE_NONE ) {
return ;
window - > type = TYPE_TOPLEVEL ;
if ( window - > shell_surface )
wl_shell_surface_set_toplevel ( window - > shell_surface ) ;
}
window_attach_surface ( window ) ;
surface_flush ( window - > main_surface ) ;
cairo_surface_destroy ( window - > cairo_surface ) ;
window - > cairo_surface = NULL ;
}
}
struct display *
struct display *
@ -1200,7 +1193,7 @@ window_get_display(struct window *window)
return window - > display ;
return window - > display ;
}
}
static cairo_surface_t *
static void
surface_create_surface ( struct surface * surface , int dx , int dy , uint32_t flags )
surface_create_surface ( struct surface * surface , int dx , int dy , uint32_t flags )
{
{
struct display * display = surface - > window - > display ;
struct display * display = surface - > window - > display ;
@ -1232,10 +1225,9 @@ surface_create_surface(struct surface *surface, int dx, int dy, uint32_t flags)
surface - > surface ,
surface - > surface ,
flags , & allocation ) ;
flags , & allocation ) ;
return surface - > toysurface - > prepare ( surface - > toysurface , dx , dy ,
surface - > cairo_surface = surface - > toysurface - > prepare (
allocation . width ,
surface - > toysurface , dx , dy ,
allocation . height ,
allocation . width , allocation . height , flags ) ;
flags ) ;
}
}
static void
static void
@ -1262,8 +1254,7 @@ window_create_surface(struct window *window)
window - > resize_edges = 0 ;
window - > resize_edges = 0 ;
window - > cairo_surface = surface_create_surface ( window - > main_surface ,
surface_create_surface ( surface , dx , dy , flags ) ;
dx , dy , flags ) ;
}
}
int
int
@ -1528,7 +1519,7 @@ widget_schedule_redraw(struct widget *widget)
cairo_surface_t *
cairo_surface_t *
window_get_surface ( struct window * window )
window_get_surface ( struct window * window )
{
{
return cairo_surface_reference ( window - > cairo_surface ) ;
return cairo_surface_reference ( window - > main_surface - > cairo_surface ) ;
}
}
struct wl_surface *
struct wl_surface *
@ -1550,15 +1541,15 @@ tooltip_redraw_handler(struct widget *widget, void *data)
const int32_t r = 3 ;
const int32_t r = 3 ;
struct tooltip * tooltip = data ;
struct tooltip * tooltip = data ;
int32_t width , height ;
int32_t width , height ;
struct window * window = widget - > window ;
struct surface * surface = widget - > surface ;
cr = cairo_create ( window - > cairo_surface ) ;
cr = cairo_create ( surface - > cairo_surface ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_SOURCE ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_SOURCE ) ;
cairo_set_source_rgba ( cr , 0.0 , 0.0 , 0.0 , 0.0 ) ;
cairo_set_source_rgba ( cr , 0.0 , 0.0 , 0.0 , 0.0 ) ;
cairo_paint ( cr ) ;
cairo_paint ( cr ) ;
width = window - > main_ surface- > allocation . width ;
width = surface - > allocation . width ;
height = window - > main_ surface- > allocation . height ;
height = surface - > allocation . height ;
rounded_rect ( cr , 0 , 0 , width , height , r ) ;
rounded_rect ( cr , 0 , 0 , width , height , r ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_OVER ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_OVER ) ;
@ -1951,7 +1942,6 @@ frame_button_redraw_handler(struct widget *widget, void *data)
struct frame_button * frame_button = data ;
struct frame_button * frame_button = data ;
cairo_t * cr ;
cairo_t * cr ;
int width , height , x , y ;
int width , height , x , y ;
struct window * window = widget - > window ;
x = widget - > allocation . x ;
x = widget - > allocation . x ;
y = widget - > allocation . y ;
y = widget - > allocation . y ;
@ -1965,7 +1955,7 @@ frame_button_redraw_handler(struct widget *widget, void *data)
if ( widget - > opaque )
if ( widget - > opaque )
return ;
return ;
cr = cairo_create ( window - > cairo_surface ) ;
cr = cairo_create ( widget - > surface - > cairo_surface ) ;
if ( frame_button - > decoration = = FRAME_BUTTON_FANCY ) {
if ( frame_button - > decoration = = FRAME_BUTTON_FANCY ) {
cairo_set_line_width ( cr , 1 ) ;
cairo_set_line_width ( cr , 1 ) ;
@ -2047,7 +2037,7 @@ frame_redraw_handler(struct widget *widget, void *data)
if ( window - > type = = TYPE_FULLSCREEN )
if ( window - > type = = TYPE_FULLSCREEN )
return ;
return ;
cr = cairo_create ( window - > cairo_surface ) ;
cr = cairo_create ( widget - > surface - > cairo_surface ) ;
if ( window - > focus_count )
if ( window - > focus_count )
flags | = THEME_FRAME_ACTIVE ;
flags | = THEME_FRAME_ACTIVE ;
@ -3772,15 +3762,15 @@ menu_redraw_handler(struct widget *widget, void *data)
const int32_t r = 3 , margin = 3 ;
const int32_t r = 3 , margin = 3 ;
struct menu * menu = data ;
struct menu * menu = data ;
int32_t width , height , i ;
int32_t width , height , i ;
struct window * window = widget - > window ;
struct surface * surface = widget - > surface ;
cr = cairo_create ( window - > cairo_surface ) ;
cr = cairo_create ( surface - > cairo_surface ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_SOURCE ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_SOURCE ) ;
cairo_set_source_rgba ( cr , 0.0 , 0.0 , 0.0 , 0.0 ) ;
cairo_set_source_rgba ( cr , 0.0 , 0.0 , 0.0 , 0.0 ) ;
cairo_paint ( cr ) ;
cairo_paint ( cr ) ;
width = window - > main_ surface- > allocation . width ;
width = surface - > allocation . width ;
height = window - > main_ surface- > allocation . height ;
height = surface - > allocation . height ;
rounded_rect ( cr , 0 , 0 , width , height , r ) ;
rounded_rect ( cr , 0 , 0 , width , height , r ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_OVER ) ;
cairo_set_operator ( cr , CAIRO_OPERATOR_OVER ) ;