mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0025289: Draw Harness, ViewerTest - support RGB color definition as input for vsetcolor and vaspects commands
This commit is contained in:
parent
9c0b61f308
commit
8316c618a4
@ -279,6 +279,15 @@ is
|
|||||||
-- Standard_OutOfRange if AName in not known
|
-- Standard_OutOfRange if AName in not known
|
||||||
-- in the Quantity_NameOfColor enumeration.
|
-- in the Quantity_NameOfColor enumeration.
|
||||||
|
|
||||||
|
ColorFromName ( myclass;
|
||||||
|
theName : CString from Standard;
|
||||||
|
theColor : out NameOfColor from Quantity )
|
||||||
|
returns Boolean from Standard;
|
||||||
|
---Purpose: Finds color from predefined names.
|
||||||
|
-- For example, the name of the color which
|
||||||
|
-- corresponds to "BLACK" is Quantity_NOC_BLACK.
|
||||||
|
-- Returns false if name is unknown.
|
||||||
|
|
||||||
HlsRgb ( myclass;
|
HlsRgb ( myclass;
|
||||||
H, L, S : Parameter from Quantity;
|
H, L, S : Parameter from Quantity;
|
||||||
R , G , B : out Parameter from Quantity ) ;
|
R , G , B : out Parameter from Quantity ) ;
|
||||||
@ -339,7 +348,7 @@ is
|
|||||||
---Purpose: Internal test
|
---Purpose: Internal test
|
||||||
---Category: Private methods
|
---Category: Private methods
|
||||||
|
|
||||||
--
|
--
|
||||||
|
|
||||||
fields
|
fields
|
||||||
|
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include <Quantity_Color.ixx>
|
#include <Quantity_Color.ixx>
|
||||||
#include <Quantity_Color_1.hxx>
|
#include <Quantity_Color_1.hxx>
|
||||||
#include <Standard_OutOfRange.hxx>
|
#include <Standard_OutOfRange.hxx>
|
||||||
|
#include <TCollection_AsciiString.hxx>
|
||||||
|
|
||||||
// for Test method (suite et fin)
|
// for Test method (suite et fin)
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -59,6 +60,28 @@ void call_rgbhls(float r, float g, float b, float& h, float& l, float& s);
|
|||||||
|
|
||||||
//-Methods, in order
|
//-Methods, in order
|
||||||
|
|
||||||
|
Standard_Boolean Quantity_Color::ColorFromName (const Standard_CString theName,
|
||||||
|
Quantity_NameOfColor& theColor)
|
||||||
|
{
|
||||||
|
TCollection_AsciiString aName (theName);
|
||||||
|
aName.UpperCase();
|
||||||
|
if (aName.Search("QUANTITY_NOC_") == 1)
|
||||||
|
{
|
||||||
|
aName = aName.SubString (14, aName.Length());
|
||||||
|
}
|
||||||
|
|
||||||
|
for (Standard_Integer anIter = Quantity_NOC_BLACK; anIter <= Quantity_NOC_WHITE; ++anIter)
|
||||||
|
{
|
||||||
|
Standard_CString aColorName = Quantity_Color::StringName (Quantity_NameOfColor (anIter));
|
||||||
|
if (aName == aColorName)
|
||||||
|
{
|
||||||
|
theColor = (Quantity_NameOfColor )anIter;
|
||||||
|
return Standard_True;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Standard_False;
|
||||||
|
}
|
||||||
|
|
||||||
Quantity_Color::Quantity_Color () {
|
Quantity_Color::Quantity_Color () {
|
||||||
|
|
||||||
Quantity_Color::ValuesOf
|
Quantity_Color::ValuesOf
|
||||||
|
@ -97,16 +97,9 @@ extern int ViewerMainLoop(Standard_Integer argc, const char** argv);
|
|||||||
|
|
||||||
Quantity_NameOfColor ViewerTest::GetColorFromName (const Standard_CString theName)
|
Quantity_NameOfColor ViewerTest::GetColorFromName (const Standard_CString theName)
|
||||||
{
|
{
|
||||||
for (Standard_Integer anIter = Quantity_NOC_BLACK; anIter <= Quantity_NOC_WHITE; ++anIter)
|
Quantity_NameOfColor aColor = DEFAULT_COLOR;
|
||||||
{
|
Quantity_Color::ColorFromName (theName, aColor);
|
||||||
Standard_CString aColorName = Quantity_Color::StringName (Quantity_NameOfColor (anIter));
|
return aColor;
|
||||||
if (strcasecmp (theName, aColorName) == 0)
|
|
||||||
{
|
|
||||||
return Quantity_NameOfColor (anIter);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return DEFAULT_COLOR;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
@ -1515,8 +1508,50 @@ static Standard_Integer VAspects (Draw_Interpretor& /*theDI*/,
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
aChangeSet->ToSetColor = 1;
|
aChangeSet->ToSetColor = 1;
|
||||||
aChangeSet->Color = ViewerTest::GetColorFromName (aNames.Last().ToCString());
|
|
||||||
aNames.Remove (aNames.Length());
|
Quantity_NameOfColor aColor = Quantity_NOC_BLACK;
|
||||||
|
Standard_Boolean isOk = Standard_False;
|
||||||
|
if (Quantity_Color::ColorFromName (aNames.Last().ToCString(), aColor))
|
||||||
|
{
|
||||||
|
aChangeSet->Color = aColor;
|
||||||
|
aNames.Remove (aNames.Length());
|
||||||
|
isOk = Standard_True;
|
||||||
|
}
|
||||||
|
else if (aNames.Length() >= 3)
|
||||||
|
{
|
||||||
|
const TCollection_AsciiString anRgbStr[3] =
|
||||||
|
{
|
||||||
|
aNames.Value (aNames.Upper() - 2),
|
||||||
|
aNames.Value (aNames.Upper() - 1),
|
||||||
|
aNames.Value (aNames.Upper() - 0)
|
||||||
|
};
|
||||||
|
isOk = anRgbStr[0].IsRealValue()
|
||||||
|
&& anRgbStr[1].IsRealValue()
|
||||||
|
&& anRgbStr[2].IsRealValue();
|
||||||
|
if (isOk)
|
||||||
|
{
|
||||||
|
Graphic3d_Vec4d anRgb;
|
||||||
|
anRgb.x() = anRgbStr[0].RealValue();
|
||||||
|
anRgb.y() = anRgbStr[1].RealValue();
|
||||||
|
anRgb.z() = anRgbStr[2].RealValue();
|
||||||
|
if (anRgb.x() < 0.0 || anRgb.x() > 1.0
|
||||||
|
|| anRgb.y() < 0.0 || anRgb.y() > 1.0
|
||||||
|
|| anRgb.z() < 0.0 || anRgb.z() > 1.0)
|
||||||
|
{
|
||||||
|
std::cout << "Error: RGB color values should be within range 0..1!\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
aChangeSet->Color.SetValues (anRgb.x(), anRgb.y(), anRgb.z(), Quantity_TOC_RGB);
|
||||||
|
aNames.Remove (aNames.Length());
|
||||||
|
aNames.Remove (aNames.Length());
|
||||||
|
aNames.Remove (aNames.Length());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!isOk)
|
||||||
|
{
|
||||||
|
std::cout << "Error: not enough arguments!\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (aCmdName == "vunsetcolor")
|
else if (aCmdName == "vunsetcolor")
|
||||||
{
|
{
|
||||||
@ -1635,13 +1670,53 @@ static Standard_Integer VAspects (Draw_Interpretor& /*theDI*/,
|
|||||||
}
|
}
|
||||||
else if (anArg == "-setcolor")
|
else if (anArg == "-setcolor")
|
||||||
{
|
{
|
||||||
if (++anArgIter >= theArgNb)
|
Standard_Integer aNbComps = 0;
|
||||||
|
Standard_Integer aCompIter = anArgIter + 1;
|
||||||
|
for (; aCompIter < theArgNb; ++aCompIter, ++aNbComps)
|
||||||
{
|
{
|
||||||
std::cout << "Error: wrong syntax at " << anArg << "\n";
|
if (theArgVec[aCompIter][0] == '-')
|
||||||
return 1;
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
switch (aNbComps)
|
||||||
|
{
|
||||||
|
case 1:
|
||||||
|
{
|
||||||
|
Quantity_NameOfColor aColor = Quantity_NOC_BLACK;
|
||||||
|
Standard_CString aName = theArgVec[anArgIter + 1];
|
||||||
|
if (!Quantity_Color::ColorFromName (aName, aColor))
|
||||||
|
{
|
||||||
|
std::cout << "Error: unknown color name '" << aName << "'\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
aChangeSet->Color = aColor;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 3:
|
||||||
|
{
|
||||||
|
Graphic3d_Vec3d anRgb;
|
||||||
|
anRgb.x() = Draw::Atof (theArgVec[anArgIter + 1]);
|
||||||
|
anRgb.y() = Draw::Atof (theArgVec[anArgIter + 2]);
|
||||||
|
anRgb.z() = Draw::Atof (theArgVec[anArgIter + 3]);
|
||||||
|
if (anRgb.x() < 0.0 || anRgb.x() > 1.0
|
||||||
|
|| anRgb.y() < 0.0 || anRgb.y() > 1.0
|
||||||
|
|| anRgb.z() < 0.0 || anRgb.z() > 1.0)
|
||||||
|
{
|
||||||
|
std::cout << "Error: RGB color values should be within range 0..1!\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
aChangeSet->Color.SetValues (anRgb.x(), anRgb.y(), anRgb.z(), Quantity_TOC_RGB);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
{
|
||||||
|
std::cout << "Error: wrong syntax at " << anArg << "\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
aChangeSet->ToSetColor = 1;
|
aChangeSet->ToSetColor = 1;
|
||||||
aChangeSet->Color = ViewerTest::GetColorFromName (theArgVec[anArgIter]);
|
anArgIter += aNbComps;
|
||||||
}
|
}
|
||||||
else if (anArg == "-unsetcolor")
|
else if (anArg == "-unsetcolor")
|
||||||
{
|
{
|
||||||
@ -4287,7 +4362,7 @@ void ViewerTest::Commands(Draw_Interpretor& theCommands)
|
|||||||
|
|
||||||
theCommands.Add("vaspects",
|
theCommands.Add("vaspects",
|
||||||
"vaspects [-noupdate|-update] [name1 [name2 [...]]]"
|
"vaspects [-noupdate|-update] [name1 [name2 [...]]]"
|
||||||
"\n\t\t: [-setcolor ColorName] [-unsetcolor]"
|
"\n\t\t: [-setcolor ColorName] [-setcolor R G B] [-unsetcolor]"
|
||||||
"\n\t\t: [-setmaterial MatName] [-unsetmaterial]"
|
"\n\t\t: [-setmaterial MatName] [-unsetmaterial]"
|
||||||
"\n\t\t: [-settransparency Transp] [-unsettransparency]"
|
"\n\t\t: [-settransparency Transp] [-unsettransparency]"
|
||||||
"\n\t\t: [-setwidth LineWidth] [-unsetwidth]"
|
"\n\t\t: [-setwidth LineWidth] [-unsetwidth]"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user