1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-05 18:16:23 +03:00

0028215: Visualization - define EMPTY type line for consistenct with Interior Style

Added new values Aspect_TOL_EMPTY (line type) and Aspect_TOM_EMPTY (marker type).
This commit is contained in:
kgv 2016-12-13 12:36:41 +03:00 committed by apn
parent f79b19a17e
commit 3a4a396251
10 changed files with 112 additions and 126 deletions

View File

@ -17,19 +17,14 @@
#define _Aspect_TypeOfLine_HeaderFile #define _Aspect_TypeOfLine_HeaderFile
//! Definition of line types //! Definition of line types
//!
//! TOL_SOLID continuous
//! TOL_DASH dashed 2.0,1.0 (MM)
//! TOL_DOT dotted 0.2,0.5 (MM)
//! TOL_DOTDASH mixed 10.0,1.0,2.0,1.0 (MM)
//! TOL_USERDEFINED defined by Users
enum Aspect_TypeOfLine enum Aspect_TypeOfLine
{ {
Aspect_TOL_SOLID, Aspect_TOL_EMPTY = -1, //!< hidden
Aspect_TOL_DASH, Aspect_TOL_SOLID = 0, //!< continuous
Aspect_TOL_DOT, Aspect_TOL_DASH, //!< dashed 2.0,1.0 (MM)
Aspect_TOL_DOTDASH, Aspect_TOL_DOT, //!< dotted 0.2,0.5 (MM)
Aspect_TOL_USERDEFINED Aspect_TOL_DOTDASH, //!< mixed 10.0,1.0,2.0,1.0 (MM)
Aspect_TOL_USERDEFINED //!< defined by Users
}; };
#endif // _Aspect_TypeOfLine_HeaderFile #endif // _Aspect_TypeOfLine_HeaderFile

View File

@ -17,37 +17,23 @@
#define _Aspect_TypeOfMarker_HeaderFile #define _Aspect_TypeOfMarker_HeaderFile
//! Definition of types of markers //! Definition of types of markers
//!
//! TOM_POINT point .
//! TOM_PLUS plus +
//! TOM_STAR star *
//! TOM_X cross x
//! TOM_O circle O
//! TOM_O_POINT a point in a circle
//! TOM_O_PLUS a plus in a circle
//! TOM_O_STAR a star in a circle
//! TOM_O_X a cross in a circle
//! TOM_RING1 a large ring
//! TOM_RING2 a medium ring
//! TOM_RING3 a small ring
//! TOM_BALL a ball with 1 color and different saturations
//! TOM_USERDEFINED defined by Users
enum Aspect_TypeOfMarker enum Aspect_TypeOfMarker
{ {
Aspect_TOM_POINT, Aspect_TOM_EMPTY = -1, //!< hidden
Aspect_TOM_PLUS, Aspect_TOM_POINT = 0, //!< point .
Aspect_TOM_STAR, Aspect_TOM_PLUS, //!< plus +
Aspect_TOM_X, Aspect_TOM_STAR, //!< star *
Aspect_TOM_O, Aspect_TOM_X, //!< cross x
Aspect_TOM_O_POINT, Aspect_TOM_O, //!< circle O
Aspect_TOM_O_PLUS, Aspect_TOM_O_POINT, //!< a point in a circle
Aspect_TOM_O_STAR, Aspect_TOM_O_PLUS, //!< a plus in a circle
Aspect_TOM_O_X, Aspect_TOM_O_STAR, //!< a star in a circle
Aspect_TOM_RING1, Aspect_TOM_O_X, //!< a cross in a circle
Aspect_TOM_RING2, Aspect_TOM_RING1, //!< a large ring
Aspect_TOM_RING3, Aspect_TOM_RING2, //!< a medium ring
Aspect_TOM_BALL, Aspect_TOM_RING3, //!< a small ring
Aspect_TOM_USERDEFINED Aspect_TOM_BALL, //!< a ball with 1 color and different saturations
Aspect_TOM_USERDEFINED //!< defined by Users (custom image)
}; };
#endif // _Aspect_TypeOfMarker_HeaderFile #endif // _Aspect_TypeOfMarker_HeaderFile

View File

@ -1606,6 +1606,7 @@ void OpenGl_AspectMarker::Resources::BuildSprites (const Handle(OpenGl_Context)&
SpriteAKey = aNewKeyA; SpriteAKey = aNewKeyA;
} }
if (theType == Aspect_TOM_POINT if (theType == Aspect_TOM_POINT
|| theType == Aspect_TOM_EMPTY
|| !aNewResource || !aNewResource
|| (theType == Aspect_TOM_USERDEFINED && theMarkerImage.IsNull())) || (theType == Aspect_TOM_USERDEFINED && theMarkerImage.IsNull()))
{ {
@ -1948,7 +1949,8 @@ void OpenGl_AspectMarker::Resources::SpriteKeys (const Handle(Graphic3d_MarkerIm
theKeyA = theMarkerImage->GetImageAlphaId(); theKeyA = theMarkerImage->GetImageAlphaId();
} }
} }
else if (theType != Aspect_TOM_POINT) else if (theType != Aspect_TOM_POINT
&& theType != Aspect_TOM_EMPTY)
{ {
// predefined markers are defined with 0.5 step // predefined markers are defined with 0.5 step
const Standard_Integer aScale = Standard_Integer(theScale * 10.0f + 0.5f); const Standard_Integer aScale = Standard_Integer(theScale * 10.0f + 0.5f);

View File

@ -2934,6 +2934,7 @@ void OpenGl_Context::SetTypeOfLine (const Aspect_TypeOfLine theType,
aPattern = 0xFF18; aPattern = 0xFF18;
break; break;
} }
case Aspect_TOL_EMPTY:
case Aspect_TOL_SOLID: case Aspect_TOL_SOLID:
{ {
aPattern = 0xFFFF; aPattern = 0xFFFF;
@ -2954,7 +2955,7 @@ void OpenGl_Context::SetTypeOfLine (const Aspect_TypeOfLine theType,
} }
#if !defined(GL_ES_VERSION_2_0) #if !defined(GL_ES_VERSION_2_0)
if (theType != Aspect_TOL_SOLID) if (aPattern != 0xFFFF)
{ {
#ifdef HAVE_GL2PS #ifdef HAVE_GL2PS
if (IsFeedback()) if (IsFeedback())

View File

@ -737,13 +737,25 @@ void OpenGl_PrimitiveArray::Render (const Handle(OpenGl_Workspace)& theWorkspace
#endif #endif
// Temporarily disable environment mapping // Temporarily disable environment mapping
Handle(OpenGl_Texture) aTextureBack; Handle(OpenGl_Texture) aTextureBack;
if (myDrawMode <= GL_LINE_STRIP) bool toDrawArray = true;
if (myDrawMode > GL_LINE_STRIP)
{
toDrawArray = anAspectFace->Aspect()->InteriorStyle() != Aspect_IS_EMPTY;
}
else if (myDrawMode <= GL_LINE_STRIP)
{ {
aTextureBack = theWorkspace->DisableTexture(); aTextureBack = theWorkspace->DisableTexture();
if (myDrawMode == GL_POINTS)
{
toDrawArray = anAspectMarker->Aspect()->Type() != Aspect_TOM_EMPTY;
}
else
{
toDrawArray = anAspectLine->Aspect()->Type() != Aspect_TOL_EMPTY;
}
} }
if ((myDrawMode > GL_LINE_STRIP && anAspectFace->Aspect()->InteriorStyle() != Aspect_IS_EMPTY) || if (toDrawArray)
(myDrawMode <= GL_LINE_STRIP))
{ {
const bool toHilight = theWorkspace->ToHighlight(); const bool toHilight = theWorkspace->ToHighlight();
const Standard_Boolean hasVertColor = hasColorAttrib && !toHilight; const Standard_Boolean hasVertColor = hasColorAttrib && !toHilight;

View File

@ -27,6 +27,7 @@
#include <ViewerTest.hxx> #include <ViewerTest.hxx>
#include <ViewerTest_CmdParser.hxx> #include <ViewerTest_CmdParser.hxx>
#include <Draw.hxx>
#include <TopLoc_Location.hxx> #include <TopLoc_Location.hxx>
#include <TopTools_HArray1OfShape.hxx> #include <TopTools_HArray1OfShape.hxx>
#include <TColStd_HArray1OfTransient.hxx> #include <TColStd_HArray1OfTransient.hxx>
@ -173,6 +174,47 @@ Standard_Boolean ViewerTest::ParseOnOff (Standard_CString theArg,
return Standard_False; return Standard_False;
} }
//=======================================================================
//function : ParseLineType
//purpose :
//=======================================================================
Standard_Boolean ViewerTest::ParseLineType (Standard_CString theArg,
Aspect_TypeOfLine& theType)
{
TCollection_AsciiString aTypeStr (theArg);
aTypeStr.LowerCase();
if (aTypeStr == "empty")
{
theType = Aspect_TOL_EMPTY;
}
else if (aTypeStr == "solid")
{
theType = Aspect_TOL_SOLID;
}
else if (aTypeStr == "dot")
{
theType = Aspect_TOL_DOT;
}
else if (aTypeStr == "dash")
{
theType = Aspect_TOL_DASH;
}
else if (aTypeStr == "dotdash")
{
theType = Aspect_TOL_DOTDASH;
}
else
{
const int aTypeInt = Draw::Atoi (theArg);
if (aTypeInt < -1 || aTypeInt >= Aspect_TOL_USERDEFINED)
{
return Standard_False;
}
theType = (Aspect_TypeOfLine )aTypeInt;
}
return Standard_True;
}
//======================================================================= //=======================================================================
//function : GetTypeNames //function : GetTypeNames
//purpose : //purpose :
@ -1893,27 +1935,7 @@ static Standard_Integer VAspects (Draw_Interpretor& /*theDI*/,
std::cout << "Error: wrong syntax at " << anArg << "\n"; std::cout << "Error: wrong syntax at " << anArg << "\n";
return 1; return 1;
} }
if (!ViewerTest::ParseLineType (theArgVec[anArgIter], aChangeSet->TypeOfLine))
TCollection_AsciiString aValue (theArgVec[anArgIter]);
aValue.LowerCase();
if (aValue.IsEqual ("solid"))
{
aChangeSet->TypeOfLine = Aspect_TOL_SOLID;
}
else if (aValue.IsEqual ("dot"))
{
aChangeSet->TypeOfLine = Aspect_TOL_DOT;
}
else if (aValue.IsEqual ("dash"))
{
aChangeSet->TypeOfLine = Aspect_TOL_DASH;
}
else if (aValue.IsEqual ("dotdash"))
{
aChangeSet->TypeOfLine = Aspect_TOL_DOTDASH;
}
else
{ {
std::cout << "Error: wrong syntax at " << anArg << "\n"; std::cout << "Error: wrong syntax at " << anArg << "\n";
return 1; return 1;

View File

@ -26,9 +26,11 @@
#include <TopAbs_ShapeEnum.hxx> #include <TopAbs_ShapeEnum.hxx>
#include <TopTools_HArray1OfShape.hxx> #include <TopTools_HArray1OfShape.hxx>
#include <AIS_KindOfInteractive.hxx> #include <AIS_KindOfInteractive.hxx>
#include <Aspect_TypeOfLine.hxx>
#include <TColStd_HArray1OfTransient.hxx> #include <TColStd_HArray1OfTransient.hxx>
#include <Quantity_NameOfColor.hxx> #include <Quantity_NameOfColor.hxx>
class TCollection_AsciiString; class TCollection_AsciiString;
class V3d_View; class V3d_View;
class MMgt_TShared; class MMgt_TShared;
@ -187,6 +189,12 @@ public:
//! Handles either flag specified by 0|1 or on|off. //! Handles either flag specified by 0|1 or on|off.
Standard_EXPORT static Standard_Boolean ParseOnOff (Standard_CString theArg, Standard_EXPORT static Standard_Boolean ParseOnOff (Standard_CString theArg,
Standard_Boolean& theIsOn); Standard_Boolean& theIsOn);
//! Parses line type argument.
//! Handles either enumeration (integer) value or string constant.
Standard_EXPORT static Standard_Boolean ParseLineType (Standard_CString theArg,
Aspect_TypeOfLine& theType);
private: private:
//! Returns a window class that implements standard behavior of //! Returns a window class that implements standard behavior of

View File

@ -5270,13 +5270,10 @@ static Standard_Integer VShowFaceBoundary (Draw_Interpretor& /*di*/,
// select appropriate line type // select appropriate line type
if (argc == 8) if (argc == 8)
{ {
switch (Draw::Atoi (argv[7])) if (!ViewerTest::ParseLineType (argv[7], aLineType))
{ {
case 1: aLineType = Aspect_TOL_DASH; break; std::cout << "Syntax error: unknown line type '" << argv[7] << "'\n";
case 2: aLineType = Aspect_TOL_DOT; break; return 1;
case 3: aLineType = Aspect_TOL_DOTDASH; break;
default:
aLineType = Aspect_TOL_SOLID;
} }
} }
@ -5913,31 +5910,14 @@ static int VSetEdgeType (Draw_Interpretor& theDI,
return 1; return 1;
} }
TCollection_AsciiString aType = theArgs[++anIt]; ++anIt;
aType.UpperCase(); Aspect_TypeOfLine aTypeEnum = Aspect_TOL_SOLID;
if (!ViewerTest::ParseLineType (theArgs[anIt], aTypeEnum))
if (aType.IsEqual ("SOLID"))
{ {
anObject->Attributes()->ShadingAspect()->Aspect()->SetEdgeLineType(Aspect_TOL_SOLID); std::cout << "Syntax error: wrong line type: '" << theArgs[anIt] << "'.\n";
}
else if (aType.IsEqual ("DASH"))
{
anObject->Attributes()->ShadingAspect()->Aspect()->SetEdgeLineType(Aspect_TOL_DASH);
}
else if (aType.IsEqual ("DOT"))
{
anObject->Attributes()->ShadingAspect()->Aspect()->SetEdgeLineType(Aspect_TOL_DOT);
}
else if (aType.IsEqual ("DOTDASH"))
{
anObject->Attributes()->ShadingAspect()->Aspect()->SetEdgeLineType(Aspect_TOL_DOTDASH);
}
else
{
theDI << theArgs[0] << " error: wrong line type: '" << aType.ToCString() << "'.\n";
return 1; return 1;
} }
anObject->Attributes()->ShadingAspect()->Aspect()->SetEdgeLineType (aTypeEnum);
} }
else if (aParam.IsEqual ("-color")) else if (aParam.IsEqual ("-color"))
{ {

View File

@ -4886,17 +4886,21 @@ static int VLayerLine(Draw_Interpretor& di, Standard_Integer argc, const char**
Standard_Real X2 = Draw::Atof(argv[3]); Standard_Real X2 = Draw::Atof(argv[3]);
Standard_Real Y2 = Draw::Atof(argv[4]); Standard_Real Y2 = Draw::Atof(argv[4]);
Standard_Real aWidth = 0.5; Standard_Real aWidth = 0.5;
Standard_Integer aType = 0; Standard_Real aTransparency = 1.0;
Standard_Real aTransparency = 1.0;
// has width // has width
if (argc > 5) if (argc > 5)
aWidth = Draw::Atof(argv[5]); aWidth = Draw::Atof(argv[5]);
// has type // select appropriate line type
if (argc > 6) Aspect_TypeOfLine aLineType = Aspect_TOL_SOLID;
aType = (Standard_Integer) Draw::Atoi(argv[6]); if (argc > 6
&& !ViewerTest::ParseLineType (argv[6], aLineType))
{
std::cout << "Syntax error: unknown line type '" << argv[6] << "'\n";
return 1;
}
// has transparency // has transparency
if (argc > 7) if (argc > 7)
@ -4906,26 +4910,6 @@ static int VLayerLine(Draw_Interpretor& di, Standard_Integer argc, const char**
aTransparency = 1.0; aTransparency = 1.0;
} }
// select appropriate line type
Aspect_TypeOfLine aLineType;
switch (aType)
{
case 1:
aLineType = Aspect_TOL_DASH;
break;
case 2:
aLineType = Aspect_TOL_DOT;
break;
case 3:
aLineType = Aspect_TOL_DOTDASH;
break;
default:
aLineType = Aspect_TOL_SOLID;
}
static Handle (V3d_LineItem) aLine; static Handle (V3d_LineItem) aLine;
if (!aLine.IsNull()) if (!aLine.IsNull())
{ {

View File

@ -976,13 +976,9 @@ static Standard_Integer XShowFaceBoundary (Draw_Interpretor& di,
// select appropriate line type // select appropriate line type
if (argc == 9) if (argc == 9)
{ {
switch (Draw::Atoi (argv[8])) if (!ViewerTest::ParseLineType (argv[8], aLineType))
{ {
case 1: aLineType = Aspect_TOL_DASH; break; std::cout << "Syntax error: unknown line type '" << argv[8] << "'\n";
case 2: aLineType = Aspect_TOL_DOT; break;
case 3: aLineType = Aspect_TOL_DOTDASH; break;
default:
aLineType = Aspect_TOL_SOLID;
} }
} }