Bitmap.cpp 3.85 KB
Newer Older
1 2
/**************************************************************************/
/*                                                                        */
3 4 5 6 7 8
/* Copyright (c) 2001, 2011 NoMachine (http://www.nomachine.com)          */
/* Copyright (c) 2008-2014 Oleksandr Shneyder <o.shneyder@phoca-gmbh.de>  */
/* Copyright (c) 2014-2016 Ulrich Sibiller <uli42@gmx.de>                 */
/* Copyright (c) 2014-2016 Mihai Moldovan <ionic@ionic.de>                */
/* Copyright (c) 2011-2016 Mike Gabriel <mike.gabriel@das-netzwerkteam.de>*/
/* Copyright (c) 2015-2016 Qindel Group (http://www.qindel.com)           */
9 10
/*                                                                        */
/* NXCOMP, NX protocol compression and NX extensions to this software     */
11
/* are copyright of the aforementioned persons and companies.             */
12
/*                                                                        */
13 14 15
/* Redistribution and use of the present software is allowed according    */
/* to terms specified in the file LICENSE.nxcomp which comes in the       */
/* source distribution.                                                   */
16 17 18
/*                                                                        */
/* All rights reserved.                                                   */
/*                                                                        */
19 20 21 22 23
/* NOTE: This software has received contributions from various other      */
/* contributors, only the core maintainers and supporters are listed as   */
/* copyright holders. Please contact us, if you feel you should be listed */
/* as copyright holder, as well.                                          */
/*                                                                        */
24 25
/**************************************************************************/

26 27 28 29
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif

30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118
#include "Misc.h"
#include "Bitmap.h"

#define PANIC
#define WARNING
#undef  TEST
#undef  DEBUG

int UnpackBitmap(T_geometry *geometry, unsigned char method, unsigned char *src_data,
                  int src_size, int dst_bpp, int dst_width, int dst_height,
                      unsigned char *dst_data, int dst_size)
{
  if (dst_bpp != 32)
  {
    #ifdef TEST
    *logofs << "UnpackBitmap: Nothing to do with "
            << "image of " << dst_bpp << " bits per plane "
            << "and size " << src_size << ".\n"
            << logofs_flush;
    #endif

    if (src_size != dst_size)
    {
      #ifdef PANIC
      *logofs << "UnpackBitmap: PANIC! Size mismatch with "
              << src_size << " bytes in the source and "
              << dst_size << " in the destination.\n"
              << logofs_flush;
      #endif

      return -1;
    }

    memcpy(dst_data, src_data, src_size);

    return 1;
  }
  else if (src_size != dst_width * dst_height * 3 ||
               dst_size != dst_width * dst_height * 4)
  {
    #ifdef PANIC
    *logofs << "UnpackBitmap: PANIC! Size mismatch with "
            << src_size << " bytes in the source and "
            << dst_size << " in the destination.\n"
            << logofs_flush;
    #endif

    return -1;
  }

  /*
   * Insert the 4th byte in the bitmap.
   */

  unsigned char *next_src = src_data;
  unsigned char *next_dst = dst_data;

  if (geometry -> image_byte_order == LSBFirst)
  {
    while (next_src < src_data + src_size)
    {
      *next_dst++ = *next_src++;
      *next_dst++ = *next_src++;
      *next_dst++ = *next_src++;

      next_dst++;
    }
  }
  else
  {
    while (next_src < src_data + src_size)
    {
      next_dst++;

      *next_dst++ = *next_src++;
      *next_dst++ = *next_src++;
      *next_dst++ = *next_src++;
    }
  }

  #ifdef TEST
  *logofs << "UnpackBitmap: Unpacked " << src_size
          << " bytes to a buffer of " << dst_size
          << " with " << dst_bpp << " bits per plane.\n"
          << logofs_flush;
  #endif

  return 1;
}