From c6fb5f93836cc7019e6751089adf3c9c64dfe5bd Mon Sep 17 00:00:00 2001 From: Daveo Date: Tue, 20 Mar 2001 23:06:17 +0000 Subject: [PATCH] --- Utils/MapEdit/LayerThing.cpp | 318 +++++++++++++++++++++++++++++++++++ Utils/MapEdit/LayerThing.h | 76 +++++++++ 2 files changed, 394 insertions(+) create mode 100644 Utils/MapEdit/LayerThing.cpp create mode 100644 Utils/MapEdit/LayerThing.h diff --git a/Utils/MapEdit/LayerThing.cpp b/Utils/MapEdit/LayerThing.cpp new file mode 100644 index 000000000..18ec40761 --- /dev/null +++ b/Utils/MapEdit/LayerThing.cpp @@ -0,0 +1,318 @@ +/******************/ +/*** Layer Elem ***/ +/******************/ + + +#include "stdafx.h" +#include +#include +#include +#include "GLEnabledView.h" + +#include "MapEdit.h" +#include "MapEditDoc.h" +#include "MapEditView.h" +#include "MainFrm.h" + +//#include "ElemSet.h" + +#include "Core.h" +#include "Layer.h" +#include "LayerElem.h" +#include "Utils.h" +//#include "Select.h" +#include "Export.h" + +/*****************************************************************************/ +/*****************************************************************************/ +/*****************************************************************************/ +// New Layer +CLayerElem::CLayerElem(int _SubType,int _Width,int _Height) +{ + SetDefaultParams(); + + Mode=MouseModePaint; +// ElemBank=new CElemBank; + +} + +/*****************************************************************************/ +// Load Layer +CLayerElem::CLayerElem(CFile *File,int Version) +{ + Load(File,Version); +} + +/*****************************************************************************/ +CLayerElem::~CLayerElem() +{ +// ElemBank->CleanUp(); +// delete ElemBank; +} + +/*****************************************************************************/ +void CLayerElem::Load(CFile *File,int Version) +{ + File->Read(&VisibleFlag,sizeof(BOOL)); + File->Read(&Mode,sizeof(MouseMode)); + + TRACE1("%s\t",GetName()); +} + +/*****************************************************************************/ +void CLayerElem::Save(CFile *File) +{ +// Always Save current version + File->Write(&VisibleFlag,sizeof(BOOL)); + File->Write(&Mode,sizeof(MouseMode)); +} + +/*****************************************************************************/ +void CLayerElem::InitSubView(CCore *Core) +{ + ElemBank=&Core->GetIconz(); +} + +/*****************************************************************************/ +/*****************************************************************************/ +/*****************************************************************************/ +void CLayerElem::Render(CCore *Core,Vector3 &CamPos,bool Is3d) +{ +Vector3 ThisCam=Core->OffsetCam(CamPos,GetScaleFactor()); + + Is3d&=Render3dFlag; + for (int x=0; x<20; x++) + { + CPoint XY; + XY.x=x; + XY.y=0; + + RenderElem(Core,ThisCam,XY,x&7,Is3d); + } +} + +/*****************************************************************************/ +void CLayerElem::RenderElem(CCore *Core,Vector3 &ThisCam,CPoint &Pos,int Elem,bool Render3d,float Alpha) +{ +float ZoomW=Core->GetZoomW(); +float ZoomH=Core->GetZoomH(); +float ScrOfsX=(ZoomW/2); +float ScrOfsY=(ZoomH/2); +Vector3 &Scale=Core->GetScaleVector(); + + if (ElemBank->NeedLoad()) ElemBank->LoadAllSets(Core); + + glMatrixMode(GL_MODELVIEW); + glPushMatrix(); + + glLoadIdentity(); + + glScalef(Scale.x,Scale.y,Scale.z); + glTranslatef(-ThisCam.x,ThisCam.y,0); // Set scroll offset + glTranslatef(-ScrOfsX,ScrOfsY,0); // Bring to top left corner + glTranslatef(Pos.x,Pos.y,0); // Set Elem Pos + glColor4f(1,1,1,Alpha); // Set default Color + ElemBank->RenderElem(0,Elem+1,0,Render3d); + glPopMatrix(); +} + +/*****************************************************************************/ +/*** Gui *********************************************************************/ +/*****************************************************************************/ +void CLayerElem::GUIInit(CCore *Core) +{ +// Core->GUIAdd(GUIToolBar,IDD_TOOLBAR); +} + +/*****************************************************************************/ +void CLayerElem::GUIKill(CCore *Core) +{ +// Core->GUIRemove(GUIToolBar,IDD_TOOLBAR); +} + +/*****************************************************************************/ +void CLayerElem::GUIUpdate(CCore *Core) +{ +} + +/*****************************************************************************/ +void CLayerElem::GUIChanged(CCore *Core) +{ +} + +/*****************************************************************************/ +/*** Functions ***************************************************************/ +/*****************************************************************************/ +bool CLayerElem::LButtonControl(CCore *Core,UINT nFlags, CPoint &CursorPos,bool DownFlag) +{ +bool Ret=false; +/* + switch(Mode) + { + case MouseModePaint: + if (DownFlag) + Ret=Paint(ElemBank->GetLBrush(),CursorPos); + break; + case MouseModeSelect: + Ret=Selection.Handle(CursorPos,nFlags); + if (Selection.HasSelection()) + { + TRACE0("LMB Selection\n"); + } + break; + default: + break; + } +*/ + return(Ret); +} + +/*****************************************************************************/ +bool CLayerElem::RButtonControl(CCore *Core,UINT nFlags, CPoint &CursorPos,bool DownFlag) +{ +bool Ret=FALSE; +/* + switch(Mode) + { + case MouseModePaint: + if (DownFlag) + Ret=Paint(ElemBank->GetRBrush(),CursorPos); + break; + case MouseModeSelect: + Ret=Selection.Handle(CursorPos,nFlags); + if (Selection.HasSelection()) + { + TRACE0("RMB Selection\n"); + } + break; + default: + break; + } +*/ + return(Ret); +} + +/*****************************************************************************/ +bool CLayerElem::MouseMove(CCore *Core,UINT nFlags, CPoint &CursorPos) +{ +bool Ret=FALSE; +/* + switch(Mode) + { + case MouseModePaint: + if (nFlags & MK_LBUTTON) + Ret=Paint(ElemBank->GetLBrush(),CursorPos); + else + if (nFlags & MK_RBUTTON) + Ret=Paint(ElemBank->GetRBrush(),CursorPos); + break; + case MouseModeSelect: + Ret=Selection.Handle(CursorPos,nFlags); + break; + default: + break; + } +*/ + return(Ret); +} + +/*****************************************************************************/ +bool CLayerElem::Command(int CmdMsg,CCore *Core,int Param0,int Param1) +{ +bool Ret=false; + + switch(CmdMsg) + { + case CmdMsg_SetMode: + Mode=(MouseMode)Param0; + Core->GUIUpdate(); + break; + case CmdMsg_SubViewSet: + Ret=ElemBank->Command(CmdMsg,Core,Param0,Param1); + break; + default: + TRACE3("LayerElem-Unhandled Command %i (%i,%i)\n",CmdMsg,Param0,Param1); + } + + return(Ret); +} + +/*****************************************************************************/ +void CLayerElem::RenderCursor(CCore *Core,Vector3 &CamPos,bool Is3d) +{ +Vector3 ThisCam=Core->OffsetCam(CamPos,GetScaleFactor()); +CPoint &CursPos=Core->GetCursorPos(); +Vector3 Ofs; + + if (CursPos.x<0 || CursPos.y<0) return; + + Ofs.x=-(CursPos.x-(int)ThisCam.x); + Ofs.y=-(CursPos.y-(int)ThisCam.y); + ThisCam.x-=(int)ThisCam.x; + ThisCam.y-=(int)ThisCam.y; + + if (Is3d && Render3dFlag) + { + glEnable(GL_DEPTH_TEST); +// Render(Core,ThisCam,,TRUE,0.5,&Ofs); + glDisable(GL_DEPTH_TEST); + } + else + { +// Render(Core,ThisCam,Brush,FALSE,0.5,&Ofs); + } +} + +/*****************************************************************************/ +bool CLayerElem::Paint(CMap &Blk,CPoint &CursorPos) +{ + + if (CursorPos.x==-1 || CursorPos.y==-1) return(false); // Off Map? + if (!Blk.IsValid()) return(false); // Invalid Elem? +/* + Map.Set(CursorPos.x,CursorPos.y,Blk); +*/ + return(true); +} + +/*****************************************************************************/ +void CLayerElem::Export(CCore *Core,CExport &Exp) +{ +/* +int Width=Map.GetWidth(); +int Height=Map.GetHeight(); + + Exp.ExportLayerHeader(LAYER_TYPE_Elem,SubType,Width,Height); + + for (int Y=0; YGetElem(MapElem.Set,MapElem.Elem); + + OutElem.Set=MapElem.Set; + OutElem.Elem=MapElem.Elem; + OutElem.TriStart=0; + OutElem.TriCount=0; + OutElem.XOfs=ThisElem.GetTexXOfs(); + OutElem.YOfs=ThisElem.GetTexYOfs(); + OutElem.Elem=Exp.AddElem(OutElem); + OutElem.Flags=MapElem.Flags; + } + + Exp.Write(&OutElem,sizeof(sExpLayerElem)); + } + } +*/ +} diff --git a/Utils/MapEdit/LayerThing.h b/Utils/MapEdit/LayerThing.h new file mode 100644 index 000000000..4708d74a3 --- /dev/null +++ b/Utils/MapEdit/LayerThing.h @@ -0,0 +1,76 @@ +/******************/ +/*** Layer Elem ***/ +/******************/ + +#ifndef __LAYER_ELEM_HEADER__ +#define __LAYER_ELEM_HEADER__ + +#include "Layer.h" +#include "MapEdit.h" +#include "GUIToolbar.h" +#include "Elem.h" + +/*****************************************************************************/ +struct sLayerElem +{ + std::vector XY; + int Type; + int SubType; + +}; + +/*****************************************************************************/ +class CLayerElem : public CElemBank +{ +public: + enum MouseMode + { + MouseModePaint=0, + MouseModeSelect, + }; + + CLayerElem(){}; + CLayerElem(int SubType,int Width,int Height); // New Layer + CLayerElem(CFile *File,int Version); // Load Layer + ~CLayerElem(); + +virtual int GetType() {return(LAYER_TYPE_ITEM);} +virtual void InitSubView(CCore *Core); + +virtual void Render(CCore *Core,Vector3 &CamPos,bool Is3d); + void RenderCursor(CCore *Core,Vector3 &CamPos,bool Is3d); + +virtual void GUIInit(CCore *Core); +virtual void GUIKill(CCore *Core); +virtual void GUIUpdate(CCore *Core); +virtual void GUIChanged(CCore *Core); + +virtual void Load(CFile *File,int Version); +virtual void Save(CFile *File); + +virtual void Export(CCore *Core,CExport &Exp); + +// Functions +virtual bool LButtonControl(CCore *Core,UINT nFlags, CPoint &point,bool DownFlag); +virtual bool RButtonControl(CCore *Core,UINT nFlags, CPoint &point,bool DownFlag); +virtual bool MouseMove(CCore *Core,UINT nFlags, CPoint &point); +virtual bool Command(int CmdMsg,CCore *Core,int Param0=0,int Param1=0); + +// Local +// CElemBank *GetElemBank() {return(ElemBank);} + +protected: + void RenderElem(CCore *Core,Vector3 &CamPos,CPoint &Pos,int Elem,bool Render3d,float Alpha=1.0f); + + bool Paint(CMap &Blk,CPoint &CursorPos); + + CElemBank *ElemBank; + CList ElemList; + MouseMode Mode; + + CGUIToolBar GUIToolBar; + +}; + +/*****************************************************************************/ +#endif