mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
Quantity_Factor, Quantity_Parameter, Quantity_Ratio, Quantity_Coefficient, Quantity_PlaneAngle, Quantity_Length, V3d_Parameter and V3d_Coordinate have been replaced by Standard_Real in visualization classes.
44 lines
1.6 KiB
C++
Executable File
44 lines
1.6 KiB
C++
Executable File
#include "stdafx.h"
|
|
|
|
#include "Sample2D_Image.h"
|
|
|
|
IMPLEMENT_STANDARD_RTTIEXT(Sample2D_Image,AIS_TexturedShape)
|
|
|
|
Sample2D_Image::Sample2D_Image(TCollection_AsciiString& aFileName,
|
|
const Standard_Real X,
|
|
const Standard_Real Y,
|
|
const Standard_Real aScale)
|
|
:AIS_TexturedShape(TopoDS_Shape())
|
|
{
|
|
myFilename = aFileName;
|
|
myX = X;
|
|
myY = Y;
|
|
myScale = aScale;
|
|
}
|
|
void Sample2D_Image::MakeShape()
|
|
{
|
|
Handle(Graphic3d_Texture1D) anImageTexture =
|
|
new Graphic3d_Texture1Dsegment(myFilename);
|
|
Standard_Real coeff = (Standard_Real)(anImageTexture->GetImage()->Height())/
|
|
(anImageTexture->GetImage()->Width())*myScale;
|
|
TopoDS_Edge E1 = BRepBuilderAPI_MakeEdge(gp_Pnt(myX,myY,0.), gp_Pnt(100*myScale+myX,myY,0.));
|
|
TopoDS_Edge E2 = BRepBuilderAPI_MakeEdge(gp_Pnt(100*myScale+myX,myY,0.), gp_Pnt(100*myScale+myX,100*coeff+myY,0.));
|
|
TopoDS_Edge E3 = BRepBuilderAPI_MakeEdge(gp_Pnt(100*myScale+myX,100*coeff+myY,0.), gp_Pnt(myX,100*coeff+myY,0.));
|
|
TopoDS_Edge E4 = BRepBuilderAPI_MakeEdge(gp_Pnt(myX,100*coeff+myY,0.), gp_Pnt(myX,myY,0.));
|
|
TopoDS_Wire anImageBounds = BRepBuilderAPI_MakeWire(E1,E2,E3,E4);
|
|
myFace = BRepBuilderAPI_MakeFace(gp_Pln(gp_Pnt(0,0,0),gp_Dir(0,0,1)),anImageBounds);
|
|
}
|
|
|
|
void Sample2D_Image::SetContext(const Handle(AIS_InteractiveContext)& theContext)
|
|
{
|
|
if(theContext.IsNull() || theContext->CurrentViewer().IsNull()) return;
|
|
AIS_InteractiveObject::SetContext(theContext);
|
|
MakeShape();
|
|
this->Set(TopoDS_Shape(myFace));
|
|
this->SetTextureFileName(myFilename);
|
|
|
|
}
|
|
|
|
|
|
|