upconvert.h
上传用户:xjjlds
上传日期:2015-12-05
资源大小:22823k
文件大小:3k
源码类别:

多媒体编程

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2. *
  3. * $Id: upconvert.h,v 1.2 2005/01/30 05:11:40 gabest Exp $ $Name:  $
  4. *
  5. * Version: MPL 1.1/GPL 2.0/LGPL 2.1
  6. *
  7. * The contents of this file are subject to the Mozilla Public License
  8. * Version 1.1 (the "License"); you may not use this file except in compliance
  9. * with the License. You may obtain a copy of the License at
  10. * http://www.mozilla.org/MPL/
  11. *
  12. * Software distributed under the License is distributed on an "AS IS" basis,
  13. * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
  14. * the specific language governing rights and limitations under the License.
  15. *
  16. * The Original Code is BBC Research and Development code.
  17. *
  18. * The Initial Developer of the Original Code is the British Broadcasting
  19. * Corporation.
  20. * Portions created by the Initial Developer are Copyright (C) 2004.
  21. * All Rights Reserved.
  22. *
  23. * Contributor(s): Richard Felton (Original Author), Thomas Davies
  24. *
  25. * Alternatively, the contents of this file may be used under the terms of
  26. * the GNU General Public License Version 2 (the "GPL"), or the GNU Lesser
  27. * Public License Version 2.1 (the "LGPL"), in which case the provisions of
  28. * the GPL or the LGPL are applicable instead of those above. If you wish to
  29. * allow use of your version of this file only under the terms of the either
  30. * the GPL or LGPL and not to allow others to use your version of this file
  31. * under the MPL, indicate your decision by deleting the provisions above
  32. * and replace them with the notice and other provisions required by the GPL
  33. * or LGPL. If you do not delete the provisions above, a recipient may use
  34. * your version of this file under the terms of any one of the MPL, the GPL
  35. * or the LGPL.
  36. * ***** END LICENSE BLOCK ***** */
  37. #ifndef _UPCONVERT_H_
  38. #define _UPCONVERT_H_
  39. #include <libdirac_common/common.h>
  40. namespace dirac
  41. {
  42.     //Optimised upconversion class - no array resizes.
  43.     //Uses integer math - no floats!
  44.     //
  45.     //! Upconversion class
  46.     /*!
  47.         Class to upconvert data by a factor of 2 in both dimensions
  48.      */
  49.     class UpConverter
  50.     {
  51.     public:
  52.         //! Constructor
  53.         UpConverter(){}
  54.         //! Destructor
  55.         ~UpConverter(){};
  56.         //! Upconvert the picture data
  57.         /*!
  58.             Upconvert the picture data, where the parameters are
  59.             param    pic_data    is the original data
  60.             param    up_data    is the upconverted data
  61.          */
  62.         void DoUpConverter(const PicArray& pic_data, PicArray& up_data);
  63.     private:
  64.         //! Private body-less copy constructor: class should not be copied
  65.         UpConverter(const UpConverter& cpy);
  66.         //! Private body-less assignment: class should not be assigned
  67.         UpConverter& operator=(const UpConverter& rhs);
  68.         //! Applies the filter to a row and its successor 
  69.         void RowLoop(PicArray& up_data, const int row_num);
  70.     private:
  71.         //Variable to keep the loops in check
  72.         int xOld, yOld;
  73.         int xNew, yNew;
  74.         //Define first set of filter parameters
  75.         static const int Stage_I_Size = 6;
  76.         static const int StageI_I = 167;
  77.         static const int StageI_II = -56; 
  78.         static const int StageI_III = 25;
  79.         static const int StageI_IV = -11; 
  80.         static const int StageI_V = 4;
  81.         static const int StageI_VI = -1;    
  82.         static const int Stage_I_Shift = 8;
  83.     };
  84. } // namespace dirac
  85. #endif