mirror of
https://github.com/netsurf-browser/netsurf
synced 2024-12-17 09:42:38 +03:00
Add scaled content redraw interface.
Add a new interface to the content to allow automaticaly scaled content redraws. This is intended to replace the thumbnail_redraw interface with something more generic.
This commit is contained in:
parent
de98108e7f
commit
ea2e1c4d98
@ -33,7 +33,9 @@
|
|||||||
#include "content/content_protected.h"
|
#include "content/content_protected.h"
|
||||||
#include "content/hlcache.h"
|
#include "content/hlcache.h"
|
||||||
#include "image/bitmap.h"
|
#include "image/bitmap.h"
|
||||||
|
#include "desktop/knockout.h"
|
||||||
#include "desktop/browser.h"
|
#include "desktop/browser.h"
|
||||||
|
#include "desktop/plotters.h"
|
||||||
#include "desktop/gui_internal.h"
|
#include "desktop/gui_internal.h"
|
||||||
#include "utils/nsoption.h"
|
#include "utils/nsoption.h"
|
||||||
|
|
||||||
@ -551,8 +553,7 @@ void content__request_redraw(struct content *c,
|
|||||||
/**
|
/**
|
||||||
* Display content on screen with optional tiling.
|
* Display content on screen with optional tiling.
|
||||||
*
|
*
|
||||||
* Calls the redraw_tile function for the content, or emulates it with the
|
* Calls the redraw function for the content.
|
||||||
* redraw function if it doesn't exist.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
bool content_redraw(hlcache_handle *h, struct content_redraw_data *data,
|
bool content_redraw(hlcache_handle *h, struct content_redraw_data *data,
|
||||||
@ -576,6 +577,74 @@ bool content_redraw(hlcache_handle *h, struct content_redraw_data *data,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* exported interface, documented in content/content.h */
|
||||||
|
bool content_scaled_redraw(struct hlcache_handle *h,
|
||||||
|
int width, int height, const struct redraw_context *ctx)
|
||||||
|
{
|
||||||
|
struct content *c = hlcache_handle_get_content(h);
|
||||||
|
struct redraw_context new_ctx = *ctx;
|
||||||
|
struct rect clip;
|
||||||
|
struct content_redraw_data data;
|
||||||
|
bool plot_ok = true;
|
||||||
|
|
||||||
|
assert(c != NULL);
|
||||||
|
|
||||||
|
/* ensure it is safe to attempt redraw */
|
||||||
|
if (c->locked) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ensure we have a redrawable content */
|
||||||
|
if (c->handler->redraw == NULL) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG(("Content %p %dx%d ctx:%p", c, width, height, ctx));
|
||||||
|
|
||||||
|
if (ctx->plot->option_knockout) {
|
||||||
|
knockout_plot_start(ctx, &new_ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set clip rectangle to required thumbnail size */
|
||||||
|
clip.x0 = 0;
|
||||||
|
clip.y0 = 0;
|
||||||
|
clip.x1 = width;
|
||||||
|
clip.y1 = height;
|
||||||
|
|
||||||
|
new_ctx.plot->clip(&clip);
|
||||||
|
|
||||||
|
/* Plot white background */
|
||||||
|
plot_ok &= new_ctx.plot->rectangle(clip.x0, clip.y0, clip.x1, clip.y1,
|
||||||
|
plot_style_fill_white);
|
||||||
|
|
||||||
|
|
||||||
|
/* Set up content redraw data */
|
||||||
|
data.x = 0;
|
||||||
|
data.y = 0;
|
||||||
|
data.width = width;
|
||||||
|
data.height = height;
|
||||||
|
|
||||||
|
data.background_colour = 0xFFFFFF;
|
||||||
|
data.repeat_x = false;
|
||||||
|
data.repeat_y = false;
|
||||||
|
|
||||||
|
/* Find the scale factor to use if the content has a width */
|
||||||
|
if (c->width) {
|
||||||
|
data.scale = (float)width / (float)c->width;
|
||||||
|
} else {
|
||||||
|
data.scale = 1.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Render the content */
|
||||||
|
plot_ok &= c->handler->redraw(c, &data, &clip, &new_ctx);
|
||||||
|
|
||||||
|
if (ctx->plot->option_knockout) {
|
||||||
|
knockout_plot_end();
|
||||||
|
}
|
||||||
|
|
||||||
|
return plot_ok;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Register a user for callbacks.
|
* Register a user for callbacks.
|
||||||
*
|
*
|
||||||
|
@ -270,6 +270,27 @@ void content_mouse_action(struct hlcache_handle *h, struct browser_window *bw,
|
|||||||
bool content_keypress(struct hlcache_handle *h, uint32_t key);
|
bool content_keypress(struct hlcache_handle *h, uint32_t key);
|
||||||
bool content_redraw(struct hlcache_handle *h, struct content_redraw_data *data,
|
bool content_redraw(struct hlcache_handle *h, struct content_redraw_data *data,
|
||||||
const struct rect *clip, const struct redraw_context *ctx);
|
const struct rect *clip, const struct redraw_context *ctx);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Redraw a content with scale set for horizontal fit.
|
||||||
|
*
|
||||||
|
* Redraws the content at a specified width and height with the
|
||||||
|
* content drawing scaled to fit within the area.
|
||||||
|
*
|
||||||
|
* \param content The content to redraw
|
||||||
|
* \param width The target width
|
||||||
|
* \param height The target height
|
||||||
|
* \param ctx current redraw context
|
||||||
|
* \return true if successful, false otherwise
|
||||||
|
*
|
||||||
|
* The thumbnail is guaranteed to be filled to its width/height extents, so
|
||||||
|
* there is no need to render a solid background first.
|
||||||
|
*
|
||||||
|
* Units for width and height are pixels.
|
||||||
|
*/
|
||||||
|
bool content_scaled_redraw(struct hlcache_handle *content, int width, int height, const struct redraw_context *ctx);
|
||||||
|
|
||||||
void content_open(struct hlcache_handle *h, struct browser_window *bw,
|
void content_open(struct hlcache_handle *h, struct browser_window *bw,
|
||||||
struct content *page, struct object_params *params);
|
struct content *page, struct object_params *params);
|
||||||
void content_close(struct hlcache_handle *h);
|
void content_close(struct hlcache_handle *h);
|
||||||
|
Loading…
Reference in New Issue
Block a user