mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0029011: Draw Harness - simplify diffimage command syntax
Command diffimage now accepts the following syntax: diffimage imageFile1 imageFile2 [diffImageFile] [-toleranceOfColor {0..1}=0] [-blackWhite {on|off}=off] [-borderFilter {on|off}=off] [-display viewName prsName1 prsName2 prsNameDiff] [-exitOnClose] Command vinit now accepts the following syntax: vinit [-name viewName] [-left leftPx] [-top topPx] [-width widthPx] [-height heightPx] [-exitOnClose] [-display displayName] Compatibility with old syntax is also preserved. diffimage now can display compared images in 3D viewer. The new option -exitOnClose can be used to exit application when closing the 3D View.
This commit is contained in:
parent
aa17dac878
commit
fd3f6bd069
@ -78,6 +78,8 @@
|
|||||||
#include <Prs3d_Drawer.hxx>
|
#include <Prs3d_Drawer.hxx>
|
||||||
#include <Prs3d_LineAspect.hxx>
|
#include <Prs3d_LineAspect.hxx>
|
||||||
#include <Prs3d_Root.hxx>
|
#include <Prs3d_Root.hxx>
|
||||||
|
#include <Prs3d_Text.hxx>
|
||||||
|
#include <Select3D_SensitivePrimitiveArray.hxx>
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#undef DrawText
|
#undef DrawText
|
||||||
@ -99,6 +101,7 @@
|
|||||||
|
|
||||||
// Auxiliary definitions
|
// Auxiliary definitions
|
||||||
static const char THE_KEY_DELETE = 127;
|
static const char THE_KEY_DELETE = 127;
|
||||||
|
static const char THE_KEY_ESCAPE = 27;
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
// VIEWER GLOBAL VARIABLES
|
// VIEWER GLOBAL VARIABLES
|
||||||
@ -194,6 +197,8 @@ int Y_ButtonPress = 0;
|
|||||||
Standard_Boolean IsDragged = Standard_False;
|
Standard_Boolean IsDragged = Standard_False;
|
||||||
Standard_Boolean DragFirst = Standard_False;
|
Standard_Boolean DragFirst = Standard_False;
|
||||||
Standard_Boolean TheIsAnimating = Standard_False;
|
Standard_Boolean TheIsAnimating = Standard_False;
|
||||||
|
Standard_Boolean Draw_ToExitOnCloseView = Standard_False;
|
||||||
|
Standard_Boolean Draw_ToCloseViewOnEsc = Standard_False;
|
||||||
|
|
||||||
|
|
||||||
Standard_EXPORT const Handle(AIS_RubberBand)& GetRubberBand()
|
Standard_EXPORT const Handle(AIS_RubberBand)& GetRubberBand()
|
||||||
@ -772,13 +777,6 @@ void ViewerTest::RedrawAllViews()
|
|||||||
|
|
||||||
static int VInit (Draw_Interpretor& theDi, Standard_Integer theArgsNb, const char** theArgVec)
|
static int VInit (Draw_Interpretor& theDi, Standard_Integer theArgsNb, const char** theArgVec)
|
||||||
{
|
{
|
||||||
if (theArgsNb > 9)
|
|
||||||
{
|
|
||||||
std::cerr << theArgVec[0] << ": incorrect number of command arguments.\n"
|
|
||||||
<< "Type help for more information.\n";
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
TCollection_AsciiString aViewName, aDisplayName;
|
TCollection_AsciiString aViewName, aDisplayName;
|
||||||
Standard_Integer aPxLeft = 0, aPxTop = 0, aPxWidth = 0, aPxHeight = 0;
|
Standard_Integer aPxLeft = 0, aPxTop = 0, aPxWidth = 0, aPxHeight = 0;
|
||||||
TCollection_AsciiString aName, aValue;
|
TCollection_AsciiString aName, aValue;
|
||||||
@ -786,44 +784,98 @@ static int VInit (Draw_Interpretor& theDi, Standard_Integer theArgsNb, const cha
|
|||||||
{
|
{
|
||||||
const TCollection_AsciiString anArg = theArgVec[anArgIt];
|
const TCollection_AsciiString anArg = theArgVec[anArgIt];
|
||||||
TCollection_AsciiString anArgCase = anArg;
|
TCollection_AsciiString anArgCase = anArg;
|
||||||
anArgCase.UpperCase();
|
anArgCase.LowerCase();
|
||||||
if (ViewerTest::SplitParameter (anArg, aName, aValue))
|
if (anArgIt + 1 < theArgsNb
|
||||||
|
&& anArgCase == "-name")
|
||||||
{
|
{
|
||||||
aName.UpperCase();
|
aViewName = theArgVec[++anArgIt];
|
||||||
if (aName.IsEqual ("NAME"))
|
}
|
||||||
|
else if (anArgIt + 1 < theArgsNb
|
||||||
|
&& (anArgCase == "-left"
|
||||||
|
|| anArgCase == "-l"))
|
||||||
|
{
|
||||||
|
aPxLeft = Draw::Atoi (theArgVec[++anArgIt]);
|
||||||
|
}
|
||||||
|
else if (anArgIt + 1 < theArgsNb
|
||||||
|
&& (anArgCase == "-top"
|
||||||
|
|| anArgCase == "-t"))
|
||||||
|
{
|
||||||
|
aPxTop = Draw::Atoi (theArgVec[++anArgIt]);
|
||||||
|
}
|
||||||
|
else if (anArgIt + 1 < theArgsNb
|
||||||
|
&& (anArgCase == "-width"
|
||||||
|
|| anArgCase == "-w"))
|
||||||
|
{
|
||||||
|
aPxWidth = Draw::Atoi (theArgVec[++anArgIt]);
|
||||||
|
}
|
||||||
|
else if (anArgIt + 1 < theArgsNb
|
||||||
|
&& (anArgCase == "-height"
|
||||||
|
|| anArgCase == "-h"))
|
||||||
|
{
|
||||||
|
aPxHeight = Draw::Atoi (theArgVec[++anArgIt]);
|
||||||
|
}
|
||||||
|
else if (anArgCase == "-exitonclose")
|
||||||
|
{
|
||||||
|
Draw_ToExitOnCloseView = true;
|
||||||
|
if (anArgIt + 1 < theArgsNb
|
||||||
|
&& ViewerTest::ParseOnOff (theArgVec[anArgIt + 1], Draw_ToExitOnCloseView))
|
||||||
|
{
|
||||||
|
++anArgIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (anArgCase == "-closeonescape"
|
||||||
|
|| anArgCase == "-closeonesc")
|
||||||
|
{
|
||||||
|
Draw_ToCloseViewOnEsc = true;
|
||||||
|
if (anArgIt + 1 < theArgsNb
|
||||||
|
&& ViewerTest::ParseOnOff (theArgVec[anArgIt + 1], Draw_ToCloseViewOnEsc))
|
||||||
|
{
|
||||||
|
++anArgIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (anArgIt + 1 < theArgsNb
|
||||||
|
&& (anArgCase == "-disp"
|
||||||
|
|| anArgCase == "-display"))
|
||||||
|
{
|
||||||
|
aDisplayName = theArgVec[++anArgIt];
|
||||||
|
}
|
||||||
|
// old syntax
|
||||||
|
else if (ViewerTest::SplitParameter (anArg, aName, aValue))
|
||||||
|
{
|
||||||
|
aName.LowerCase();
|
||||||
|
if (aName == "name")
|
||||||
{
|
{
|
||||||
aViewName = aValue;
|
aViewName = aValue;
|
||||||
}
|
}
|
||||||
else if (aName.IsEqual ("L")
|
else if (aName == "l"
|
||||||
|| aName.IsEqual ("LEFT"))
|
|| aName == "left")
|
||||||
{
|
{
|
||||||
aPxLeft = aValue.IntegerValue();
|
aPxLeft = aValue.IntegerValue();
|
||||||
}
|
}
|
||||||
else if (aName.IsEqual ("T")
|
else if (aName == "t"
|
||||||
|| aName.IsEqual ("TOP"))
|
|| aName == "top")
|
||||||
{
|
{
|
||||||
aPxTop = aValue.IntegerValue();
|
aPxTop = aValue.IntegerValue();
|
||||||
}
|
}
|
||||||
#if !defined(_WIN32) && (!defined(__APPLE__) || defined(MACOSX_USE_GLX))
|
else if (aName == "disp"
|
||||||
else if (aName.IsEqual ("DISP")
|
|| aName == "display")
|
||||||
|| aName.IsEqual ("DISPLAY"))
|
|
||||||
{
|
{
|
||||||
aDisplayName = aValue;
|
aDisplayName = aValue;
|
||||||
}
|
}
|
||||||
#endif
|
else if (aName == "w"
|
||||||
else if (aName.IsEqual ("W")
|
|| aName == "width")
|
||||||
|| aName.IsEqual ("WIDTH"))
|
|
||||||
{
|
{
|
||||||
aPxWidth = aValue.IntegerValue();
|
aPxWidth = aValue.IntegerValue();
|
||||||
}
|
}
|
||||||
else if (aName.IsEqual ("H")
|
else if (aName == "h"
|
||||||
|| aName.IsEqual ("HEIGHT"))
|
|| aName == "height")
|
||||||
{
|
{
|
||||||
aPxHeight = aValue.IntegerValue();
|
aPxHeight = aValue.IntegerValue();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
std::cerr << theArgVec[0] << ": Warning: unknown argument " << anArg << ".\n";
|
std::cout << "Syntax error: unknown argument " << anArg << ".\n";
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (aViewName.IsEmpty())
|
else if (aViewName.IsEmpty())
|
||||||
@ -832,10 +884,19 @@ static int VInit (Draw_Interpretor& theDi, Standard_Integer theArgsNb, const cha
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
std::cerr << theArgVec[0] << ": Warning: unknown argument " << anArg << ".\n";
|
std::cout << "Syntax error: unknown argument " << anArg << ".\n";
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(_WIN32) || (defined(__APPLE__) && !defined(MACOSX_USE_GLX))
|
||||||
|
if (!aDisplayName.IsEmpty())
|
||||||
|
{
|
||||||
|
aDisplayName.Clear();
|
||||||
|
std::cout << "Warning: display parameter will be ignored.\n";
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
ViewerTest_Names aViewNames (aViewName);
|
ViewerTest_Names aViewNames (aViewName);
|
||||||
if (ViewerTest_myViews.IsBound1 (aViewNames.GetViewName()))
|
if (ViewerTest_myViews.IsBound1 (aViewNames.GetViewName()))
|
||||||
{
|
{
|
||||||
@ -1258,7 +1319,10 @@ void ViewerTest::RemoveView (const TCollection_AsciiString& theViewName, const S
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
cout << "3D View - " << theViewName << " was deleted.\n";
|
cout << "3D View - " << theViewName << " was deleted.\n";
|
||||||
|
if (Draw_ToExitOnCloseView)
|
||||||
|
{
|
||||||
|
Draw_Interprete ("exit");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
@ -1625,6 +1689,15 @@ void VT_ProcessKeyPress (const char* buf_ret)
|
|||||||
Draw_Interprete ("verase");
|
Draw_Interprete ("verase");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (*buf_ret == THE_KEY_ESCAPE)
|
||||||
|
{
|
||||||
|
Handle(AIS_InteractiveContext) aCtx = ViewerTest::GetAISContext();
|
||||||
|
if (!aCtx.IsNull()
|
||||||
|
&& Draw_ToCloseViewOnEsc)
|
||||||
|
{
|
||||||
|
Draw_Interprete (Draw_ToExitOnCloseView ? "exit" : "vclose");
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Number
|
// Number
|
||||||
@ -2149,6 +2222,10 @@ static LRESULT WINAPI ViewerWindowProc( HWND hwnd,
|
|||||||
{
|
{
|
||||||
c[0] = THE_KEY_DELETE;
|
c[0] = THE_KEY_DELETE;
|
||||||
}
|
}
|
||||||
|
else if (wParam == VK_ESCAPE)
|
||||||
|
{
|
||||||
|
c[0] = THE_KEY_ESCAPE;
|
||||||
|
}
|
||||||
// comma
|
// comma
|
||||||
else if (wParam == VK_OEM_COMMA)
|
else if (wParam == VK_OEM_COMMA)
|
||||||
{
|
{
|
||||||
@ -5990,6 +6067,117 @@ static int VReadPixel (Draw_Interpretor& theDI,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//! Auxiliary presentation for an image plane.
|
||||||
|
class ViewerTest_ImagePrs : public AIS_InteractiveObject
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
//! Main constructor.
|
||||||
|
ViewerTest_ImagePrs (const Handle(Image_PixMap)& theImage,
|
||||||
|
const Standard_Real theWidth,
|
||||||
|
const Standard_Real theHeight,
|
||||||
|
const TCollection_AsciiString& theLabel)
|
||||||
|
: myLabel (theLabel), myWidth (theWidth), myHeight(theHeight)
|
||||||
|
{
|
||||||
|
SetDisplayMode (0);
|
||||||
|
SetHilightMode (1);
|
||||||
|
myDynHilightDrawer->SetZLayer (Graphic3d_ZLayerId_Topmost);
|
||||||
|
{
|
||||||
|
myDrawer->SetShadingAspect (new Prs3d_ShadingAspect());
|
||||||
|
const Handle(Graphic3d_AspectFillArea3d)& aFillAspect = myDrawer->ShadingAspect()->Aspect();
|
||||||
|
Graphic3d_MaterialAspect aMat;
|
||||||
|
aMat.SetMaterialType (Graphic3d_MATERIAL_PHYSIC);
|
||||||
|
aMat.SetAmbient (1.0);
|
||||||
|
aMat.SetDiffuse (1.0);
|
||||||
|
aMat.SetSpecular (1.0);
|
||||||
|
aMat.SetEmissive (1.0);
|
||||||
|
aMat.SetReflectionModeOn (Graphic3d_TOR_AMBIENT);
|
||||||
|
aMat.SetReflectionModeOn (Graphic3d_TOR_DIFFUSE);
|
||||||
|
aMat.SetReflectionModeOn (Graphic3d_TOR_SPECULAR);
|
||||||
|
aMat.SetReflectionModeOn (Graphic3d_TOR_EMISSION);
|
||||||
|
aMat.SetAmbientColor (Quantity_Color (0.0, 0.0, 0.0, Quantity_TOC_RGB));
|
||||||
|
aMat.SetDiffuseColor (Quantity_Color (1.0, 1.0, 1.0, Quantity_TOC_RGB));
|
||||||
|
aMat.SetSpecularColor (Quantity_Color (0.0, 0.0, 0.0, Quantity_TOC_RGB));
|
||||||
|
aMat.SetEmissiveColor (Quantity_Color (0.0, 0.0, 0.0, Quantity_TOC_RGB));
|
||||||
|
aFillAspect->SetFrontMaterial (aMat);
|
||||||
|
aFillAspect->SetTextureMap (new Graphic3d_Texture2Dmanual (theImage));
|
||||||
|
aFillAspect->SetTextureMapOn();
|
||||||
|
}
|
||||||
|
{
|
||||||
|
Handle(Prs3d_TextAspect) aTextAspect = new Prs3d_TextAspect();
|
||||||
|
aTextAspect->SetHorizontalJustification (Graphic3d_HTA_CENTER);
|
||||||
|
aTextAspect->SetVerticalJustification (Graphic3d_VTA_CENTER);
|
||||||
|
myDrawer->SetTextAspect (aTextAspect);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
const gp_Dir aNorm (0.0, 0.0, 1.0);
|
||||||
|
myTris = new Graphic3d_ArrayOfTriangles (4, 6, true, false, true);
|
||||||
|
myTris->AddVertex (gp_Pnt(-myWidth * 0.5, -myHeight * 0.5, 0.0), aNorm, gp_Pnt2d (0.0, 0.0));
|
||||||
|
myTris->AddVertex (gp_Pnt( myWidth * 0.5, -myHeight * 0.5, 0.0), aNorm, gp_Pnt2d (1.0, 0.0));
|
||||||
|
myTris->AddVertex (gp_Pnt(-myWidth * 0.5, myHeight * 0.5, 0.0), aNorm, gp_Pnt2d (0.0, 1.0));
|
||||||
|
myTris->AddVertex (gp_Pnt( myWidth * 0.5, myHeight * 0.5, 0.0), aNorm, gp_Pnt2d (1.0, 1.0));
|
||||||
|
myTris->AddEdge (1);
|
||||||
|
myTris->AddEdge (2);
|
||||||
|
myTris->AddEdge (3);
|
||||||
|
myTris->AddEdge (3);
|
||||||
|
myTris->AddEdge (2);
|
||||||
|
myTris->AddEdge (4);
|
||||||
|
|
||||||
|
myRect = new Graphic3d_ArrayOfPolylines (4);
|
||||||
|
myRect->AddVertex (myTris->Vertice (1));
|
||||||
|
myRect->AddVertex (myTris->Vertice (3));
|
||||||
|
myRect->AddVertex (myTris->Vertice (4));
|
||||||
|
myRect->AddVertex (myTris->Vertice (2));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Returns TRUE for accepted display modes.
|
||||||
|
virtual Standard_Boolean AcceptDisplayMode (const Standard_Integer theMode) const Standard_OVERRIDE { return theMode == 0 || theMode == 1; }
|
||||||
|
|
||||||
|
//! Compute presentation.
|
||||||
|
virtual void Compute (const Handle(PrsMgr_PresentationManager3d)& , const Handle(Prs3d_Presentation)& thePrs, const Standard_Integer theMode) Standard_OVERRIDE
|
||||||
|
{
|
||||||
|
switch (theMode)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
{
|
||||||
|
Handle(Graphic3d_Group) aGroup = thePrs->NewGroup();
|
||||||
|
aGroup->AddPrimitiveArray (myTris);
|
||||||
|
aGroup->SetGroupPrimitivesAspect (myDrawer->ShadingAspect()->Aspect());
|
||||||
|
aGroup->AddPrimitiveArray (myRect);
|
||||||
|
aGroup->SetGroupPrimitivesAspect (myDrawer->LineAspect()->Aspect());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case 1:
|
||||||
|
{
|
||||||
|
Prs3d_Text::Draw (thePrs->NewGroup(), myDrawer->TextAspect(), myLabel, gp_Pnt(0.0, 0.0, 0.0));
|
||||||
|
Handle(Graphic3d_Group) aGroup = thePrs->NewGroup();
|
||||||
|
aGroup->AddPrimitiveArray (myRect);
|
||||||
|
aGroup->SetGroupPrimitivesAspect (myDrawer->LineAspect()->Aspect());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Compute selection.
|
||||||
|
virtual void ComputeSelection (const Handle(SelectMgr_Selection)& theSel, const Standard_Integer theMode) Standard_OVERRIDE
|
||||||
|
{
|
||||||
|
if (theMode == 0)
|
||||||
|
{
|
||||||
|
Handle(SelectMgr_EntityOwner) anEntityOwner = new SelectMgr_EntityOwner (this, 5);
|
||||||
|
Handle(Select3D_SensitivePrimitiveArray) aSensitive = new Select3D_SensitivePrimitiveArray (anEntityOwner);
|
||||||
|
aSensitive->InitTriangulation (myTris->Attributes(), myTris->Indices(), TopLoc_Location());
|
||||||
|
theSel->Add (aSensitive);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
Handle(Graphic3d_ArrayOfTriangles) myTris;
|
||||||
|
Handle(Graphic3d_ArrayOfPolylines) myRect;
|
||||||
|
TCollection_AsciiString myLabel;
|
||||||
|
Standard_Real myWidth;
|
||||||
|
Standard_Real myHeight;
|
||||||
|
};
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
//function : VDiffImage
|
//function : VDiffImage
|
||||||
//purpose : The draw-command compares two images.
|
//purpose : The draw-command compares two images.
|
||||||
@ -5997,47 +6185,238 @@ static int VReadPixel (Draw_Interpretor& theDI,
|
|||||||
|
|
||||||
static int VDiffImage (Draw_Interpretor& theDI, Standard_Integer theArgNb, const char** theArgVec)
|
static int VDiffImage (Draw_Interpretor& theDI, Standard_Integer theArgNb, const char** theArgVec)
|
||||||
{
|
{
|
||||||
if (theArgNb < 6)
|
if (theArgNb < 3)
|
||||||
{
|
{
|
||||||
theDI << "Not enough arguments.\n";
|
std::cout << "Syntax error: not enough arguments.\n";
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// image file names
|
Standard_Integer anArgIter = 1;
|
||||||
const char* anImgPathRef = theArgVec[1];
|
TCollection_AsciiString anImgPathRef (theArgVec[anArgIter++]);
|
||||||
const char* anImgPathNew = theArgVec[2];
|
TCollection_AsciiString anImgPathNew (theArgVec[anArgIter++]);
|
||||||
|
TCollection_AsciiString aDiffImagePath;
|
||||||
|
Standard_Real aTolColor = -1.0;
|
||||||
|
Standard_Integer toBlackWhite = -1;
|
||||||
|
Standard_Integer isBorderFilterOn = -1;
|
||||||
|
Standard_Boolean isOldSyntax = Standard_False;
|
||||||
|
TCollection_AsciiString aViewName, aPrsNameRef, aPrsNameNew, aPrsNameDiff;
|
||||||
|
for (; anArgIter < theArgNb; ++anArgIter)
|
||||||
|
{
|
||||||
|
TCollection_AsciiString anArg (theArgVec[anArgIter]);
|
||||||
|
anArg.LowerCase();
|
||||||
|
if (anArgIter + 1 < theArgNb
|
||||||
|
&& (anArg == "-toleranceofcolor"
|
||||||
|
|| anArg == "-tolerancecolor"
|
||||||
|
|| anArg == "-tolerance"
|
||||||
|
|| anArg == "-toler"))
|
||||||
|
{
|
||||||
|
aTolColor = Atof (theArgVec[++anArgIter]);
|
||||||
|
if (aTolColor < 0.0 || aTolColor > 1.0)
|
||||||
|
{
|
||||||
|
std::cout << "Syntax error at '" << anArg << " " << theArgVec[anArgIter] << "'\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (anArg == "-blackwhite")
|
||||||
|
{
|
||||||
|
Standard_Boolean toEnable = Standard_True;
|
||||||
|
if (anArgIter + 1 < theArgNb
|
||||||
|
&& ViewerTest::ParseOnOff (theArgVec[anArgIter + 1], toEnable))
|
||||||
|
{
|
||||||
|
++anArgIter;
|
||||||
|
}
|
||||||
|
toBlackWhite = toEnable ? 1 : 0;
|
||||||
|
}
|
||||||
|
else if (anArg == "-borderfilter")
|
||||||
|
{
|
||||||
|
Standard_Boolean toEnable = Standard_True;
|
||||||
|
if (anArgIter + 1 < theArgNb
|
||||||
|
&& ViewerTest::ParseOnOff (theArgVec[anArgIter + 1], toEnable))
|
||||||
|
{
|
||||||
|
++anArgIter;
|
||||||
|
}
|
||||||
|
isBorderFilterOn = toEnable ? 1 : 0;
|
||||||
|
}
|
||||||
|
else if (anArg == "-exitonclose")
|
||||||
|
{
|
||||||
|
Draw_ToExitOnCloseView = true;
|
||||||
|
if (anArgIter + 1 < theArgNb
|
||||||
|
&& ViewerTest::ParseOnOff (theArgVec[anArgIter + 1], Draw_ToExitOnCloseView))
|
||||||
|
{
|
||||||
|
++anArgIter;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (anArg == "-closeonescape"
|
||||||
|
|| anArg == "-closeonesc")
|
||||||
|
{
|
||||||
|
Draw_ToCloseViewOnEsc = true;
|
||||||
|
if (anArgIter + 1 < theArgNb
|
||||||
|
&& ViewerTest::ParseOnOff (theArgVec[anArgIter + 1], Draw_ToCloseViewOnEsc))
|
||||||
|
{
|
||||||
|
++anArgIter;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (anArgIter + 3 < theArgNb
|
||||||
|
&& anArg == "-display")
|
||||||
|
{
|
||||||
|
aViewName = theArgVec[++anArgIter];
|
||||||
|
aPrsNameRef = theArgVec[++anArgIter];
|
||||||
|
aPrsNameNew = theArgVec[++anArgIter];
|
||||||
|
if (anArgIter + 1 < theArgNb
|
||||||
|
&& *theArgVec[anArgIter + 1] != '-')
|
||||||
|
{
|
||||||
|
aPrsNameDiff = theArgVec[++anArgIter];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (aTolColor < 0.0
|
||||||
|
&& anArg.IsRealValue())
|
||||||
|
{
|
||||||
|
isOldSyntax = Standard_True;
|
||||||
|
aTolColor = anArg.RealValue();
|
||||||
|
if (aTolColor < 0.0 || aTolColor > 1.0)
|
||||||
|
{
|
||||||
|
std::cout << "Syntax error at '" << anArg << " " << theArgVec[anArgIter] << "'\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (isOldSyntax
|
||||||
|
&& toBlackWhite == -1
|
||||||
|
&& (anArg == "0" || anArg == "1"))
|
||||||
|
{
|
||||||
|
toBlackWhite = anArg == "1" ? 1 : 0;
|
||||||
|
}
|
||||||
|
else if (isOldSyntax
|
||||||
|
&& isBorderFilterOn == -1
|
||||||
|
&& (anArg == "0" || anArg == "1"))
|
||||||
|
{
|
||||||
|
isBorderFilterOn = anArg == "1" ? 1 : 0;
|
||||||
|
}
|
||||||
|
else if (aDiffImagePath.IsEmpty())
|
||||||
|
{
|
||||||
|
aDiffImagePath = theArgVec[anArgIter];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::cout << "Syntax error at '" << theArgVec[anArgIter] << "'\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// get string tolerance and check its validity
|
Handle(Image_AlienPixMap) anImgRef = new Image_AlienPixMap();
|
||||||
Standard_Real aTolColor = Draw::Atof (theArgVec[3]);
|
Handle(Image_AlienPixMap) anImgNew = new Image_AlienPixMap();
|
||||||
if (aTolColor < 0.0)
|
if (!anImgRef->Load (anImgPathRef))
|
||||||
aTolColor = 0.0;
|
{
|
||||||
if (aTolColor > 1.0)
|
std::cout << "Error: image file '" << anImgPathRef << "' cannot be read\n";
|
||||||
aTolColor = 1.0;
|
return 1;
|
||||||
|
}
|
||||||
Standard_Boolean toBlackWhite = (Draw::Atoi (theArgVec[4]) == 1);
|
if (!anImgNew->Load (anImgPathNew))
|
||||||
Standard_Boolean isBorderFilterOn = (Draw::Atoi (theArgVec[5]) == 1);
|
{
|
||||||
|
std::cout << "Error: image file '" << anImgPathNew << "' cannot be read\n";
|
||||||
// image file of difference
|
return 1;
|
||||||
const char* aDiffImagePath = (theArgNb >= 7) ? theArgVec[6] : NULL;
|
}
|
||||||
|
|
||||||
// compare the images
|
// compare the images
|
||||||
Image_Diff aComparer;
|
Image_Diff aComparer;
|
||||||
if (!aComparer.Init (anImgPathRef, anImgPathNew, toBlackWhite))
|
Standard_Integer aDiffColorsNb = -1;
|
||||||
|
if (aComparer.Init (anImgRef, anImgNew, toBlackWhite == 1))
|
||||||
{
|
{
|
||||||
return 1;
|
aComparer.SetColorTolerance (aTolColor >= 0.0 ? aTolColor : 0.0);
|
||||||
}
|
aComparer.SetBorderFilterOn (isBorderFilterOn == 1);
|
||||||
|
aDiffColorsNb = aComparer.Compare();
|
||||||
aComparer.SetColorTolerance (aTolColor);
|
|
||||||
aComparer.SetBorderFilterOn (isBorderFilterOn);
|
|
||||||
Standard_Integer aDiffColorsNb = aComparer.Compare();
|
|
||||||
theDI << aDiffColorsNb << "\n";
|
theDI << aDiffColorsNb << "\n";
|
||||||
|
}
|
||||||
|
|
||||||
// save image of difference
|
// save image of difference
|
||||||
if (aDiffColorsNb >0 && aDiffImagePath != NULL)
|
Handle(Image_AlienPixMap) aDiff;
|
||||||
|
if (aDiffColorsNb > 0
|
||||||
|
&& (!aDiffImagePath.IsEmpty() || !aPrsNameDiff.IsEmpty()))
|
||||||
{
|
{
|
||||||
aComparer.SaveDiffImage (aDiffImagePath);
|
aDiff = new Image_AlienPixMap();
|
||||||
|
if (!aDiff->InitTrash (Image_Format_Gray, anImgRef->SizeX(), anImgRef->SizeY()))
|
||||||
|
{
|
||||||
|
std::cout << "Error: cannot allocate memory for diff image " << anImgRef->SizeX() << "x" << anImgRef->SizeY() << "\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
aComparer.SaveDiffImage (*aDiff);
|
||||||
|
if (!aDiffImagePath.IsEmpty()
|
||||||
|
&& !aDiff->Save (aDiffImagePath))
|
||||||
|
{
|
||||||
|
std::cout << "Error: diff image file '" << aDiffImagePath << "' cannot be written\n";
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (aViewName.IsEmpty())
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
ViewerTest_Names aViewNames (aViewName);
|
||||||
|
if (ViewerTest_myViews.IsBound1 (aViewNames.GetViewName()))
|
||||||
|
{
|
||||||
|
TCollection_AsciiString aCommand = TCollection_AsciiString ("vclose ") + aViewNames.GetViewName();
|
||||||
|
theDI.Eval (aCommand.ToCString());
|
||||||
|
}
|
||||||
|
|
||||||
|
Standard_Integer aPxLeft = 0;
|
||||||
|
Standard_Integer aPxTop = 0;
|
||||||
|
Standard_Integer aWinSizeX = int(anImgRef->SizeX() * 2);
|
||||||
|
Standard_Integer aWinSizeY = !aDiff.IsNull() && !aPrsNameDiff.IsEmpty()
|
||||||
|
? int(anImgRef->SizeY() * 2)
|
||||||
|
: int(anImgRef->SizeY());
|
||||||
|
TCollection_AsciiString aDisplayName;
|
||||||
|
TCollection_AsciiString aViewId = ViewerTest::ViewerInit (aPxLeft, aPxTop,
|
||||||
|
aWinSizeX, aWinSizeY,
|
||||||
|
aViewName.ToCString(),
|
||||||
|
aDisplayName.ToCString());
|
||||||
|
|
||||||
|
Standard_Real aRatio = anImgRef->Ratio();
|
||||||
|
Standard_Real aSizeX = 1.0;
|
||||||
|
Standard_Real aSizeY = aSizeX / aRatio;
|
||||||
|
{
|
||||||
|
OSD_Path aPath (anImgPathRef);
|
||||||
|
TCollection_AsciiString aLabelRef;
|
||||||
|
if (!aPath.Name().IsEmpty())
|
||||||
|
{
|
||||||
|
aLabelRef = aPath.Name() + aPath.Extension();
|
||||||
|
}
|
||||||
|
aLabelRef += TCollection_AsciiString() + "\n" + int(anImgRef->SizeX()) + "x" + int(anImgRef->SizeY());
|
||||||
|
|
||||||
|
Handle(ViewerTest_ImagePrs) anImgRefPrs = new ViewerTest_ImagePrs (anImgRef, aSizeX, aSizeY, aLabelRef);
|
||||||
|
gp_Trsf aTrsfRef;
|
||||||
|
aTrsfRef.SetTranslationPart (gp_Vec (-aSizeX * 0.5, 0.0, 0.0));
|
||||||
|
anImgRefPrs->SetLocalTransformation (aTrsfRef);
|
||||||
|
ViewerTest::Display (aPrsNameRef, anImgRefPrs, false, true);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
OSD_Path aPath (anImgPathNew);
|
||||||
|
TCollection_AsciiString aLabelNew;
|
||||||
|
if (!aPath.Name().IsEmpty())
|
||||||
|
{
|
||||||
|
aLabelNew = aPath.Name() + aPath.Extension();
|
||||||
|
}
|
||||||
|
aLabelNew += TCollection_AsciiString() + "\n" + int(anImgNew->SizeX()) + "x" + int(anImgNew->SizeY());
|
||||||
|
|
||||||
|
Handle(ViewerTest_ImagePrs) anImgNewPrs = new ViewerTest_ImagePrs (anImgNew, aSizeX, aSizeY, aLabelNew);
|
||||||
|
gp_Trsf aTrsfRef;
|
||||||
|
aTrsfRef.SetTranslationPart (gp_Vec (aSizeX * 0.5, 0.0, 0.0));
|
||||||
|
anImgNewPrs->SetLocalTransformation (aTrsfRef);
|
||||||
|
ViewerTest::Display (aPrsNameNew, anImgNewPrs, false, true);
|
||||||
|
}
|
||||||
|
Handle(ViewerTest_ImagePrs) anImgDiffPrs;
|
||||||
|
if (!aDiff.IsNull())
|
||||||
|
{
|
||||||
|
anImgDiffPrs = new ViewerTest_ImagePrs (aDiff, aSizeX, aSizeY, TCollection_AsciiString() + "Difference: " + aDiffColorsNb + " pixels");
|
||||||
|
gp_Trsf aTrsfDiff;
|
||||||
|
aTrsfDiff.SetTranslationPart (gp_Vec (0.0, -aSizeY, 0.0));
|
||||||
|
anImgDiffPrs->SetLocalTransformation (aTrsfDiff);
|
||||||
|
}
|
||||||
|
if (!aPrsNameDiff.IsEmpty())
|
||||||
|
{
|
||||||
|
ViewerTest::Display (aPrsNameDiff, anImgDiffPrs, false, true);
|
||||||
|
}
|
||||||
|
ViewerTest::CurrentView()->SetProj (V3d_Zpos);
|
||||||
|
ViewerTest::CurrentView()->FitAll();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10952,24 +11331,26 @@ void ViewerTest::ViewerCommands(Draw_Interpretor& theCommands)
|
|||||||
|
|
||||||
const char *group = "ZeViewer";
|
const char *group = "ZeViewer";
|
||||||
theCommands.Add("vinit",
|
theCommands.Add("vinit",
|
||||||
#if !defined(_WIN32) && !defined(__WIN32__) && (!defined(__APPLE__) || defined(MACOSX_USE_GLX))
|
"vinit [-name viewName] [-left leftPx] [-top topPx] [-width widthPx] [-height heightPx]"
|
||||||
"[name=view_name] [display=display_name] [l=leftPx t=topPx] [w=widthPx h=heightPx]\n"
|
"\n\t\t: [-exitOnClose] [-closeOnEscape]"
|
||||||
#else
|
#if !defined(_WIN32) && (!defined(__APPLE__) || defined(MACOSX_USE_GLX))
|
||||||
"[name=view_name] [l=leftPx t=topPx] [w=widthPx h=heightPx]\n"
|
"\n\t\t: [-display displayName]"
|
||||||
#endif
|
#endif
|
||||||
" - Creates new View window with specified name view_name.\n"
|
"\n\t\t: Creates new View window with specified name viewName."
|
||||||
"By default the new view is created in the viewer and in"
|
"\n\t\t: By default the new view is created in the viewer and in"
|
||||||
" graphic driver shared with active view.\n"
|
"\n\t\t: graphic driver shared with active view."
|
||||||
" - name = {driverName/viewerName/viewName | viewerName/viewName | viewName}.\n"
|
"\n\t\t: -name {driverName/viewerName/viewName | viewerName/viewName | viewName}"
|
||||||
"If driverName isn't specified the driver will be shared with active view.\n"
|
"\n\t\t: If driverName isn't specified the driver will be shared with active view."
|
||||||
"If viewerName isn't specified the viewer will be shared with active view.\n"
|
"\n\t\t: If viewerName isn't specified the viewer will be shared with active view."
|
||||||
#if !defined(_WIN32) && !defined(__WIN32__) && (!defined(__APPLE__) || defined(MACOSX_USE_GLX))
|
#if !defined(_WIN32) && (!defined(__APPLE__) || defined(MACOSX_USE_GLX))
|
||||||
" - display = HostName.DisplayNumber[:ScreenNumber] : if specified"
|
"\n\t\t: -display HostName.DisplayNumber[:ScreenNumber]"
|
||||||
"is used in creation of graphic driver\n"
|
"\n\t\t: Display name will be used within creation of graphic driver, when specified."
|
||||||
#endif
|
#endif
|
||||||
" - l, t: pixel position of left top corner of the window\n"
|
"\n\t\t: -left, -top pixel position of left top corner of the window."
|
||||||
" - w,h: width and heigth of window respectively.\n"
|
"\n\t\t: -width, -height width and heigth of window respectively."
|
||||||
"Additional commands for operations with views: vclose, vactivate, vviewlist.\n",
|
"\n\t\t: -exitOnClose when specified, closing the view will exit application."
|
||||||
|
"\n\t\t: -closeOnEscape when specified, view will be closed on pressing Escape."
|
||||||
|
"\n\t\t: Additional commands for operations with views: vclose, vactivate, vviewlist.",
|
||||||
__FILE__,VInit,group);
|
__FILE__,VInit,group);
|
||||||
theCommands.Add("vclose" ,
|
theCommands.Add("vclose" ,
|
||||||
"[view_id [keep_context=0|1]]\n"
|
"[view_id [keep_context=0|1]]\n"
|
||||||
@ -11263,7 +11644,12 @@ void ViewerTest::ViewerCommands(Draw_Interpretor& theCommands)
|
|||||||
" : Read pixel value for active view",
|
" : Read pixel value for active view",
|
||||||
__FILE__, VReadPixel, group);
|
__FILE__, VReadPixel, group);
|
||||||
theCommands.Add("diffimage",
|
theCommands.Add("diffimage",
|
||||||
"diffimage : diffimage imageFile1 imageFile2 toleranceOfColor(0..1) blackWhite(1|0) borderFilter(1|0) [diffImageFile]",
|
"diffimage imageFile1 imageFile2 [diffImageFile]"
|
||||||
|
"\n\t\t: [-toleranceOfColor {0..1}=0] [-blackWhite {on|off}=off] [-borderFilter {on|off}=off]"
|
||||||
|
"\n\t\t: [-display viewName prsName1 prsName2 prsNameDiff] [-exitOnClose] [-closeOnEscape]"
|
||||||
|
"\n\t\t: Compare two images by content and generate difference image."
|
||||||
|
"\n\t\t: When -exitOnClose is specified, closing the view will exit application."
|
||||||
|
"\n\t\t: When -closeOnEscape is specified, view will be closed on pressing Escape.",
|
||||||
__FILE__, VDiffImage, group);
|
__FILE__, VDiffImage, group);
|
||||||
theCommands.Add ("vselect",
|
theCommands.Add ("vselect",
|
||||||
"vselect x1 y1 [x2 y2 [x3 y3 ... xn yn]] [-allowoverlap 0|1] [shift_selection = 0|1]\n"
|
"vselect x1 y1 [x2 y2 [x3 y3 ... xn yn]] [-allowoverlap 0|1] [shift_selection = 0|1]\n"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user