00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075 #ifndef INC_MI32_GEOFRMLA_H
00076 #define INC_MI32_GEOFRMLA_H
00077
00078 #ifndef INC_SML
00079 #include <mi32/sml.h>
00080 #endif
00081
00082 #ifndef INC_RVC_TIN_H
00083 #include <rvc/tin.h>
00084 #endif
00085
00086 #ifndef INC_RVC_VECTOR_H
00087 #include <rvc/vector.h>
00088 #endif
00089
00090 #ifndef INC_MI32_RINTERP_H
00091 #include <mi32/rinterp.h>
00092 #endif
00093
00094 #ifndef INC_MI32_SERIALIZ_H
00095 #include <mi32/serializ.h>
00096 #endif
00097
00098
00099
00100 class GEOFORMULA {
00101 public:
00102
00103
00104
00105 enum OUTPUTTYPE {
00106 OUTPUTTYPE_Numeric = 0,
00107 OUTPUTTYPE_Color = 1
00108 };
00109
00110
00111
00112 enum EXTENTSMODE {
00113 EXTENTSMODE_UserDefined = 0,
00114 EXTENTSMODE_Intersection = 1,
00115 EXTENTSMODE_Union = 2,
00116 EXTENTSMODE_Region = 3
00117 };
00118
00119 enum SCRIPTFLAGS {
00120 SCRIPTFLAG_None = 0x00,
00121 SCRIPTFLAG_AllSymbols = 0x01,
00122 SCRIPTFLAG_NoParse = 0x02
00123 };
00124
00125
00126 class EDITOR;
00127
00128
00129 class OBJECT {
00130 public:
00131
00132
00133 OBJECT (
00134 );
00135
00136
00137 OBJECT (
00138 const OBJECT& rhs
00139 );
00140
00141
00142 virtual ~OBJECT (
00143 ) = 0;
00144
00145
00146 OBJECT& operator= (
00147 const OBJECT& rhs
00148 );
00149
00150 virtual ERRVALUE AddSymbols (
00151 GEOFORMULA& formula,
00152 bool OnlyIfUsed = true
00153 );
00154
00155 virtual void ClearSymbols (
00156 );
00157
00158 virtual void Close (
00159 );
00160
00161 const RVCGENINFO& GetInfo (
00162 ) const { return (m_objitem.GetInfo()); }
00163
00164 RVCINODENUM GetInode (
00165 ) const { return (m_objitem.GetInode()); }
00166
00167 const RVC::OBJITEM& GetObjectItem (
00168 ) const { return (m_objitem); }
00169
00170 const FILEPATH& GetPath (
00171 ) const { return (m_objitem.GetFilePath()); }
00172
00173 const SPATREF::COORDREFSYS& GetCoordRefSys (
00174 ) const { return (GetMapRegion().GetCoordRefSys()); }
00175
00176 const REGION2D& GetMapRegion (
00177 ) const { return (m_MapRegion); }
00178
00179 const REGION2D& GetObjRegion (
00180 ) const { return (m_ObjRegion); }
00181
00182 const MISTRING& GetSymbolName (
00183 ) const { return (m_SymbolName); }
00184
00185 virtual ERRVALUE Open (
00186 );
00187
00188 protected:
00189
00190 MISTRING m_SymbolName;
00191 RVCFILEHANDLE m_fhandle;
00192 SMLSYMBOL *m_symobj;
00193 SIMPLE_ARRAY<DPOINT2D> m_pointbuf;
00194
00195
00196 OBJECT (
00197 const RVCOBJITEM& objitem
00198 );
00199
00200
00201 OBJECT (
00202 int objtype,
00203 INIHANDLE handle,
00204 int objnum
00205 );
00206
00207
00208 OBJECT (
00209 int objtype,
00210 const MISTRING& SymbolName,
00211 const FILEPATH& FilePath,
00212 INT32 ObjectInode
00213 );
00214
00215 virtual ERRVALUE SetObjPoint (
00216 int idx
00217 );
00218
00219 virtual void WriteDefn (
00220 INIHANDLE handle,
00221 int objnum
00222 ) const;
00223
00224 private:
00225 #ifndef GENERATING_DOXYGEN_OUTPUT
00226
00227 SMLSYMBOL *m_symx;
00228 SMLSYMBOL *m_symy;
00229 MAT3X3 m_fwd, m_inv;
00230 bool m_IsAffine;
00231
00232 RVCOBJITEM m_objitem;
00233 REGION2D m_ObjRegion;
00234 REGION2D m_MapRegion;
00235 TRANS2D_MAPGEN m_trans;
00236
00237 ERRVALUE CalcObjPoints (
00238 const GEOFORMULA& formula,
00239 const DPOINT2D& start,
00240 const DPOINT2D& inc,
00241 INT32 numvals
00242 );
00243
00244 ERRVALUE SetupTrans (
00245 GEOFORMULA& formula
00246 );
00247
00248 friend class GEOFORMULA;
00249 #endif // GENERATING_DOXYGEN_OUTPUT
00250 };
00251
00252
00253
00254 class RASTER : public OBJECT {
00255 public:
00256
00257
00258 RASTER (
00259 const RASTER& rhs
00260 );
00261
00262
00263 virtual ~RASTER (
00264 );
00265
00266
00267 RASTER& operator= (
00268 const RASTER& rhs
00269 );
00270
00271 virtual ERRVALUE AddSymbols (
00272 GEOFORMULA& formula,
00273 bool OnlyIfUsed = true
00274 );
00275
00276 virtual void ClearSymbols (
00277 );
00278
00279 virtual void Close (
00280 );
00281
00282 virtual ERRVALUE Open (
00283 );
00284
00285 void SetContrastType (
00286 UINT8 conttype
00287 ) { m_conttype = conttype; }
00288
00289 void SetContrastUseTable (
00290 bool contusetable
00291 ) { m_contusetable = contusetable; }
00292
00293 private:
00294 #ifndef GENERATING_DOXYGEN_OUTPUT
00295
00296 enum DATATYPE {
00297 DATATYPE_RasterNumeric = 0,
00298 DATATYPE_RasterColor = 1,
00299 DATATYPE_RasterComplex = 2
00300 };
00301
00302 RVCRASTINFO m_objinfo;
00303 DATATYPE m_datatype;
00304 UINT8 m_interpmode;
00305 UINT8 m_conttype;
00306 bool m_contusetable;
00307 int m_ohandle;
00308 RASTINTERPHANDLE m_interphandle;
00309 SMLSYMBOL *m_symval;
00310 SMLSYMBOL *m_symred;
00311 SMLSYMBOL *m_symgreen;
00312 SMLSYMBOL *m_symblue;
00313 CONTPARM m_contparm;
00314 bool m_NeedValue;
00315 bool m_DoContrast;
00316
00317
00318 RASTER (
00319 const FILEPATH& filepath,
00320 const RVCRASTINFO& objinfo
00321 );
00322
00323
00324 RASTER (
00325 INIHANDLE handle,
00326 int objnum
00327 );
00328
00329
00330 RASTER (
00331 const MISTRING& SymbolName,
00332 const FILEPATH& FilePath,
00333 INT32 ObjectInode
00334 );
00335
00336 ERRVALUE SerialWrite (
00337 SERIALIZER& serializer
00338 );
00339 #endif // GENERATING_DOXYGEN_OUTPUT
00340
00341 virtual ERRVALUE SetObjPoint (
00342 int idx
00343 );
00344
00345 virtual void WriteDefn (
00346 INIHANDLE handle,
00347 int objnum
00348 ) const;
00349
00350 friend class GEOFORMULA;
00351 friend class EDITOR;
00352 };
00353
00354
00355
00356 class VECTOR : public OBJECT {
00357 public:
00358
00359
00360 VECTOR (
00361 );
00362
00363
00364 VECTOR (
00365 const VECTOR& rhs
00366 );
00367
00368
00369 virtual ~VECTOR (
00370 );
00371
00372
00373 VECTOR& operator= (
00374 const VECTOR& rhs
00375 );
00376
00377 virtual ERRVALUE AddSymbols (
00378 GEOFORMULA& formula,
00379 bool OnlyIfUsed = true
00380 );
00381
00382 virtual void Close (
00383 );
00384
00385 virtual ERRVALUE Open (
00386 );
00387
00388 private:
00389 #ifndef GENERATING_DOXYGEN_OUTPUT
00390
00391 RVC::VECTOR m_VectObj;
00392
00393
00394 VECTOR (
00395 const FILEPATH& filepath,
00396 const RVCVECTINFO& objinfo
00397 );
00398
00399
00400 VECTOR (
00401 INIHANDLE handle,
00402 int objnum
00403 ):
00404 OBJECT(OTYPE_VECTOR,handle,objnum)
00405 { }
00406
00407
00408 VECTOR (
00409 const MISTRING& SymbolName,
00410 const FILEPATH& FilePath,
00411 INT32 ObjectInode
00412 );
00413
00414 ERRVALUE SerialWrite (
00415 SERIALIZER& serializer
00416 );
00417 #endif // GENERATING_DOXYGEN_OUTPUT
00418
00419 virtual ERRVALUE SetObjPoint (
00420 int idx
00421 );
00422
00423 virtual void WriteDefn (
00424 INIHANDLE handle,
00425 int objnum
00426 ) const;
00427
00428 friend class GEOFORMULA;
00429 };
00430
00431
00432
00433 class TIN : public OBJECT {
00434 public:
00435
00436
00437 TIN (
00438 );
00439
00440
00441 TIN (
00442 const TIN& rhs
00443 );
00444
00445
00446 virtual ~TIN (
00447 );
00448
00449
00450 TIN& operator= (
00451 const TIN& rhs
00452 );
00453
00454 virtual ERRVALUE AddSymbols (
00455 GEOFORMULA& formula,
00456 bool OnlyIfUsed = true
00457 );
00458
00459 virtual void ClearSymbols (
00460 );
00461
00462 virtual void Close (
00463 );
00464
00465 virtual ERRVALUE Open (
00466 );
00467
00468 private:
00469 #ifndef GENERATING_DOXYGEN_OUTPUT
00470
00471 RVC::TIN m_TinObj;
00472 SMLSYMBOL *m_symval;
00473
00474
00475 TIN (
00476 const FILEPATH& filepath,
00477 const RVCTININFO& objinfo
00478 );
00479
00480
00481 TIN (
00482 INIHANDLE handle,
00483 int objnum
00484 ):
00485 OBJECT(OTYPE_TIN,handle,objnum)
00486 { }
00487
00488
00489 TIN (
00490 const MISTRING& SymbolName,
00491 const FILEPATH& FilePath,
00492 INT32 ObjectInode
00493 );
00494
00495 ERRVALUE SerialWrite (
00496 SERIALIZER& serializer
00497 );
00498 #endif // GENERATING_DOXYGEN_OUTPUT
00499
00500 virtual ERRVALUE SetObjPoint (
00501 int idx
00502 );
00503
00504 virtual void WriteDefn (
00505 INIHANDLE handle,
00506 int objnum
00507 ) const;
00508
00509 friend class GEOFORMULA;
00510 };
00511
00512
00513
00514 class VALUE {
00515 public:
00516
00517 VALUE (
00518 );
00519
00520 VALUE (
00521 const VALUE& rhs
00522 );
00523
00524 virtual ~VALUE (
00525 ) {
00526 }
00527
00528 VALUE& operator= (
00529 const VALUE& rhs
00530 );
00531
00532 void ClearSymbol (
00533 ) { m_Symbol = 0; }
00534
00535 void CreateSymbol (
00536 SMLCONTEXT *context
00537 ) {
00538 m_Symbol = context->AddSymbol(m_SymbolName,STYPE_Constant);
00539 m_Symbol->SetValue(m_UserValue);
00540 return;
00541 }
00542
00543 double GetDefaultValue (
00544 ) const { return (m_DefaultValue); }
00545
00546 const MISTRING& GetSymbolName (
00547 ) const { return (m_SymbolName); }
00548
00549 void SetDefaultValue (
00550 double value
00551 ) { m_DefaultValue = m_UserValue = value; }
00552
00553 void SetSymbolName (
00554 const UNICODE* SymbolName
00555 ) { m_SymbolName = SymbolName; }
00556
00557 void SetUserValue (
00558 double value
00559 ) { m_UserValue = value; }
00560
00561 virtual void WriteDefn (
00562 INIHANDLE handle,
00563 int idx
00564 ) const;
00565
00566 private:
00567 #ifndef GENERATING_DOXYGEN_OUTPUT
00568
00569 MISTRING m_SymbolName;
00570 double m_DefaultValue;
00571 double m_UserValue;
00572 SMLSYMBOL *m_Symbol;
00573
00574
00575 VALUE (
00576 INIHANDLE handle,
00577 int valnum
00578 );
00579
00580
00581 VALUE (
00582 const UNICODE *name,
00583 double dftvalue
00584 );
00585
00586 static const SERIALIZER::ITEMDEF* SerialGetItemDef ();
00587
00588 ERRVALUE SerialRead (
00589 SERIALIZER& serializer
00590 ) { return (serializer.Read(SerialGetItemDef(),this)); }
00591
00592 ERRVALUE SerialWrite (
00593 SERIALIZER& serializer
00594 ) { return (serializer.Write("VALUE",SerialGetItemDef(),this)); }
00595
00596 #endif // GENERATING_DOXYGEN_OUTPUT
00597 friend class GEOFORMULA;
00598 friend class EDITOR;
00599 };
00600
00601
00602
00603 #ifndef WIN32_NATIVE
00604 class EDITOR {
00605 public:
00606
00607
00608 explicit EDITOR (
00609 GEOFORMULA& formula
00610 );
00611
00612
00613 ~EDITOR (
00614 ) {
00615 }
00616
00617 bool CheckValid (
00618 Widget pageform,
00619 int scriptpage
00620 );
00621
00622 Widget CreateFormExtents (
00623 Widget pwidget,
00624 Arg *arglist,
00625 int argcount
00626 );
00627
00628 void CreatePageObjects (Widget);
00629
00630 void CreatePageValues (Widget);
00631
00632 void CreatePageScript (Widget);
00633
00634 void DisableUpdateContext (
00635 ) { ++m_UpdateContextDisabled; }
00636
00637 void EnableUpdateContext (
00638 ) { if (m_UpdateContextDisabled) --m_UpdateContextDisabled; }
00639
00640 SMLEDITOR* GetScriptEditHandle (
00641 ) const {
00642 return (m_qehandle);
00643 }
00644
00645 const MISTRING& GetScript (
00646 ) const;
00647
00648 void* GetTextEditHandle (
00649 ) const {
00650 return (m_tehandle);
00651 }
00652
00653 bool IsChanged (
00654 ) const { return (m_IsChanged); }
00655
00656 int Reset (
00657 );
00658
00659 ERRVALUE SelectExtentsRegion (
00660 );
00661
00662 void SetChanged (
00663 bool ischanged = true
00664 ) { m_IsChanged = ischanged; }
00665
00666 void SetMsgLine (
00667 Widget MsgLine
00668 );
00669
00670 void ShowAllDetails (
00671 );
00672
00673 void ShowObjListDetails (
00674 bool show = true
00675 );
00676
00677 void ShowValListDetails (
00678 bool show = true
00679 );
00680
00681 int UpdateObjects (
00682 );
00683
00684 void UpdateScriptContext (
00685 bool doinit
00686 );
00687
00688 private:
00689 #ifndef GENERATING_DOXYGEN_OUTPUT
00690
00691 struct OBJINFO {
00692
00693 EDITOR& m_editor;
00694 OBJECT& m_object;
00695 Widget m_form;
00696 Widget m_DetailsTB;
00697 Widget m_SymbolP;
00698 Widget m_ObjectLabel;
00699 Widget m_detform;
00700 Widget m_conttypeOM;
00701 Widget m_usecontabTB;
00702 UNICODE m_symname[32];
00703
00704 OBJINFO (
00705 EDITOR& editor,
00706 OBJECT& object
00707 ):
00708 m_editor(editor),
00709 m_object(object)
00710 {
00711 }
00712 };
00713
00714 struct VALINFO {
00715
00716 EDITOR& m_editor;
00717 VALUE& m_value;
00718 Widget m_form;
00719 Widget m_SymbolP;
00720 Widget m_detform;
00721 UNICODE m_symname[32];
00722
00723 VALINFO (
00724 EDITOR& editor,
00725 VALUE& value
00726 ):
00727 m_editor(editor),
00728 m_value(value)
00729 {
00730 }
00731 };
00732
00733 GEOFORMULA& m_Formula;
00734 Widget m_Shell;
00735 Widget m_MsgLine;
00736 Widget m_ObjectsPage;
00737 Widget m_ObjectsRC;
00738 Widget m_ShowObjListDetailsTB;
00739 Widget m_ValuesPage;
00740 Widget m_ValuesRC;
00741 Widget m_ShowValListDetailsTB;
00742 Widget m_ScriptPage;
00743 Widget m_ScriptXeT;
00744 Widget m_ExtentsOM;
00745 Widget m_ExtentsRegionPB;
00746 Widget m_ExtentsRegionXeT;
00747 void *m_tehandle;
00748 SMLEDITOR *m_qehandle;
00749 bool m_IsChanged;
00750 bool m_HasRaster;
00751 bool m_ShowObjListDetails;
00752 bool m_ShowValListDetails;
00753 UINT32 m_UpdateContextDisabled;
00754 UNICODE m_NewValueName[16];
00755 double m_NewValueDefault;
00756
00757 MILIST<OBJINFO> m_ObjInfoList;
00758 MILIST<VALINFO> m_ValInfoList;
00759 REGION2D m_MapRegionUnion;
00760 REGION2D m_MapRegionIntersection;
00761
00762 static void CB_AddValue (Widget, void*, void*);
00763 static void CB_OptionExtentsMode (Widget, void*, void*);
00764 static void CB_OptionRastContType (Widget, void*, void*);
00765 static void CB_SelectExtentsRegion (Widget, void*, void*);
00766 static void CB_ToggleRastContUseTab (Widget, void*, XmToggleButtonCallbackStruct*);
00767
00768 static MENUITEM* GetMenuOptionContrast ();
00769 static MENUITEM* GetMenuOptionExtentsMode ();
00770
00771 static void PCB_ChangeObjectSymbolName (
00772 MxPromptCallbackStruct *cbs,
00773 void *vobjinfo
00774 );
00775
00776 static void PCB_ChangeValueSymbolName (
00777 MxPromptCallbackStruct *cbs,
00778 void *vobjinfo
00779 );
00780
00781 static bool NewValueCheckOK (
00782 void *veditor
00783 );
00784
00785 static Widget NewValueCreateForm (
00786 Widget pwidget,
00787 void *veditor,
00788 Arg *arglist,
00789 int argcount
00790 );
00791
00792 void ClearMessage (
00793 ) const {
00794 MxMsgLineClear(m_MsgLine);
00795 return;
00796 }
00797
00798 void CreateObjectForm (
00799 OBJECT& obj,
00800 const char *IconName
00801 );
00802
00803 void CreateValueForm (
00804 VALUE& val
00805 );
00806
00807 void SetSensitive () const;
00808
00809 EDITOR (const EDITOR&);
00810 EDITOR& operator= (const EDITOR&);
00811 #endif
00812
00813 friend class GEOFORMULA;
00814 };
00815 #endif
00816
00817
00818
00819 GEOFORMULA (
00820 );
00821
00822
00823 GEOFORMULA (
00824 const GEOFORMULA& rhs
00825 );
00826
00827
00828 ~GEOFORMULA (
00829 );
00830
00831 GEOFORMULA& operator= (
00832 const GEOFORMULA& rhs
00833 );
00834
00835
00836 static int FilterObject (
00837 int fhandle,
00838 INT32 objinode,
00839 RVCGENINFO *geninfo,
00840 void *,
00841 char *msgkey
00842 );
00843
00844
00845 ERRVALUE AddValue (
00846 const UNICODE *SymbolName,
00847 double value
00848 );
00849
00850
00851 ERRVALUE CreateFromObjects (
00852 const RVCOBJITEMLIST& objitems
00853 );
00854
00855
00856 ERRVALUE DlgSelectExtentsRegion (
00857 MDLGPARENT dlgparent,
00858 const REGION2D *testregion = 0
00859 );
00860
00861
00862 ERRVALUE DlgSelectObjects (
00863 MDLGPARENT dlgparent
00864 );
00865
00866
00867 ERRVALUE Evaluate (
00868 const DPOINT2D& start,
00869 const DPOINT2D& increment,
00870 INT32 numvals,
00871 void *buffer,
00872 UINT8 *omask
00873 );
00874
00875
00876 const REGION2D& GetExtMapRegion (
00877 ) const { return (m_ExtMapRegion); }
00878
00879
00880 ERRVALUE GetFirstObjectCoordRefSys (
00881 SPATREF::COORDREFSYS& CoordRefSys
00882 ) const;
00883
00884
00885 ERRVALUE GetMinRasterCellSize (
00886 double& MinCellSize
00887 ) const;
00888
00889
00890 int GetNumObjects (
00891 ) const {
00892 return (m_Rasters.GetNumItems() + m_Vectors.GetNumItems() + m_TINs.GetNumItems());
00893 }
00894
00895
00896 const MILIST<RASTER>& GetObjectListRaster (
00897 ) const {
00898 return (m_Rasters);
00899 }
00900
00901
00902 const MILIST<TIN>& GetObjectListTIN (
00903 ) const {
00904 return (m_TINs);
00905 }
00906
00907
00908 const MILIST<VECTOR>& GetObjectListVector (
00909 ) const {
00910 return (m_Vectors);
00911 }
00912
00913
00914 OUTPUTTYPE GetOutputType (
00915 ) const {
00916 return (m_OutputType);
00917 }
00918
00919
00920 const MISTRING& GetScript (
00921 ) const {
00922 return (m_Script);
00923 }
00924
00925
00926 ERRVALUE GetTransToExtCRS (
00927 TRANS2D_MAPGEN& Trans,
00928 bool dooutput = false
00929 ) const;
00930
00931
00932 ERRVALUE OpenObjects (
00933 );
00934
00935
00936 ERRVALUE ReadDefn (
00937 const FILEPATH& filepath
00938 );
00939
00940
00941 ERRVALUE SerialRead (
00942 SERIALIZER& serializer
00943 );
00944
00945
00946 ERRVALUE SerialWrite (
00947 SERIALIZER& serializer,
00948 const char *tagname = 0
00949 );
00950
00951
00952 void SetExtMapCoordRefSys (
00953 const SPATREF::COORDREFSYS& CoordRefSys
00954 ) { m_ExtMapRegion.SetCoordRefSys(CoordRefSys); m_Trans.SetOutputMapCoordRefSys(CoordRefSys); }
00955
00956
00957 void SetOutputCoordRefSys (
00958 const SPATREF::COORDREFSYS& CoordRefSys
00959 ) { m_Trans.SetInputMapCoordRefSys(CoordRefSys); }
00960
00961
00962 void SetOutputTrans (
00963 const MAT3X3 fwd,
00964 const MAT3X3 inv
00965 ) { m_Trans.SetInputTrans(fwd,inv); }
00966
00967
00968 void SetOutputTrans (
00969 const TRANS2D_AFFINE& trans
00970 ) { m_Trans.SetInputTrans(trans); }
00971
00972
00973 void SetOutputTrans (
00974 const TRANSPARM& transparm
00975 ) { m_Trans.CopyOutputToInput(transparm); }
00976
00977
00978 void SetOutputTrans (
00979 const TRANS2D_MAPGEN& trans
00980 ) { m_Trans.CopyOutputToInput(trans); }
00981
00982
00983 void SetOutputTransIdentity (
00984 ) { m_Trans.SetInputTransIdentity(); }
00985
00986
00987 void SetOutputType (
00988 OUTPUTTYPE OutputType
00989 ) { m_OutputType = OutputType; }
00990
00991
00992 void SetScript (
00993 const UNICODE* script
00994 ) { m_Script = script; }
00995
00996
00997 ERRVALUE Start (
00998 const DRECT2D *extents,
00999 SCRIPTFLAGS flags = SCRIPTFLAG_None
01000 );
01001
01002
01003 void Stop (
01004 );
01005
01006
01007 ERRVALUE WriteDefn (
01008 const FILEPATH& filepath
01009 );
01010
01011 private:
01012 #ifndef GENERATING_DOXYGEN_OUTPUT
01013
01014 OUTPUTTYPE m_OutputType;
01015 EXTENTSMODE m_ExtentsMode;
01016 INT32 m_RegionInode;
01017 SMLCONTEXT *m_Context;
01018 int m_Segment;
01019 SMLSYMBOL *m_symred;
01020 SMLSYMBOL *m_symgreen;
01021 SMLSYMBOL *m_symblue;
01022 bool m_AllAffine;
01023 #ifndef WIN32_NATIVE
01024 EDITOR *m_editor;
01025 #endif
01026
01027 MILIST<RASTER> m_Rasters;
01028 MILIST<VECTOR> m_Vectors;
01029 MILIST<TIN> m_TINs;
01030 MILIST<VALUE> m_Values;
01031 MISTRING m_Script;
01032 FILEPATH m_RegionFilePath;
01033 REGION2D m_ExtMapRegion;
01034 TRANS2D_MAPGEN m_Trans;
01035 SIMPLE_ARRAY<DPOINT2D> m_ipointbuf;
01036
01037 static const SERIALIZER::ITEMDEF* SerialGetItemDef ();
01038 static ERRVALUE SerializerCB_Object (SERIALIZER&, const SERIALIZER::ITEMDEF*, void*, SERIALIZER::ITEMDEF::ACTION);
01039 static ERRVALUE SerializerCB_Value (SERIALIZER&, const SERIALIZER::ITEMDEF*, void*, SERIALIZER::ITEMDEF::ACTION);
01040
01041 ERRVALUE AddObjectRegion (
01042 const OBJECT& object
01043 );
01044
01045 SMLSYMBOL* AddSymbol (
01046 const MISTRING& basename,
01047 const char* subname,
01048 bool OnlyIfUsed
01049 );
01050
01051 void Clear ();
01052
01053 void Copy (
01054 const GEOFORMULA& rhs
01055 );
01056
01057 OBJECT* FindObjectByName (
01058 const UNICODE *symname
01059 );
01060
01061 const VALUE* FindValueByName (
01062 const UNICODE *symname
01063 ) const;
01064
01065 const OBJECT* GetFirstObject () const;
01066
01067 int GetNumNameUses (const MISTRING& symname) const;
01068
01069 ERRVALUE InitQuery (
01070 SCRIPTFLAGS flags = SCRIPTFLAG_None
01071 );
01072
01073
01074 bool SetObjectSymbolName (
01075 OBJECT& obj,
01076 const UNICODE *symname
01077 );
01078
01079
01080 bool SetValueSymbolName (
01081 VALUE& obj,
01082 const UNICODE *symname
01083 );
01084
01085 void StopQuery ();
01086 #endif
01087
01088 friend class EDITOR;
01089 friend class OBJECT;
01090 friend class RASTER;
01091 friend class VECTOR;
01092 friend class TIN;
01093 };
01094
01095 DEFINE_ENUM_OPERATORS(GEOFORMULA::SCRIPTFLAGS);
01096
01097 #endif