aboutsummaryrefslogtreecommitdiffstats
path: root/unix
diff options
context:
space:
mode:
Diffstat (limited to 'unix')
-rw-r--r--unix/tx/TXImage.cxx32
1 files changed, 19 insertions, 13 deletions
diff --git a/unix/tx/TXImage.cxx b/unix/tx/TXImage.cxx
index 95cd2b70..0a50791a 100644
--- a/unix/tx/TXImage.cxx
+++ b/unix/tx/TXImage.cxx
@@ -304,28 +304,34 @@ static int depth2bpp(Display* dpy, int depth)
void TXImage::getNativePixelFormat(Visual* vis, int depth)
{
+ int bpp;
+ int trueColour, bigEndian;
+ int redShift, greenShift, blueShift;
+ int redMax, greenMax, blueMax;
+
cube = 0;
- nativePF.depth = depth;
- nativePF.bpp = depth2bpp(dpy, depth);
- nativePF.bigEndian = (ImageByteOrder(dpy) == MSBFirst);
- nativePF.trueColour = (vis->c_class == TrueColor);
+
+ bpp = depth2bpp(dpy, depth);
+ bigEndian = (ImageByteOrder(dpy) == MSBFirst);
+ trueColour = (vis->c_class == TrueColor);
vlog.info("Using default colormap and visual, %sdepth %d.",
(vis->c_class == TrueColor) ? "TrueColor, " :
((vis->c_class == PseudoColor) ? "PseudoColor, " : ""),
depth);
- if (nativePF.trueColour) {
+ redShift = ffs(vis->red_mask) - 1;
+ greenShift = ffs(vis->green_mask) - 1;
+ blueShift = ffs(vis->blue_mask) - 1;
+ redMax = vis->red_mask >> redShift;
+ greenMax = vis->green_mask >> greenShift;
+ blueMax = vis->blue_mask >> blueShift;
- nativePF.redShift = ffs(vis->red_mask) - 1;
- nativePF.greenShift = ffs(vis->green_mask) - 1;
- nativePF.blueShift = ffs(vis->blue_mask) - 1;
- nativePF.redMax = vis->red_mask >> nativePF.redShift;
- nativePF.greenMax = vis->green_mask >> nativePF.greenShift;
- nativePF.blueMax = vis->blue_mask >> nativePF.blueShift;
-
- } else {
+ nativePF = PixelFormat(bpp, depth, bigEndian, trueColour,
+ redMax, greenMax, blueMax,
+ redShift, greenShift, blueShift);
+ if (!trueColour) {
XColor xc[256];
cube = new rfb::ColourCube(6,6,6);
int r;