start of new render code
This commit is contained in:
parent
29f331b63f
commit
0dcbf985c1
7 changed files with 250 additions and 1 deletions
|
@ -8,7 +8,7 @@ INCLUDES= -I../src
|
||||||
#noinst_LIBRARIES=libotk.a
|
#noinst_LIBRARIES=libotk.a
|
||||||
noinst_LTLIBRARIES=libotk.la
|
noinst_LTLIBRARIES=libotk.la
|
||||||
|
|
||||||
libotk_la_SOURCES=rendercontrol.cc \
|
libotk_la_SOURCES=rendercontrol.cc truerendercontrol.cc \
|
||||||
color.cc display.cc font.cc gccache.cc image.cc \
|
color.cc display.cc font.cc gccache.cc image.cc \
|
||||||
property.cc imagecontrol.cc rect.cc screeninfo.cc \
|
property.cc imagecontrol.cc rect.cc screeninfo.cc \
|
||||||
texture.cc timer.cc style.cc \
|
texture.cc timer.cc style.cc \
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
#ifndef __otk_hh
|
#ifndef __otk_hh
|
||||||
#define __otk_hh
|
#define __otk_hh
|
||||||
|
|
||||||
|
#include "../config.h"
|
||||||
|
|
||||||
#include "eventdispatcher.hh"
|
#include "eventdispatcher.hh"
|
||||||
#include "eventhandler.hh"
|
#include "eventhandler.hh"
|
||||||
#include "widget.hh"
|
#include "widget.hh"
|
||||||
|
|
60
otk/rendercontrol.cc
Normal file
60
otk/rendercontrol.cc
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "../config.h"
|
||||||
|
#endif // HAVE_CONFIG_H
|
||||||
|
|
||||||
|
#include "rendercontrol.hh"
|
||||||
|
#include "truerendercontrol.hh"
|
||||||
|
#include "display.hh"
|
||||||
|
#include "screeninfo.hh"
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#ifdef HAVE_STDLIB_H
|
||||||
|
# include <stdlib.h>
|
||||||
|
#endif // HAVE_STDLIB_H
|
||||||
|
|
||||||
|
#include "gettext.h"
|
||||||
|
#define _(str) gettext(str)
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace otk {
|
||||||
|
|
||||||
|
RenderControl *RenderControl::getRenderControl(int screen)
|
||||||
|
{
|
||||||
|
const ScreenInfo *info = display->screenInfo(screen);
|
||||||
|
|
||||||
|
// get the visual on the screen and return the correct type of RenderControl
|
||||||
|
int vclass = info->visual()->c_class;
|
||||||
|
switch (vclass) {
|
||||||
|
case TrueColor:
|
||||||
|
return new TrueRenderControl(info);
|
||||||
|
case PseudoColor:
|
||||||
|
case StaticColor:
|
||||||
|
// return new PseudoRenderControl(info);
|
||||||
|
case GrayScale:
|
||||||
|
case StaticGray:
|
||||||
|
// return new GrayRenderControl(info);
|
||||||
|
default:
|
||||||
|
printf(_("RenderControl: Unsupported visual %d specified. Aborting.\n"),
|
||||||
|
vclass);
|
||||||
|
::exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
RenderControl::RenderControl(const ScreenInfo *screen)
|
||||||
|
: _screen(screen)
|
||||||
|
{
|
||||||
|
printf("Initializing RenderControl\n");
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
RenderControl::~RenderControl()
|
||||||
|
{
|
||||||
|
printf("Destroying RenderControl\n");
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
60
otk/rendercontrol.hh
Normal file
60
otk/rendercontrol.hh
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
|
||||||
|
#ifndef __rendercontrol_hh
|
||||||
|
#define __rendercontrol_hh
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace otk {
|
||||||
|
|
||||||
|
class ScreenInfo;
|
||||||
|
|
||||||
|
class RenderControl {
|
||||||
|
protected:
|
||||||
|
const ScreenInfo *_screen;
|
||||||
|
/*
|
||||||
|
Bool _dither;
|
||||||
|
|
||||||
|
int _cpc; // colors-per-channel: must be a value between [2,6]
|
||||||
|
int _bpp; // bits-per-pixel
|
||||||
|
|
||||||
|
unsigned int *_grad_xbuffer;
|
||||||
|
unsigned int *_grad_ybuffer;
|
||||||
|
unsigned int _grad_buffer_width;
|
||||||
|
unsigned int _grad_buffer_height;
|
||||||
|
|
||||||
|
unsigned long *_sqrt_table;
|
||||||
|
|
||||||
|
// These values are all determined based on a visual
|
||||||
|
|
||||||
|
int _red_bits; // the number of bits (1-255) that each shade of color
|
||||||
|
int _green_bits; // spans across. best case is 1, which gives 255 shades.
|
||||||
|
int _blue_bits;
|
||||||
|
unsigned char _red_color_table[256];
|
||||||
|
unsigned char _green_color_table[256];
|
||||||
|
unsigned char _blue_color_table[256];
|
||||||
|
|
||||||
|
// These are only used for TrueColor visuals
|
||||||
|
int _red_offset; // the offset of each color in a color mask
|
||||||
|
int _green_offset;
|
||||||
|
int _blue_offset;
|
||||||
|
|
||||||
|
// These are only used for !TrueColor visuals
|
||||||
|
XColor *_colors;
|
||||||
|
int _ncolors;
|
||||||
|
*/
|
||||||
|
|
||||||
|
RenderControl(const ScreenInfo *screen);
|
||||||
|
|
||||||
|
public:
|
||||||
|
virtual ~RenderControl();
|
||||||
|
|
||||||
|
static RenderControl *getRenderControl(int screen);
|
||||||
|
|
||||||
|
virtual void render(::Drawable d) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // __rendercontrol_hh
|
25
otk/rendertest.cc
Normal file
25
otk/rendertest.cc
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
#include "otk.hh"
|
||||||
|
#include "rendercontrol.hh"
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
printf("\n");
|
||||||
|
|
||||||
|
otk::Application app(argc, argv);
|
||||||
|
otk::AppWidget foo(&app);
|
||||||
|
foo.resize(600, 500);
|
||||||
|
foo.show();
|
||||||
|
|
||||||
|
otk::RenderControl *rc = otk::RenderControl::getRenderControl(0);
|
||||||
|
|
||||||
|
rc->render(foo.window());
|
||||||
|
|
||||||
|
app.run();
|
||||||
|
|
||||||
|
delete rc;
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
return 0;
|
||||||
|
}
|
64
otk/truerendercontrol.cc
Normal file
64
otk/truerendercontrol.cc
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "../config.h"
|
||||||
|
#endif // HAVE_CONFIG_H
|
||||||
|
|
||||||
|
#include "truerendercontrol.hh"
|
||||||
|
#include "display.hh"
|
||||||
|
#include "screeninfo.hh"
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#ifdef HAVE_STDLIB_H
|
||||||
|
# include <stdlib.h>
|
||||||
|
#endif // HAVE_STDLIB_H
|
||||||
|
|
||||||
|
#include "gettext.h"
|
||||||
|
#define _(str) gettext(str)
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace otk {
|
||||||
|
|
||||||
|
TrueRenderControl::TrueRenderControl(const ScreenInfo *screen)
|
||||||
|
: RenderControl(screen)
|
||||||
|
{
|
||||||
|
printf("Initializing TrueColor RenderControl\n");
|
||||||
|
|
||||||
|
unsigned long red_mask, green_mask, blue_mask;
|
||||||
|
|
||||||
|
// find the offsets for each color in the visual's masks
|
||||||
|
red_mask = screen->visual()->red_mask;
|
||||||
|
green_mask = screen->visual()->green_mask;
|
||||||
|
blue_mask = screen->visual()->blue_mask;
|
||||||
|
|
||||||
|
while (! (red_mask & 1)) { _red_offset++; red_mask >>= 1; }
|
||||||
|
while (! (green_mask & 1)) { _green_offset++; green_mask >>= 1; }
|
||||||
|
while (! (blue_mask & 1)) { _blue_offset++; blue_mask >>= 1; }
|
||||||
|
|
||||||
|
// use the mask to determine the number of bits for each shade of color
|
||||||
|
// so, best case, red_mask == 0xff (255), with each bit as a different
|
||||||
|
// shade!
|
||||||
|
_red_bits = 255 / red_mask;
|
||||||
|
_green_bits = 255 / green_mask;
|
||||||
|
_blue_bits = 255 / blue_mask;
|
||||||
|
|
||||||
|
// compute color tables, based on the number of bits for each shade
|
||||||
|
for (int i = 0; i < 256; i++) {
|
||||||
|
_red_color_table[i] = i / _red_bits;
|
||||||
|
_green_color_table[i] = i / _green_bits;
|
||||||
|
_blue_color_table[i] = i / _blue_bits;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TrueRenderControl::~TrueRenderControl()
|
||||||
|
{
|
||||||
|
printf("Destroying TrueColor RenderControl\n");
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void TrueRenderControl::render(::Drawable d)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
38
otk/truerendercontrol.hh
Normal file
38
otk/truerendercontrol.hh
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
|
||||||
|
#ifndef __truerendercontrol_hh
|
||||||
|
#define __truerendercontrol_hh
|
||||||
|
|
||||||
|
#include "rendercontrol.hh"
|
||||||
|
|
||||||
|
namespace otk {
|
||||||
|
|
||||||
|
class TrueRenderControl : public RenderControl {
|
||||||
|
private:
|
||||||
|
// the offset of each color in a color mask
|
||||||
|
int _red_offset;
|
||||||
|
int _green_offset;
|
||||||
|
int _blue_offset;
|
||||||
|
|
||||||
|
// the number of bits (1-255) that each shade of color spans across. best
|
||||||
|
// case is 1, which gives 255 shades
|
||||||
|
int _red_bits;
|
||||||
|
int _green_bits;
|
||||||
|
int _blue_bits;
|
||||||
|
|
||||||
|
// color tables, meaning, 256 (possibly) different shades of each color,
|
||||||
|
// based on the number of bits there are available for each color in the
|
||||||
|
// visual
|
||||||
|
unsigned char _red_color_table[256];
|
||||||
|
unsigned char _green_color_table[256];
|
||||||
|
unsigned char _blue_color_table[256];
|
||||||
|
|
||||||
|
public:
|
||||||
|
TrueRenderControl(const ScreenInfo *screen);
|
||||||
|
virtual ~TrueRenderControl();
|
||||||
|
|
||||||
|
virtual void render(::Drawable d);
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // __truerendercontrol_hh
|
Loading…
Reference in a new issue