2011-01-06 00:02:22 +03:00
|
|
|
/*
|
|
|
|
* Copyright 2010 Ole Loots <ole@monochrom.net>
|
|
|
|
*
|
|
|
|
* This file is part of NetSurf, http://www.netsurf-browser.org/
|
|
|
|
*
|
|
|
|
* NetSurf is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; version 2 of the License.
|
|
|
|
*
|
|
|
|
* NetSurf is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
#ifndef GEM_PLOTTER_DUMMY_H_INCLUDED
|
|
|
|
#define GEM_PLOTTER_DUMMY_H_INCLUDED
|
2011-04-11 01:43:22 +04:00
|
|
|
|
2011-01-06 00:02:22 +03:00
|
|
|
#include "plotter.h"
|
|
|
|
#include <Hermes/Hermes.h>
|
|
|
|
|
|
|
|
struct s_vdi_priv_data {
|
2011-11-24 02:33:02 +04:00
|
|
|
short bufops;
|
|
|
|
/* temp buffer for bitmap conversion: */
|
|
|
|
void * buf_packed;
|
|
|
|
int size_buf_packed;
|
|
|
|
|
|
|
|
/* temp buffer for bitmap conversion: */
|
|
|
|
void * buf_planar;
|
2011-01-06 00:02:22 +03:00
|
|
|
int size_buf_planar;
|
2011-11-24 02:33:02 +04:00
|
|
|
|
|
|
|
/* buffer for plot operations that require device format, */
|
|
|
|
/* currently used for transparent mfdb blits: */
|
|
|
|
MFDB buf_scr;
|
|
|
|
int size_buf_scr;
|
|
|
|
struct bitmap * buf_scr_compat;
|
|
|
|
|
|
|
|
/* intermediate bitmap format */
|
|
|
|
HermesFormat vfmt;
|
|
|
|
|
|
|
|
/* no screen format here, hermes may not suitable for it */
|
|
|
|
|
|
|
|
/* netsurf source bitmap format */
|
|
|
|
HermesFormat nsfmt;
|
2011-04-11 01:43:22 +04:00
|
|
|
};
|
2011-11-24 02:33:02 +04:00
|
|
|
|
|
|
|
/* how much memory should be kept allocated for temp. conversion bitmaps: */
|
|
|
|
#define CONV_KEEP_LIMIT 512000
|
|
|
|
/* how much memory to allocate if some is needed: */
|
|
|
|
#define CONV_BLOCK_SIZE 32000
|
2011-04-11 01:43:22 +04:00
|
|
|
|
|
|
|
/* this is an shortcut cast to access the members of the s_vdi_priv_data */
|
2011-01-06 00:02:22 +03:00
|
|
|
#define DUMMY_PRIV(self) ((struct s_vdi_priv_data*)self->priv_data)
|
|
|
|
|
2011-04-11 01:43:22 +04:00
|
|
|
/* Each driver object must export 1 it's own constructor: */
|
2011-01-06 00:02:22 +03:00
|
|
|
int ctor_plotter_vdi( GEM_PLOTTER p );
|
|
|
|
|
2011-04-11 01:43:22 +04:00
|
|
|
/*
|
|
|
|
* Capture the screen at x,y location
|
|
|
|
* param self instance
|
|
|
|
* param x absolute screen coords
|
|
|
|
* param y absolute screen coords
|
|
|
|
* param w width
|
|
|
|
* param h height
|
2011-11-24 02:33:02 +04:00
|
|
|
*
|
|
|
|
* This creates an snapshot in RGBA format (NetSurf's native format)
|
|
|
|
*
|
2011-04-11 01:43:22 +04:00
|
|
|
*/
|
2011-01-06 00:02:22 +03:00
|
|
|
static struct bitmap * snapshot_create(GEM_PLOTTER self, int x, int y, int w, int h);
|
2011-04-11 01:43:22 +04:00
|
|
|
|
|
|
|
/* Garbage collection of the snapshot routine */
|
|
|
|
/* this should be called after you are done with the data returned by snapshot_create */
|
|
|
|
/* don't access the screenshot after you called this function */
|
2011-01-06 00:02:22 +03:00
|
|
|
static void snapshot_suspend(GEM_PLOTTER self );
|
2011-04-11 01:43:22 +04:00
|
|
|
|
|
|
|
/* destroy memory used by screenshot */
|
2011-01-06 00:02:22 +03:00
|
|
|
static void snapshot_destroy( GEM_PLOTTER self );
|
|
|
|
|
|
|
|
#endif
|