G3Encoder.h
上传用户:weiyuanprp
上传日期:2020-05-20
资源大小:1169k
文件大小:2k
源码类别:

传真(Fax)编程

开发平台:

C/C++

  1. /* $Id: G3Encoder.h,v 1.1.1.1 2005/11/11 21:32:02 faxguy Exp $ */
  2. /*
  3.  * Copyright (c) 1994-1996 Sam Leffler
  4.  * Copyright (c) 1994-1996 Silicon Graphics, Inc.
  5.  * HylaFAX is a trademark of Silicon Graphics
  6.  *
  7.  * Permission to use, copy, modify, distribute, and sell this software and 
  8.  * its documentation for any purpose is hereby granted without fee, provided
  9.  * that (i) the above copyright notices and this permission notice appear in
  10.  * all copies of the software and related documentation, and (ii) the names of
  11.  * Sam Leffler and Silicon Graphics may not be used in any advertising or
  12.  * publicity relating to the software without the specific, prior written
  13.  * permission of Sam Leffler and Silicon Graphics.
  14.  * 
  15.  * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, 
  16.  * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY 
  17.  * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.  
  18.  * 
  19.  * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
  20.  * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
  21.  * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
  22.  * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF 
  23.  * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE 
  24.  * OF THIS SOFTWARE.
  25.  */
  26. #ifndef _G3Encoder_
  27. #define _G3Encoder_
  28. /*
  29.  * Group 3 Facsimile Encoder Support.
  30.  */
  31. #include "Types.h"
  32. class fxStackBuffer;
  33. struct tableentry;
  34. class G3Encoder {
  35. private:
  36.     bool is2D; // data is to be 1d/2d-encoded
  37.     bool isG4; // data is to be G4-encoded
  38.     bool firstEOL; // first EOL is not byte-aligned
  39.     const u_char* bitmap; // bit reversal table
  40.     short data; // current input/output byte
  41.     short bit; // current bit in input/output byte
  42.     fxStackBuffer& buf;
  43.     static const u_char zeroruns[256];
  44.     static const u_char oneruns[256];
  45.     static int findspan(const u_char**, int, int, const u_char*);
  46.     static int find0span(const u_char*, int, int);
  47.     static int find1span(const u_char*, int, int);
  48.     static int finddiff(const u_char*, int, int, int);
  49.     void putBits(u_int bits, u_int length);
  50.     void putcode(const tableentry& te);
  51.     void putspan(int span, const tableentry* tab);
  52.     void flushBits();
  53. public:
  54.     G3Encoder(fxStackBuffer&);
  55.     virtual ~G3Encoder();
  56.     void setupEncoder(u_int fillOrder, bool, bool);
  57.     void encode(const void* raster, u_int w, u_int h, u_char* rp = NULL);
  58.     void encoderCleanup();
  59. };
  60. #endif /* _G3Encoder_ */