rsmooth.h

Go to the documentation of this file.
00001 // $Id: rsmooth.h 1282 2006-06-09 09:46:49Z alex $
00002 /* @@tag:xara-cn@@ DO NOT MODIFY THIS LINE
00003 ================================XARAHEADERSTART===========================
00004  
00005                Xara LX, a vector drawing and manipulation program.
00006                     Copyright (C) 1993-2006 Xara Group Ltd.
00007        Copyright on certain contributions may be held in joint with their
00008               respective authors. See AUTHORS file for details.
00009 
00010 LICENSE TO USE AND MODIFY SOFTWARE
00011 ----------------------------------
00012 
00013 This file is part of Xara LX.
00014 
00015 Xara LX is free software; you can redistribute it and/or modify it
00016 under the terms of the GNU General Public License version 2 as published
00017 by the Free Software Foundation.
00018 
00019 Xara LX and its component source files are distributed in the hope
00020 that it will be useful, but WITHOUT ANY WARRANTY; without even the
00021 implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
00022 See the GNU General Public License for more details.
00023 
00024 You should have received a copy of the GNU General Public License along
00025 with Xara LX (see the file GPL in the root directory of the
00026 distribution); if not, write to the Free Software Foundation, Inc., 51
00027 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
00028 
00029 
00030 ADDITIONAL RIGHTS
00031 -----------------
00032 
00033 Conditional upon your continuing compliance with the GNU General Public
00034 License described above, Xara Group Ltd grants to you certain additional
00035 rights. 
00036 
00037 The additional rights are to use, modify, and distribute the software
00038 together with the wxWidgets library, the wxXtra library, and the "CDraw"
00039 library and any other such library that any version of Xara LX relased
00040 by Xara Group Ltd requires in order to compile and execute, including
00041 the static linking of that library to XaraLX. In the case of the
00042 "CDraw" library, you may satisfy obligation under the GNU General Public
00043 License to provide source code by providing a binary copy of the library
00044 concerned and a copy of the license accompanying it.
00045 
00046 Nothing in this section restricts any of the rights you have under
00047 the GNU General Public License.
00048 
00049 
00050 SCOPE OF LICENSE
00051 ----------------
00052 
00053 This license applies to this program (XaraLX) and its constituent source
00054 files only, and does not necessarily apply to other Xara products which may
00055 in part share the same code base, and are subject to their own licensing
00056 terms.
00057 
00058 This license does not apply to files in the wxXtra directory, which
00059 are built into a separate library, and are subject to the wxWindows
00060 license contained within that directory in the file "WXXTRA-LICENSE".
00061 
00062 This license does not apply to the binary libraries (if any) within
00063 the "libs" directory, which are subject to a separate license contained
00064 within that directory in the file "LIBS-LICENSE".
00065 
00066 
00067 ARRANGEMENTS FOR CONTRIBUTION OF MODIFICATIONS
00068 ----------------------------------------------
00069 
00070 Subject to the terms of the GNU Public License (see above), you are
00071 free to do whatever you like with your modifications. However, you may
00072 (at your option) wish contribute them to Xara's source tree. You can
00073 find details of how to do this at:
00074   http://www.xaraxtreme.org/developers/
00075 
00076 Prior to contributing your modifications, you will need to complete our
00077 contributor agreement. This can be found at:
00078   http://www.xaraxtreme.org/developers/contribute/
00079 
00080 Please note that Xara will not accept modifications which modify any of
00081 the text between the start and end of this header (marked
00082 XARAHEADERSTART and XARAHEADEREND).
00083 
00084 
00085 MARKS
00086 -----
00087 
00088 Xara, Xara LX, Xara X, Xara X/Xtreme, Xara Xtreme, the Xtreme and Xara
00089 designs are registered or unregistered trademarks, design-marks, and/or
00090 service marks of Xara Group Ltd. All rights in these marks are reserved.
00091 
00092 
00093       Xara Group Ltd, Gaddesden Place, Hemel Hempstead, HP2 6EX, UK.
00094                         http://www.xara.com/
00095 
00096 =================================XARAHEADEREND============================
00097  */
00098 // Contains class definitions for retrosmoothing functions
00099 
00100 /*
00101 */
00102 
00103 #ifndef INC_RETSMOOTH
00104 #define INC_RETSMOOTH
00105 
00106 //#include "selop.h" - in camtypes.h [AUTOMATICALLY REMOVED]
00107 //#include "doccoord.h" - in camtypes.h [AUTOMATICALLY REMOVED]
00108 
00109 #define SMOOTH_MAX (2000*2000)
00110 #define SMOOTH_MIN (256*256)
00111 
00112 #define OPTOKEN_RETROSMOOTH _T("RetroSmooth")
00113 
00114 
00115 //  define a region type to hold region start, end values
00116 
00117 struct Set {
00118     INT32 first;
00119     BOOL Finclusive;
00120     INT32 last;
00121     BOOL Linclusive;
00122 };
00123 
00124 #define ITEM_TYPE Set
00125 
00126 class NodePath;
00127 
00128 /******************************************************************************
00129 
00130     class DynArray
00131 
00132     Author:     Mike_Kenny (Xara Group Ltd) <camelotdev@xara.com>
00133     Created:    16/11/94
00134     Purpose:    A temporary class to control a dynamic array of doccoords.
00135                 This will be replaced by a template class whenever we can
00136                 use the template directive.
00137     
00138 ******************************************************************************/
00139 
00140 class DynArray {
00141 
00142     public:
00143         DynArray();
00144         ~DynArray();
00145         BOOL        Initialise(INT32 inititems, INT32 newitems);
00146         ITEM_TYPE*  GetFirstItem();
00147         INT32       NumItems() { return UsedSlots; };
00148         BOOL        AddItem(ITEM_TYPE&);
00149         void        DeleteItems(INT32 firstitem, INT32 numitems);
00150         void        Empty(BOOL compress=TRUE);
00151         ITEM_TYPE&  operator[](const INT32 i);
00152         void        Compact();
00153         BOOL        CloneFrom(DynArray* SourceArray);
00154 
00155     private:
00156         BOOL    MakeSpaceInList(const INT32 numitems);
00157 
00158     private:
00159         MHANDLE BlockHandle;
00160 
00161         INT32   UsedSlots;
00162         INT32   UnusedSlots;
00163         INT32   SlotInitSize;
00164         INT32   SlotAllocSize;
00165 
00166 };
00167 
00168 
00169 /******************************************************************************
00170 
00171 > class RetroSmooth
00172 
00173     Author:     Mike_Kenny (Xara Group Ltd) <camelotdev@xara.com>
00174     Created:    11/11/94
00175     Purpose:    A new class to control retro smoothing of path regions.
00176 
00177 ******************************************************************************/
00178 
00179 class RetroSmooth
00180 {
00181     public:
00182         RetroSmooth();
00183         BOOL    Initialise();
00184         void    Changing(NodePath* pNodePath, Spread* pSpread, double smooth);
00185         void    Finished();
00186         void    Invalidate();
00187         double  ReturnCachedAccuracy(Path* pPath);
00188 
00189         // non-undoable version of finished. does not launch an operation
00190         BOOL    FinishedNoUndo(NodePath* pNodePath);
00191         void    SetRenderFlag(BOOL Render);
00192     private:
00193         BOOL    Starting(NodePath* pDocNodePath);
00194         void    Update();
00195         BOOL    RenderRegions();
00196         BOOL    NewPathToSmooth(NodePath* pNodePath);
00197         BOOL    MatchRegions(NodePath* pNodePath);
00198         BOOL    RecordPathRegions(Path* pPath);
00199         void    AlterRegion(INT32 index, INT32 newstart, INT32 newend);
00200         INT32   FindMasterRegion();
00201         void    TranslateRetroData(Path* pPath);
00202 
00203     private:
00204         BOOL        RetroSmoothing;
00205         NodePath*   pRetroNode;             // a pointer to the current 'retro' node
00206         Spread*     pRetroSpread;
00207         Path        RetroPath;              // the original path points we need
00208         Path        RetroEorPath;           // the current path points after smoothing
00209         DynArray    RetroEorRegion;         // the working path regions
00210         double      RetroSmoothPercent;     // the current cached percentage
00211         double      RetroSmoothAcc;         // the current retro smoothing accurary
00212         INT32       RetroPathCRC;           // cyclic reduncancy for the EorPath
00213         INT32       RetroSelCRC;            // cyclic redundancy for the Selected points
00214 
00215         BOOL        m_bRender;              // flag to say whether or not we should do EOR rendering
00216 };
00217 
00218 
00219 /********************************************************************************************
00220 
00221 >   class OpRetroSmooth : public SelOperation
00222 
00223     Author:     Mike_Kenny (Xara Group Ltd) <camelotdev@xara.com>
00224     Created:    7/10/94
00225     Purpose:    
00226 
00227 ********************************************************************************************/
00228 
00229 class OpRetroSmooth : public SelOperation
00230 {
00231 
00232 CC_DECLARE_DYNCREATE(OpRetroSmooth)
00233 
00234 public:
00235     OpRetroSmooth();
00236     static BOOL     Init();             
00237     static OpState  GetState(String_256*, OpDescriptor*);       
00238     void            GetOpName(String_256* OpName);
00239     void            DoRetroSmooth(NodePath* pNode, Path* pPath, double smoothacc);
00240 };
00241 
00242 
00243 #endif

Generated on Sat Nov 10 03:46:46 2007 for Camelot by  doxygen 1.4.4