summaryrefslogtreecommitdiff
path: root/hammer/mapsphere.cpp
diff options
context:
space:
mode:
authorFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
committerFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
commit3bf9df6b2785fa6d951086978a3e66f49427166a (patch)
tree2c0f1f0c63c4832882bc93814ebd2c2b1c6224e5 /hammer/mapsphere.cpp
downloadarchived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.tar.xz
archived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.zip
Diffstat (limited to 'hammer/mapsphere.cpp')
-rw-r--r--hammer/mapsphere.cpp361
1 files changed, 361 insertions, 0 deletions
diff --git a/hammer/mapsphere.cpp b/hammer/mapsphere.cpp
new file mode 100644
index 0000000..62a5bea
--- /dev/null
+++ b/hammer/mapsphere.cpp
@@ -0,0 +1,361 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+// Purpose: Implements a sphere helper for entities that have a radius of effect.
+// Renders only when the parent entity is selected.
+//
+//=============================================================================//
+
+#include "stdafx.h"
+#include "Box3D.h"
+#include "fgdlib/HelperInfo.h"
+#include "materialsystem/imaterialsystem.h"
+#include "materialsystem/imesh.h"
+#include "MapDoc.h"
+#include "MapSphere.h"
+#include "MapView2D.h"
+#include "Material.h"
+#include "mathlib/MathLib.h"
+#include "Render2D.h"
+#include "Render3D.h"
+#include "ToolManager.h"
+#include "ToolSphere.h"
+
+// memdbgon must be the last include file in a .cpp file!!!
+#include <tier0/memdbgon.h>
+
+
+IMPLEMENT_MAPCLASS(CMapSphere)
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Factory function. Used for creating a CMapSphere helper from a
+// set of string parameters from the FGD file.
+// Input : pInfo - Pointer to helper info class which gives us information
+// about how to create the helper.
+// Output : Returns a pointer to the helper, NULL if an error occurs.
+//-----------------------------------------------------------------------------
+CMapClass *CMapSphere::Create(CHelperInfo *pHelperInfo, CMapEntity *pParent)
+{
+ CMapSphere *pSphere = new CMapSphere;
+ if (pSphere != NULL)
+ {
+ //
+ // The first parameter should be the key name to represent. If it isn't
+ // there we assume "radius".
+ //
+ const char *pszKeyName = pHelperInfo->GetParameter(0);
+ if (pszKeyName != NULL)
+ {
+ strcpy(pSphere->m_szKeyName, pszKeyName);
+ }
+ else
+ {
+ strcpy(pSphere->m_szKeyName, "radius");
+ }
+
+ //
+ // Extract the line color from the parameter list.
+ //
+ unsigned char chRed = 255;
+ unsigned char chGreen = 255;
+ unsigned char chBlue = 255;
+
+ const char *pszParam = pHelperInfo->GetParameter(1);
+ if (pszParam != NULL)
+ {
+ chRed = atoi(pszParam);
+ }
+
+ pszParam = pHelperInfo->GetParameter(2);
+ if (pszParam != NULL)
+ {
+ chGreen = atoi(pszParam);
+ }
+
+ pszParam = pHelperInfo->GetParameter(3);
+ if (pszParam != NULL)
+ {
+ chBlue = atoi(pszParam);
+ }
+
+ pSphere->SetRenderColor(chRed, chGreen, chBlue);
+ }
+
+ return pSphere;
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Constructor.
+//-----------------------------------------------------------------------------
+CMapSphere::CMapSphere(void)
+{
+ m_szKeyName[0] = '\0';
+
+ m_flRadius = 0;
+
+ r = 255;
+ g = 255;
+ b = 0;
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Destructor.
+//-----------------------------------------------------------------------------
+CMapSphere::~CMapSphere(void)
+{
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose:
+// Input : bFullUpdate -
+//-----------------------------------------------------------------------------
+void CMapSphere::CalcBounds(BOOL bFullUpdate)
+{
+ CMapClass::CalcBounds(bFullUpdate);
+
+ //
+ // Pretend we're a point so that we don't change our parent entity bounds
+ // in the 2D view.
+ //
+ m_Render2DBox.ResetBounds();
+ m_Render2DBox.UpdateBounds(m_Origin);
+
+ //
+ // Build our bounds for frustum culling in the 3D views.
+ //
+ m_CullBox.ResetBounds();
+ Vector mins = m_Origin - Vector(m_flRadius, m_flRadius, m_flRadius);
+ Vector maxs = m_Origin + Vector(m_flRadius, m_flRadius, m_flRadius);
+ m_CullBox.UpdateBounds(mins, maxs);
+
+ m_BoundingBox.ResetBounds(); // we don't want to use the bounds of the sphere for our bounding box
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose:
+// Output : CMapClass
+//-----------------------------------------------------------------------------
+CMapClass *CMapSphere::Copy(bool bUpdateDependencies)
+{
+ CMapSphere *pCopy = new CMapSphere;
+
+ if (pCopy != NULL)
+ {
+ pCopy->CopyFrom(this, bUpdateDependencies);
+ }
+
+ return(pCopy);
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Makes this an exact duplicate of pObject.
+// Input : pObject - Object to copy.
+// Output : Returns this.
+//-----------------------------------------------------------------------------
+CMapClass *CMapSphere::CopyFrom(CMapClass *pObject, bool bUpdateDependencies)
+{
+ Assert(pObject->IsMapClass(MAPCLASS_TYPE(CMapSphere)));
+ CMapSphere *pFrom = (CMapSphere *)pObject;
+
+ CMapClass::CopyFrom(pObject, bUpdateDependencies);
+
+ m_flRadius = pFrom->m_flRadius;
+ strcpy(m_szKeyName, pFrom->m_szKeyName);
+
+ return(this);
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Sets the radius of the sphere helper and updates our parent
+// entity's keyvalue.
+//-----------------------------------------------------------------------------
+void CMapSphere::SetRadius(float flRadius)
+{
+ m_flRadius = V_rint(flRadius);
+
+ CMapEntity *pEntity = dynamic_cast <CMapEntity *>(m_pParent);
+ if (pEntity != NULL)
+ {
+ char szValue[80];
+ sprintf(szValue, "%g", m_flRadius);
+ pEntity->NotifyChildKeyChanged(this, m_szKeyName, szValue);
+ }
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Gets the tool object for a given context data from HitTest2D.
+//-----------------------------------------------------------------------------
+CBaseTool *CMapSphere::GetToolObject(int nHitData, bool bAttachObject)
+{
+ CToolSphere *pTool = (CToolSphere *)ToolManager()->GetToolForID(TOOL_SPHERE);
+
+ if ( bAttachObject )
+ pTool->Attach(this);
+
+ return pTool;
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose:
+// Input : pView -
+// point - point in client coordinates
+// Output :
+//-----------------------------------------------------------------------------
+bool CMapSphere::HitTest2D(CMapView2D *pView, const Vector2D &point, HitInfo_t &HitData)
+{
+ if (!IsVisible() || m_flRadius <= 0 || !IsSelected() )
+ {
+ return NULL;
+ }
+
+ Vector2D vecClientOrigin;
+ pView->WorldToClient(vecClientOrigin, m_Origin);
+
+ Vector vecRadius = m_Origin;
+ vecRadius[pView->axHorz] += m_flRadius;
+
+ Vector2D vecClientRadius;
+ pView->WorldToClient(vecClientRadius, vecRadius);
+
+ int nRadius = abs(vecClientRadius.x - vecClientOrigin.x);
+
+ vecClientRadius.x = nRadius;
+ vecClientRadius.y = nRadius;
+
+ HitData.pObject = this;
+ HitData.nDepth = 0; // handles have no depth
+ HitData.uData = nRadius;
+
+ Vector2D vecClientMin = vecClientOrigin - vecClientRadius;
+ Vector2D vecClientMax = vecClientOrigin + vecClientRadius;
+
+ //
+ // Check the four resize handles.
+ //
+ Vector2D vecTemp(vecClientOrigin.x, vecClientMin.y - HANDLE_OFFSET);
+
+ if (pView->CheckDistance(point, vecTemp, 6))
+ {
+ // Top handle
+ SetCursor(AfxGetApp()->LoadStandardCursor(IDC_SIZENS));
+ return true;
+ }
+
+ vecTemp.x = vecClientOrigin.x;
+ vecTemp.y = vecClientMax.y + HANDLE_OFFSET;
+ if (pView->CheckDistance(point, vecTemp, HANDLE_RADIUS))
+ {
+ // Bottom handle
+ SetCursor(AfxGetApp()->LoadStandardCursor(IDC_SIZENS));
+ return true;
+ }
+
+ vecTemp.x = vecClientMin.x - HANDLE_OFFSET;
+ vecTemp.y = vecClientOrigin.y;
+ if (pView->CheckDistance(point, vecTemp, HANDLE_RADIUS))
+ {
+ // Left handle
+ SetCursor(AfxGetApp()->LoadStandardCursor(IDC_SIZEWE));
+ return true;
+ }
+
+ vecTemp.x = vecClientMax.x + HANDLE_OFFSET;
+ vecTemp.y = vecClientOrigin.y;
+ if (pView->CheckDistance(point, vecTemp, HANDLE_RADIUS))
+ {
+ // Right handle
+ SetCursor(AfxGetApp()->LoadStandardCursor(IDC_SIZEWE));
+ return true;
+ }
+
+ HitData.pObject = NULL;
+ return false;
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Notifies that this object's parent entity has had a key value change.
+// Input : szKey - The key that changed.
+// szValue - The new value of the key.
+//-----------------------------------------------------------------------------
+void CMapSphere::OnParentKeyChanged(const char *szKey, const char *szValue)
+{
+ if (!stricmp(szKey, m_szKeyName))
+ {
+ m_flRadius = atof(szValue);
+ PostUpdate(Notify_Changed);
+ }
+}
+
+
+
+
+//-----------------------------------------------------------------------------
+// Purpose:
+// Input : pRender -
+//-----------------------------------------------------------------------------
+void CMapSphere::Render2D(CRender2D *pRender)
+{
+ if (m_pParent->IsSelected() && (m_flRadius > 0) )
+ {
+ pRender->SetDrawColor( 255, 255, 0 );
+
+ Vector2D ptClientRadius;
+ pRender->TransformNormal(ptClientRadius, Vector(m_flRadius,m_flRadius,m_flRadius) );
+
+ int radius = ptClientRadius.x;
+
+ pRender->DrawCircle( m_Origin, m_flRadius );
+
+ bool bPopMode = pRender->BeginClientSpace();
+
+ //
+ // Draw the four resize handles.
+ //
+ pRender->SetHandleStyle( HANDLE_RADIUS, CRender::HANDLE_SQUARE );
+ pRender->SetHandleColor( 255,255,255 );
+
+ Vector2D offset;
+ offset.x = 0;
+ offset.y = -(radius + HANDLE_OFFSET);
+ pRender->DrawHandle( m_Origin, &offset );
+
+ offset.x = 0;
+ offset.y = radius + HANDLE_OFFSET;
+ pRender->DrawHandle( m_Origin, &offset );
+
+ offset.x = -(radius + HANDLE_OFFSET);
+ offset.y = 0;
+ pRender->DrawHandle( m_Origin, &offset );
+
+ offset.x = radius + HANDLE_OFFSET;
+ offset.y = 0;
+ pRender->DrawHandle( m_Origin, &offset );
+
+ if ( bPopMode )
+ pRender->EndClientSpace();
+ }
+}
+
+
+//-----------------------------------------------------------------------------
+// Purpose: Renders the wireframe sphere.
+// Input : pRender - Interface to renderer.
+//-----------------------------------------------------------------------------
+void CMapSphere::Render3D(CRender3D *pRender)
+{
+ if (m_pParent->IsSelected() && (m_flRadius > 0))
+ {
+ pRender->RenderWireframeSphere(m_Origin, m_flRadius, 12, 12, 255, 255, 0);
+ }
+}
+
+