diff options
| author | Dana Jansens <danakj@orodu.net> | 2003-02-12 01:12:34 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2003-02-12 01:12:34 +0000 |
| commit | 5e0fc865a8b6063cbcb3451fbac4cdbe841889df (patch) | |
| tree | c7016162b5ef21ec947b5d18f132af3c92246f3d | |
| parent | 325a909dcdf5faa3a1cd5d30c45f2cda77c5ab4c (diff) | |
start of pseudocolor init
| -rw-r--r-- | otk/pseudorendercontrol.cc | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/otk/pseudorendercontrol.cc b/otk/pseudorendercontrol.cc index f6162cec..b3ee06c3 100644 --- a/otk/pseudorendercontrol.cc +++ b/otk/pseudorendercontrol.cc @@ -23,13 +23,34 @@ PseudoRenderControl::PseudoRenderControl(int screen) : RenderControl(screen) { printf("Initializing PseudoColor RenderControl\n"); - const ScreenInfo *info = display->screenInfo(_screen); + int depth = info->depth(); + + _cpc = 4; // XXX THIS SHOULD BE A USER OPTION + _ncolors = _cpc * _cpc * _cpc; + + if (_cpc < 2 || ncolors > 1 << depth) { + fprintf(stderr, + _("PseudoRenderControl: Invalid colormap size. Using maximum size +available.\n")); + _cpc = 1 << (depth/3); + _ncolors = 1 << depth; // _cpc * _cpc * _cpc + } + + if (!(_colors = new XColor[_ncolors])) { + fprintf(stderr, + _("PseudoRenderControl: error allocating colormap\n")); + ::exit(1); + } + + } PseudoRenderControl::~PseudoRenderControl() { printf("Destroying PseudoColor RenderControl\n"); + + delete _colors; } void PseudoRenderControl::reduceDepth(Surface &sf, XImage *im) const |
