1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0023544: Texture management in TKOpenGl should be redesigned

Structures Graphic3d_CView, Graphic3d_CStructure, Graphic3d_CGroup become classes and their definitions moved from InterfaceGraphic to Graphic3d.
Introduced new class OpenGl_Texture as replacement for OpenGl_ResourceTexture class and static functions in OpenGl_TextureBox.
Graphic3d_TextureRoot now no more communicate within Graphic3d_GraphicalDriver.
Instead class returns image through GetImage() method.
OpenGl_AspectFace - avoid possible NULL-dereference
OpenGl_Texture::Init() - check gluBuild2DMipmaps() return value
OpenGl_Texture - check GL_BGRA_EXT for compatibility
OpenGl_Texture - scale NPOT image when required
Added more description to Graphic3d_TextureRoot class
OpenGl_Texture - added missing break statement for ImgBGR32 case
OpenGl_Workspace::setTextureParams() - fixed local variable aFilterMin overrides visibility of early declared variable
OpenGl_Workspace::DisableTexture() - reset texture matrix
FTGL do not reset texture matrix and corrupt text could be rendered if custom texture has not identity texture matrix.
This commit is contained in:
kgv 2012-12-07 13:58:30 +04:00
parent ab8fcacf28
commit bf75be9867
92 changed files with 3647 additions and 3857 deletions

3
.gitignore vendored
View File

@ -15,7 +15,8 @@
# project files and artifacts # project files and artifacts
/adm/msvc /adm/msvc
/adm/wnt/cbp /adm/wnt
/adm/lin
/adm/mac /adm/mac
/adm/make /adm/make
*.vcproj*user *.vcproj*user

View File

@ -177,7 +177,7 @@ void AIS_TexturedShape::EnableTextureModulate()
//======================================================================= //=======================================================================
//function : DisableTextureModulate //function : DisableTextureModulate
//purpose : //purpose :
//======================================================================= //=======================================================================
void AIS_TexturedShape::DisableTextureModulate() void AIS_TexturedShape::DisableTextureModulate()
@ -192,7 +192,6 @@ void AIS_TexturedShape::DisableTextureModulate()
void AIS_TexturedShape::UpdateAttributes() void AIS_TexturedShape::UpdateAttributes()
{ {
Handle(Graphic3d_StructureManager) aStrucMana = GetContext()->MainPrsMgr()->StructureManager();
Prs3d_ShadingAspect aDummy; Prs3d_ShadingAspect aDummy;
myAspect = aDummy.Aspect(); myAspect = aDummy.Aspect();
Handle(Prs3d_Presentation) aPrs = Presentation(); Handle(Prs3d_Presentation) aPrs = Presentation();
@ -203,9 +202,9 @@ void AIS_TexturedShape::UpdateAttributes()
} }
if (myPredefTexture != -1) if (myPredefTexture != -1)
mytexture = new Graphic3d_Texture2Dmanual (aStrucMana, myPredefTexture); mytexture = new Graphic3d_Texture2Dmanual (myPredefTexture);
else else
mytexture = new Graphic3d_Texture2Dmanual (aStrucMana, myTextureFile.ToCString()); mytexture = new Graphic3d_Texture2Dmanual (myTextureFile.ToCString());
myAspect->SetTextureMapOn(); myAspect->SetTextureMapOn();
@ -323,7 +322,6 @@ void AIS_TexturedShape::Compute (const Handle(PrsMgr_PresentationManager3d)& /*t
BRepTools::Clean (myshape); BRepTools::Clean (myshape);
BRepTools::Update (myshape); BRepTools::Update (myshape);
Handle(Graphic3d_StructureManager) aStrucMana = GetContext()->MainPrsMgr()->StructureManager();
{ {
Handle(Prs3d_ShadingAspect) aPrs3d_ShadingAspect = new Prs3d_ShadingAspect(); Handle(Prs3d_ShadingAspect) aPrs3d_ShadingAspect = new Prs3d_ShadingAspect();
myAspect = aPrs3d_ShadingAspect->Aspect(); myAspect = aPrs3d_ShadingAspect->Aspect();
@ -345,9 +343,9 @@ void AIS_TexturedShape::Compute (const Handle(PrsMgr_PresentationManager3d)& /*t
myAspect->SetTextureMapOn(); myAspect->SetTextureMapOn();
if (myPredefTexture != -1) if (myPredefTexture != -1)
mytexture = new Graphic3d_Texture2Dmanual (aStrucMana, myPredefTexture); mytexture = new Graphic3d_Texture2Dmanual (myPredefTexture);
else else
mytexture = new Graphic3d_Texture2Dmanual (aStrucMana, myTextureFile.ToCString()); mytexture = new Graphic3d_Texture2Dmanual (myTextureFile.ToCString());
if (!mytexture->IsDone()) if (!mytexture->IsDone())
{ {

View File

@ -10,8 +10,6 @@ Graphic3d_CBitFields8.cxx
Graphic3d_CBitFields8.hxx Graphic3d_CBitFields8.hxx
Graphic3d_CBitFields4.cxx Graphic3d_CBitFields4.cxx
Graphic3d_CBitFields4.hxx Graphic3d_CBitFields4.hxx
Graphic3d_CInitTexture.cxx
Graphic3d_CInitTexture.hxx
Graphic3d_CTexture.cxx Graphic3d_CTexture.cxx
Graphic3d_CTexture.hxx Graphic3d_CTexture.hxx
Graphic3d_CLight.cxx Graphic3d_CLight.cxx
@ -53,3 +51,6 @@ Graphic3d_AspectText3d.cxx
Graphic3d_WNTGraphicDevice.cxx Graphic3d_WNTGraphicDevice.cxx
Graphic3d_PtrFrameBuffer.hxx Graphic3d_PtrFrameBuffer.hxx
Graphic3d_BufferType.hxx Graphic3d_BufferType.hxx
Graphic3d_Vec2.hxx
Graphic3d_Vec3.hxx
Graphic3d_Vec4.hxx

View File

@ -220,6 +220,21 @@ is
---Purpose: Type of the texture projection. ---Purpose: Type of the texture projection.
---Category: Enumerations ---Category: Enumerations
enumeration TypeOfTextureFilter is TOTF_NEAREST,
TOTF_BILINEAR,
TOTF_TRILINEAR;
---Purpose: Type of the texture filter.
-- Notice that for textures without mipmaps linear interpolation will be used instead of TOTF_BILINEAR and TOTF_TRILINEAR.
---Category: Enumerations
enumeration LevelOfTextureAnisotropy is LOTA_OFF,
LOTA_FAST,
LOTA_MIDDLE,
LOTA_QUALITY;
---Purpose: Level of anisotropy filter.
-- Notice that actual quality depends on hardware capabilities!
---Category: Enumerations
enumeration NameOfTexturePlane is NOTP_XY, enumeration NameOfTexturePlane is NOTP_XY,
NOTP_YZ, NOTP_YZ,
NOTP_ZX, NOTP_ZX,
@ -384,15 +399,15 @@ is
---Purpose: Defines the C structure of a graduated trihedron. ---Purpose: Defines the C structure of a graduated trihedron.
---Category: Imported types ---Category: Imported types
imported CInitTexture;
imported CTexture; imported CTexture;
-- ABD 29/10/04 Transform Persistence of Presentation( pan, zoom, rotate ) imported CTransPersStruct;
imported CTransPersStruct; imported TransModeFlags;
imported TransModeFlags;
-- ABD 29/10/04 Transform Persistence of Presentation( pan, zoom, rotate )
primitive PtrFrameBuffer; primitive PtrFrameBuffer;
primitive Vec2;
primitive Vec3;
primitive Vec4;
-------------------- --------------------
-- Category: Classes -- Category: Classes
@ -614,12 +629,12 @@ is
imported NListOfHAsciiString; imported NListOfHAsciiString;
---Category: Instantiated classes ---Category: Instantiated classes
deferred class TextureRoot from Graphic3d;
deferred class TextureRoot from Graphic3d;
deferred class TextureMap from Graphic3d; deferred class TextureMap from Graphic3d;
deferred class Texture1D from Graphic3d; deferred class Texture1D from Graphic3d;
deferred class Texture2D from Graphic3d; deferred class Texture2D from Graphic3d;
class TextureParams from Graphic3d;
class TextureEnv from Graphic3d; class TextureEnv from Graphic3d;
class Texture1Dmanual from Graphic3d; class Texture1Dmanual from Graphic3d;
class Texture1Dsegment from Graphic3d; class Texture1Dsegment from Graphic3d;

View File

@ -16,24 +16,100 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
/*============================================================================*/
/*==== Titre: Graphic3d_CGroup.hxx */
/*==== Role : The header file of primitive type "CGroup" from Graphic3d */
/*==== */
/*==== Implementation: This is a primitive type implemented with typedef */
/*============================================================================*/
#ifndef _Graphic3d_CGroup_HeaderFile #ifndef _Graphic3d_CGroup_HeaderFile
#define _Graphic3d_CGroup_HeaderFile #define _Graphic3d_CGroup_HeaderFile
#include <InterfaceGraphic_Graphic3d.hxx> #include <InterfaceGraphic_Visual3d.hxx>
typedef CALL_DEF_GROUP Graphic3d_CGroup; #include <Graphic3d_CTexture.hxx>
#if defined(__cplusplus) || defined(c_plusplus) class Graphic3d_CStructure;
/*==== Definition de Type ====================================================*/
#include <Standard_Type.hxx>
const Handle(Standard_Type)& TYPE(Graphic3d_CGroup);
/*============================================================================*/
#endif class CALL_DEF_CONTEXTFILLAREA
#endif /*Graphic3d_CGroup_HeaderFile*/ {
public:
CALL_DEF_CONTEXTFILLAREA()
: IsDef (0),
IsSet (0),
Style (0),
LineType (0),
Width (0.0f),
Hatch (0),
Distinguish (0),
BackFace (0),
Edge (0),
DegenerationMode (0),
SkipRatio (0.0f),
PolygonOffsetMode (0),
PolygonOffsetFactor (0.0f),
PolygonOffsetUnits (0.0f)
{
//
}
public:
int IsDef;
int IsSet;
int Style;
CALL_DEF_COLOR IntColor;
CALL_DEF_COLOR BackIntColor;
CALL_DEF_COLOR EdgeColor;
int LineType;
float Width;
int Hatch;
int Distinguish;
int BackFace;
int Edge;
CALL_DEF_MATERIAL Front;
CALL_DEF_MATERIAL Back;
Graphic3d_CTexture Texture;
int DegenerationMode;
float SkipRatio;
int PolygonOffsetMode;
float PolygonOffsetFactor;
float PolygonOffsetUnits;
};
class Graphic3d_CGroup
{
public:
int LabelBegin;
int LabelEnd;
void* ptrGroup;
int StructureEnd;
CALL_DEF_CONTEXTLINE ContextLine;
CALL_DEF_CONTEXTFILLAREA ContextFillArea;
CALL_DEF_CONTEXTMARKER ContextMarker;
CALL_DEF_CONTEXTTEXT ContextText;
Graphic3d_CStructure* Struct;
CALL_DEF_PICKID PickId;
unsigned IsDeleted : 1;
unsigned IsOpen : 1;
};
const Handle(Standard_Type)& TYPE(Graphic3d_CGroup);
#endif // Graphic3d_CGroup_HeaderFile

View File

@ -1,40 +0,0 @@
// Copyright (c) 1999-2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
/*============================================================================*/
/*==== Titre: Graphic3d_CInitTexture.hxx */
/*==== Role : The header file of primitive type "CInitTexture" from Graphic3d */
/*==== */
/*==== Implementation: This is a primitive type implemented with typedef */
/*==== Created: 1/07/97 ; PCT : texture mapping */
/*============================================================================*/
#ifndef _Graphic3d_CInitTexture_HeaderFile
#define _Graphic3d_CInitTexture_HeaderFile
#include <InterfaceGraphic_Graphic3d.hxx>
#include <InterfaceGraphic_Visual3d.hxx>
typedef CALL_DEF_INIT_TEXTURE Graphic3d_CInitTexture;
#if defined(__cplusplus) || defined(c_plusplus)
/*==== Definition de Type ====================================================*/
#include <Standard_Type.hxx>
const Handle(Standard_Type)& TYPE(Graphic3d_CInitTexture);
/*============================================================================*/
#endif
#endif /*Graphic3d_CInitTexture_HeaderFile*/

View File

@ -16,25 +16,51 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
/*============================================================================*/
/*==== Titre: Graphic3d_CStructure.hxx */
/*==== Role : The header file of primitive type "CStructure" from Graphic3d */
/*==== */
/*==== Implementation: This is a primitive type implemented with typedef */
/*============================================================================*/
#ifndef _Graphic3d_CStructure_HeaderFile #ifndef _Graphic3d_CStructure_HeaderFile
#define _Graphic3d_CStructure_HeaderFile #define _Graphic3d_CStructure_HeaderFile
#include <InterfaceGraphic_Graphic3d.hxx> #include <Graphic3d_CGroup.hxx>
typedef CALL_DEF_STRUCTURE Graphic3d_CStructure;
#if defined(__cplusplus) || defined(c_plusplus) class Graphic3d_CStructure
/*==== Definition de Type ====================================================*/ {
#include <Standard_Type.hxx> public:
const Handle(Standard_Type)& TYPE(Graphic3d_CStructure) ;
/*============================================================================*/
#endif int Id;
#endif /*Graphic3d_CStructure_HeaderFile*/ void* ptrStructure;
int Priority;
int PreviousPriority;
int GroupBegin;
int GroupEnd;
CALL_DEF_CONTEXTLINE ContextLine;
CALL_DEF_CONTEXTFILLAREA ContextFillArea;
CALL_DEF_CONTEXTMARKER ContextMarker;
CALL_DEF_CONTEXTTEXT ContextText;
CALL_DEF_BOUNDBOX BoundBox;
float Transformation[4][4];
int Composition;
int ContainsFacet;
unsigned IsDeleted : 1;
unsigned IsOpen : 1;
unsigned IsInfinite : 1;
unsigned stick : 1;
unsigned highlight : 1;
unsigned visible : 1;
unsigned pick : 1;
unsigned HLRValidation : 1;
CALL_DEF_TRANSFORM_PERSISTENCE TransformPersistence;
};
///typedef Graphic3d_CStructure CALL_DEF_STRUCTURE;
const Handle(Standard_Type)& TYPE(Graphic3d_CStructure);
#endif // Graphic3d_CStructure_HeaderFile

View File

@ -15,26 +15,30 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
/*============================================================================*/
/*==== Titre: Graphic3d_CTexture.hxx */
/*==== Role : The header file of primitive type "CTexture" from Graphic3d */
/*==== */
/*==== Implementation: This is a primitive type implemented with typedef */
/*==== created: 1/07/97 ; PCT : texture mapping */
/*============================================================================*/
#ifndef _Graphic3d_CTexture_HeaderFile #ifndef _Graphic3d_CTexture_HeaderFile
#define _Graphic3d_CTexture_HeaderFile #define _Graphic3d_CTexture_HeaderFile
#include <InterfaceGraphic_Graphic3d.hxx> #include <Handle_Graphic3d_TextureMap.hxx>
#include <InterfaceGraphic_Visual3d.hxx>
typedef CALL_DEF_TEXTURE Graphic3d_CTexture;
#if defined(__cplusplus) || defined(c_plusplus)
/*==== Definition de Type ====================================================*/
#include <Standard_Type.hxx> #include <Standard_Type.hxx>
const Handle(Standard_Type)& TYPE(Graphic3d_CTexture);
/*============================================================================*/
#endif class Graphic3d_CTexture
#endif /*Graphic3d_CTexture_HeaderFile*/ {
public:
Graphic3d_CTexture()
: doTextureMap (0)
{
//
}
public:
Handle(Graphic3d_TextureMap) TextureMap; //!< handle to texture
int doTextureMap; //!< flag indicates to use texture or not
};
const Handle(Standard_Type)& TYPE(Graphic3d_CTexture);
#endif // Graphic3d_CTexture_HeaderFile

View File

@ -15,25 +15,130 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
/*============================================================================*/
/*==== Titre: Graphic3d_CView.hxx */
/*==== Role : The header file of primitive type "CView" from Graphic3d */
/*==== */
/*==== Implementation: This is a primitive type implemented with typedef */
/*============================================================================*/
#ifndef _Graphic3d_CView_HeaderFile #ifndef _Graphic3d_CView_HeaderFile
#define _Graphic3d_CView_HeaderFile #define _Graphic3d_CView_HeaderFile
#include <InterfaceGraphic_Graphic3d.hxx> #include <InterfaceGraphic_Graphic3d.hxx>
#include <InterfaceGraphic_Visual3d.hxx> #include <InterfaceGraphic_Visual3d.hxx>
typedef CALL_DEF_VIEW Graphic3d_CView; #include <Handle_Graphic3d_TextureEnv.hxx>
#if defined(__cplusplus) || defined(c_plusplus)
/*==== Definition de Type ====================================================*/
#include <Standard_Type.hxx> #include <Standard_Type.hxx>
const Handle(Standard_Type)& TYPE(Graphic3d_CView);
/*============================================================================*/
#endif class CALL_DEF_VIEWCONTEXT
#endif /*Graphic3d_CView_HeaderFile*/ {
public:
CALL_DEF_VIEWCONTEXT()
: Aliasing (0),
BackZClipping (0),
FrontZClipping (0),
DepthCueing (0),
ZClipFrontPlane (0.0f),
ZClipBackPlane (0.0f),
DepthFrontPlane (0.0f),
DepthBackPlane (0.0f),
ZBufferActivity (0),
Model (0),
Visualization (0),
NbActiveLight (0),
ActiveLight (NULL),
NbActivePlane (0),
ActivePlane (NULL),
SurfaceDetail (0)
{
//
}
public:
int Aliasing;
int BackZClipping;
int FrontZClipping;
int DepthCueing;
float ZClipFrontPlane;
float ZClipBackPlane;
float DepthFrontPlane;
float DepthBackPlane;
int ZBufferActivity;
int Model;
int Visualization;
int NbActiveLight;
CALL_DEF_LIGHT* ActiveLight;
int NbActivePlane;
CALL_DEF_PLANE* ActivePlane;
Handle(Graphic3d_TextureEnv) TextureEnv;
int SurfaceDetail;
};
class Graphic3d_CView
{
public:
Graphic3d_CView()
: WsId (-1),
ViewId (0),
ptrView (NULL),
IsDeleted (0),
IsOpen (0),
Active (0),
ptrUnderLayer (NULL),
ptrOverLayer (NULL),
IsDegenerates (0),
IsDegeneratesPrev (0),
Backfacing (0),
GDisplayCB (NULL),
GClientData (NULL),
ptrFBO (NULL)
{
//
}
public:
int WsId;
int ViewId;
void* ptrView;
int IsDeleted;
int IsOpen;
int Active;
CALL_DEF_VIEWORIENTATION Orientation;
CALL_DEF_VIEWMAPPING Mapping;
CALL_DEF_VIEWORIENTATION OrientationReset;
CALL_DEF_VIEWMAPPING MappingReset;
CALL_DEF_VIEWCONTEXT Context;
CALL_DEF_WINDOW DefWindow;
void* ptrUnderLayer;
void* ptrOverLayer;
int IsDegenerates;
int IsDegeneratesPrev;
int Backfacing;
Aspect_RenderingContext GContext;
Aspect_GraphicCallbackProc GDisplayCB;
void* GClientData;
void* ptrFBO;
};
const Handle(Standard_Type)& TYPE(Graphic3d_CView);
#endif // Graphic3d_CView_HeaderFile

View File

@ -18,30 +18,6 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
-- Modified: 01/08/97 ; PCT : ajout texture mapping
-- 07/08/97 ; PCT : ajout texture environnante
-- 27/08/97 ; PCT : ajout coordonnee texture
-- 00/11/97 ; CAL : retrait de la dependance avec math
-- 00/11/97 ; CAL : ajout polyline par 2 points
-- 16-09-98 ; BGN : Points d'entree du Triedre (S3819, Phase 1)
-- 22-09-98 ; BGN : S3989 (anciennement S3819)
-- TypeOfTriedron* from Aspect(et pas Graphic3d)
-- 03-11-98 ; CAL : Introduction de Visual3d_LayerManager.
-- 07-10-99 : EUG : Degeneration support (G003)
-- Add DegenerateStructure() and
-- SetBackFacingModel() methods.
-- 10-11-99 ; GG : PRO19603 Change Redraw( ) method
-- 16-06-2000 : ATS,GG : G005 - method PrimitiveArray, which are interface of OpenGl
-- package, and used to initialize internal fields
-- of primitives (Convert high level data to internal presentation).
-- 17/08/00 ; THA ; Thomas HARTL <t-hartl@muenchen.matra-dtv.fr>
-- -> Add Print methods (works only under Windows).
-- 27/03/02 ; GG ; RIC120302 Add new method Begin(Aspect_Display)
-- 28/05/02 ; VSV : New trihedron
-- 23/12/02 ; SAV : Added methods to set background image and its
-- appearence style
-- 20/01/09 ; ABD : Integration support of system fonts (using FTGL and FreeType)
deferred class GraphicDriver from Graphic3d inherits GraphicDriver from Aspect deferred class GraphicDriver from Graphic3d inherits GraphicDriver from Aspect
---Version: ---Version:
@ -114,8 +90,6 @@ uses
Array2OfVertexNC from Graphic3d, Array2OfVertexNC from Graphic3d,
VertexNC from Graphic3d, VertexNC from Graphic3d,
VerticalTextAlignment from Graphic3d, VerticalTextAlignment from Graphic3d,
CInitTexture from Graphic3d,
TypeOfTexture from Graphic3d,
VertexNT from Graphic3d, VertexNT from Graphic3d,
Array1OfVertexNT from Graphic3d, Array1OfVertexNT from Graphic3d,
Array2OfVertexNT from Graphic3d, Array2OfVertexNT from Graphic3d,
@ -800,30 +774,6 @@ is
is deferred; is deferred;
---Purpose: call_togl_transform ---Purpose: call_togl_transform
-----------------------------
-- Category: Textures methods
-----------------------------
CreateTexture ( me;
theType : TypeOfTexture from Graphic3d;
theImage : PixMap from Image;
theFileName : CString from Standard;
theTexUpperBounds : HArray1OfReal from TColStd )
returns Integer from Standard
is deferred;
---Purpose:
DestroyTexture ( me;
TexId : Integer from Standard )
is deferred;
---Purpose:
ModifyTexture ( me;
TexId : Integer from Standard;
AValue : CInitTexture from Graphic3d )
is deferred;
---Purpose:
------------------------------- -------------------------------
-- Category: Layer mode methods -- Category: Layer mode methods
------------------------------- -------------------------------

View File

@ -21,7 +21,7 @@
// 11/97 ; CAL : retrait DownCast // 11/97 ; CAL : retrait DownCast
//-Version //-Version
//-Design Declaration of variables specific to groups //-Design Declaration of variables specific to groups
// of primitives // of primitives
@ -29,7 +29,7 @@
//-Warning A group is definedv in a structure //-Warning A group is definedv in a structure
// This is the smallest editable entity // This is the smallest editable entity
//-References //-References
//-Language C++ 2.0 //-Language C++ 2.0
@ -87,7 +87,7 @@ Standard_Integer TheLabelBegin, TheLabelEnd;
MyContainsFacet = Standard_False, MyContainsFacet = Standard_False,
MyIsEmpty = Standard_True; MyIsEmpty = Standard_True;
MyCGroup.Struct = (CALL_DEF_STRUCTURE *) (MyStructure->CStructure ()); MyCGroup.Struct = MyStructure->CStructure();
MyCGroup.Struct->Id = int (MyStructure->Identification ()); MyCGroup.Struct->Id = int (MyStructure->Identification ());
MyCGroup.IsDeleted = 0; MyCGroup.IsDeleted = 0;
MyCGroup.IsOpen = 0; MyCGroup.IsOpen = 0;

View File

@ -21,11 +21,11 @@
// modified: 1/07/97 ; PCT : ajout texture mapping // modified: 1/07/97 ; PCT : ajout texture mapping
// 20/07/97 ; PCT : ajout transparence texture // 20/07/97 ; PCT : ajout transparence texture
// 08/04/98 ; FGU : Ajout emission surface // 08/04/98 ; FGU : Ajout emission surface
// 30/11/98 ; FMN : S4069. Textes always visible. // 30/11/98 ; FMN : S4069. Textes always visible.
// 22/03/04 ; SAN : OCC4895 High-level interface for controlling polygon offsets */ // 22/03/04 ; SAN : OCC4895 High-level interface for controlling polygon offsets */
//-Version //-Version
//-Design Declaration des variables specifiques aux groupes //-Design Declaration des variables specifiques aux groupes
// de primitives // de primitives
@ -33,7 +33,7 @@
//-Warning Un groupe est defini dans une structure //-Warning Un groupe est defini dans une structure
// Il s'agit de la plus petite entite editable // Il s'agit de la plus petite entite editable
//-References //-References
//-Language C++ 2.0 //-Language C++ 2.0
@ -136,7 +136,7 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
MyCGroup.ContextFillArea.Back.Emission = MyCGroup.ContextFillArea.Back.Emission =
float ((CTX->BackMaterial ()).Emissive ()); float ((CTX->BackMaterial ()).Emissive ());
// Reflection mode // Reflection mode
MyCGroup.ContextFillArea.Back.IsAmbient = MyCGroup.ContextFillArea.Back.IsAmbient =
( (CTX->BackMaterial ()).ReflectionMode ( (CTX->BackMaterial ()).ReflectionMode
(Graphic3d_TOR_AMBIENT) ? 1 : 0 ); (Graphic3d_TOR_AMBIENT) ? 1 : 0 );
@ -150,13 +150,13 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
( (CTX->BackMaterial ()).ReflectionMode ( (CTX->BackMaterial ()).ReflectionMode
(Graphic3d_TOR_EMISSION) ? 1 : 0 ); (Graphic3d_TOR_EMISSION) ? 1 : 0 );
// Material type // Material type
//JR/Hp //JR/Hp
const Graphic3d_MaterialAspect ama = CTX->BackMaterial () ; const Graphic3d_MaterialAspect ama = CTX->BackMaterial () ;
Standard_Boolean amt = ama.MaterialType(Graphic3d_MATERIAL_PHYSIC) ; Standard_Boolean amt = ama.MaterialType(Graphic3d_MATERIAL_PHYSIC) ;
MyCGroup.ContextFillArea.Back.IsPhysic = ( amt ? 1 : 0 ); MyCGroup.ContextFillArea.Back.IsPhysic = ( amt ? 1 : 0 );
// Specular color // Specular color
MyCGroup.ContextFillArea.Back.ColorSpec.r = MyCGroup.ContextFillArea.Back.ColorSpec.r =
float (((CTX->BackMaterial ()).SpecularColor ()).Red ()); float (((CTX->BackMaterial ()).SpecularColor ()).Red ());
MyCGroup.ContextFillArea.Back.ColorSpec.g = MyCGroup.ContextFillArea.Back.ColorSpec.g =
@ -189,7 +189,7 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
MyCGroup.ContextFillArea.Back.ColorEms.b = MyCGroup.ContextFillArea.Back.ColorEms.b =
float (((CTX->BackMaterial ()).EmissiveColor ()).Blue ()); float (((CTX->BackMaterial ()).EmissiveColor ()).Blue ());
MyCGroup.ContextFillArea.Back.EnvReflexion = MyCGroup.ContextFillArea.Back.EnvReflexion =
float ((CTX->BackMaterial ()).EnvReflexion()); float ((CTX->BackMaterial ()).EnvReflexion());
/*** Front Material ***/ /*** Front Material ***/
@ -205,9 +205,9 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
MyCGroup.ContextFillArea.Front.Transparency = MyCGroup.ContextFillArea.Front.Transparency =
float ((CTX->FrontMaterial ()).Transparency ()); float ((CTX->FrontMaterial ()).Transparency ());
MyCGroup.ContextFillArea.Front.Emission = MyCGroup.ContextFillArea.Front.Emission =
float ((CTX->FrontMaterial ()).Emissive ()); float ((CTX->FrontMaterial ()).Emissive ());
// Reflection mode // Reflection mode
MyCGroup.ContextFillArea.Front.IsAmbient = MyCGroup.ContextFillArea.Front.IsAmbient =
( (CTX->FrontMaterial ()).ReflectionMode ( (CTX->FrontMaterial ()).ReflectionMode
(Graphic3d_TOR_AMBIENT) ? 1 : 0 ); (Graphic3d_TOR_AMBIENT) ? 1 : 0 );
@ -227,7 +227,7 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
Standard_Boolean amty = amas.MaterialType(Graphic3d_MATERIAL_PHYSIC) ; Standard_Boolean amty = amas.MaterialType(Graphic3d_MATERIAL_PHYSIC) ;
MyCGroup.ContextFillArea.Front.IsPhysic = ( amty ? 1 : 0 ); MyCGroup.ContextFillArea.Front.IsPhysic = ( amty ? 1 : 0 );
// Specular color // Specular color
MyCGroup.ContextFillArea.Front.ColorSpec.r = MyCGroup.ContextFillArea.Front.ColorSpec.r =
float (((CTX->FrontMaterial ()).SpecularColor ()).Red ()); float (((CTX->FrontMaterial ()).SpecularColor ()).Red ());
MyCGroup.ContextFillArea.Front.ColorSpec.g = MyCGroup.ContextFillArea.Front.ColorSpec.g =
@ -235,7 +235,7 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
MyCGroup.ContextFillArea.Front.ColorSpec.b = MyCGroup.ContextFillArea.Front.ColorSpec.b =
float (((CTX->FrontMaterial ()).SpecularColor ()).Blue ()); float (((CTX->FrontMaterial ()).SpecularColor ()).Blue ());
// Ambient color // Ambient color
MyCGroup.ContextFillArea.Front.ColorAmb.r = MyCGroup.ContextFillArea.Front.ColorAmb.r =
float (((CTX->FrontMaterial ()).AmbientColor ()).Red ()); float (((CTX->FrontMaterial ()).AmbientColor ()).Red ());
MyCGroup.ContextFillArea.Front.ColorAmb.g = MyCGroup.ContextFillArea.Front.ColorAmb.g =
@ -243,7 +243,7 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
MyCGroup.ContextFillArea.Front.ColorAmb.b = MyCGroup.ContextFillArea.Front.ColorAmb.b =
float (((CTX->FrontMaterial ()).AmbientColor ()).Blue ()); float (((CTX->FrontMaterial ()).AmbientColor ()).Blue ());
// Diffuse color // Diffuse color
MyCGroup.ContextFillArea.Front.ColorDif.r = MyCGroup.ContextFillArea.Front.ColorDif.r =
float (((CTX->FrontMaterial ()).DiffuseColor ()).Red ()); float (((CTX->FrontMaterial ()).DiffuseColor ()).Red ());
MyCGroup.ContextFillArea.Front.ColorDif.g = MyCGroup.ContextFillArea.Front.ColorDif.g =
@ -259,31 +259,23 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectFil
MyCGroup.ContextFillArea.Front.ColorEms.b = MyCGroup.ContextFillArea.Front.ColorEms.b =
float (((CTX->FrontMaterial ()).EmissiveColor ()).Blue ()); float (((CTX->FrontMaterial ()).EmissiveColor ()).Blue ());
MyCGroup.ContextFillArea.Front.EnvReflexion = MyCGroup.ContextFillArea.Front.EnvReflexion =
float ((CTX->FrontMaterial ()).EnvReflexion()); float ((CTX->FrontMaterial ()).EnvReflexion());
MyCGroup.ContextFillArea.IsDef = 1; // Definition material ok MyCGroup.ContextFillArea.IsDef = 1; // Definition material ok
/*** Texture map ***/ /*** Texture map ***/
Handle(Graphic3d_TextureMap) GroupTextureMap = CTX->TextureMap(); MyCGroup.ContextFillArea.Texture.TextureMap = CTX->TextureMap();
if (! GroupTextureMap.IsNull() ) { MyCGroup.ContextFillArea.Texture.doTextureMap = CTX->TextureMapState() ? 1 : 0;
MyCGroup.ContextFillArea.Texture.TexId = GroupTextureMap->TextureId();
MyCGroup.ContextFillArea.Texture.doTextureMap =
CTX->TextureMapState () ? 1 : 0;
}
else {
MyCGroup.ContextFillArea.Texture.TexId = -1;
MyCGroup.ContextFillArea.Texture.doTextureMap = 0;
}
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
Standard_Integer aPolyMode; Standard_Integer aPolyMode;
Standard_ShortReal aPolyFactor, aPolyUnits; Standard_ShortReal aPolyFactor, aPolyUnits;
CTX->PolygonOffsets(aPolyMode, aPolyFactor, aPolyUnits); CTX->PolygonOffsets(aPolyMode, aPolyFactor, aPolyUnits);
MyCGroup.ContextFillArea.PolygonOffsetMode = aPolyMode; MyCGroup.ContextFillArea.PolygonOffsetMode = aPolyMode;
MyCGroup.ContextFillArea.PolygonOffsetFactor = aPolyFactor; MyCGroup.ContextFillArea.PolygonOffsetFactor = aPolyFactor;
MyCGroup.ContextFillArea.PolygonOffsetUnits = aPolyUnits; MyCGroup.ContextFillArea.PolygonOffsetUnits = aPolyUnits;
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
int noinsert = 1; int noinsert = 1;
MyGraphicDriver->FaceContextGroup (MyCGroup, noinsert); MyGraphicDriver->FaceContextGroup (MyCGroup, noinsert);
@ -361,8 +353,8 @@ void Graphic3d_Group::SetGroupPrimitivesAspect (const Handle(Graphic3d_AspectTex
MyCGroup.ContextText.ColorSubTitle.r = float (Rs); MyCGroup.ContextText.ColorSubTitle.r = float (Rs);
MyCGroup.ContextText.ColorSubTitle.g = float (Gs); MyCGroup.ContextText.ColorSubTitle.g = float (Gs);
MyCGroup.ContextText.ColorSubTitle.b = float (Bs); MyCGroup.ContextText.ColorSubTitle.b = float (Bs);
MyCGroup.ContextText.TextZoomable = ATextZoomable; MyCGroup.ContextText.TextZoomable = ATextZoomable;
MyCGroup.ContextText.TextAngle = float (ATextAngle); MyCGroup.ContextText.TextAngle = float (ATextAngle);
MyCGroup.ContextText.TextFontAspect = (int)ATextFontAspect; MyCGroup.ContextText.TextFontAspect = (int)ATextFontAspect;
MyCGroup.ContextText.IsDef = 1; MyCGroup.ContextText.IsDef = 1;
@ -423,7 +415,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.IntColor.r = float (R); MyCGroup.ContextFillArea.IntColor.r = float (R);
MyCGroup.ContextFillArea.IntColor.g = float (G); MyCGroup.ContextFillArea.IntColor.g = float (G);
MyCGroup.ContextFillArea.IntColor.b = float (B); MyCGroup.ContextFillArea.IntColor.b = float (B);
#ifdef OCC1174 #ifdef OCC1174
if ( CTX->Distinguish() ) if ( CTX->Distinguish() )
BackIntColor.Values( R, G, B, Quantity_TOC_RGB ); BackIntColor.Values( R, G, B, Quantity_TOC_RGB );
#endif #endif
@ -458,9 +450,9 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Back.Transparency = MyCGroup.ContextFillArea.Back.Transparency =
float ((CTX->BackMaterial ()).Transparency ()); float ((CTX->BackMaterial ()).Transparency ());
MyCGroup.ContextFillArea.Back.Emission = MyCGroup.ContextFillArea.Back.Emission =
float ((CTX->BackMaterial ()).Emissive ()); float ((CTX->BackMaterial ()).Emissive ());
// Reflection mode // Reflection mode
MyCGroup.ContextFillArea.Back.IsAmbient = MyCGroup.ContextFillArea.Back.IsAmbient =
( (CTX->BackMaterial ()).ReflectionMode ( (CTX->BackMaterial ()).ReflectionMode
(Graphic3d_TOR_AMBIENT) ? 1 : 0 ); (Graphic3d_TOR_AMBIENT) ? 1 : 0 );
@ -480,7 +472,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
Standard_Boolean amt = ama.MaterialType(Graphic3d_MATERIAL_PHYSIC) ; Standard_Boolean amt = ama.MaterialType(Graphic3d_MATERIAL_PHYSIC) ;
MyCGroup.ContextFillArea.Back.IsPhysic = ( amt ? 1 : 0 ); MyCGroup.ContextFillArea.Back.IsPhysic = ( amt ? 1 : 0 );
// Specular color // Specular color
MyCGroup.ContextFillArea.Back.ColorSpec.r = MyCGroup.ContextFillArea.Back.ColorSpec.r =
float (((CTX->BackMaterial ()).SpecularColor ()).Red ()); float (((CTX->BackMaterial ()).SpecularColor ()).Red ());
MyCGroup.ContextFillArea.Back.ColorSpec.g = MyCGroup.ContextFillArea.Back.ColorSpec.g =
@ -488,7 +480,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Back.ColorSpec.b = MyCGroup.ContextFillArea.Back.ColorSpec.b =
float (((CTX->BackMaterial ()).SpecularColor ()).Blue ()); float (((CTX->BackMaterial ()).SpecularColor ()).Blue ());
// Ambient color // Ambient color
MyCGroup.ContextFillArea.Back.ColorAmb.r = MyCGroup.ContextFillArea.Back.ColorAmb.r =
float (((CTX->BackMaterial ()).AmbientColor ()).Red ()); float (((CTX->BackMaterial ()).AmbientColor ()).Red ());
MyCGroup.ContextFillArea.Back.ColorAmb.g = MyCGroup.ContextFillArea.Back.ColorAmb.g =
@ -496,7 +488,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Back.ColorAmb.b = MyCGroup.ContextFillArea.Back.ColorAmb.b =
float (((CTX->BackMaterial ()).AmbientColor ()).Blue ()); float (((CTX->BackMaterial ()).AmbientColor ()).Blue ());
// Diffuse color // Diffuse color
MyCGroup.ContextFillArea.Back.ColorDif.r = MyCGroup.ContextFillArea.Back.ColorDif.r =
float (((CTX->BackMaterial ()).DiffuseColor ()).Red ()); float (((CTX->BackMaterial ()).DiffuseColor ()).Red ());
MyCGroup.ContextFillArea.Back.ColorDif.g = MyCGroup.ContextFillArea.Back.ColorDif.g =
@ -512,7 +504,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Back.ColorEms.b = MyCGroup.ContextFillArea.Back.ColorEms.b =
float (((CTX->BackMaterial ()).EmissiveColor ()).Blue ()); float (((CTX->BackMaterial ()).EmissiveColor ()).Blue ());
MyCGroup.ContextFillArea.Back.EnvReflexion = MyCGroup.ContextFillArea.Back.EnvReflexion =
float ((CTX->BackMaterial ()).EnvReflexion()); float ((CTX->BackMaterial ()).EnvReflexion());
/*** Front Material ***/ /*** Front Material ***/
@ -528,9 +520,9 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Front.Transparency = MyCGroup.ContextFillArea.Front.Transparency =
float ((CTX->FrontMaterial ()).Transparency ()); float ((CTX->FrontMaterial ()).Transparency ());
MyCGroup.ContextFillArea.Front.Emission = MyCGroup.ContextFillArea.Front.Emission =
float ((CTX->FrontMaterial ()).Emissive ()); float ((CTX->FrontMaterial ()).Emissive ());
// Reflection mode // Reflection mode
MyCGroup.ContextFillArea.Front.IsAmbient = MyCGroup.ContextFillArea.Front.IsAmbient =
( (CTX->FrontMaterial ()).ReflectionMode ( (CTX->FrontMaterial ()).ReflectionMode
(Graphic3d_TOR_AMBIENT) ? 1 : 0 ); (Graphic3d_TOR_AMBIENT) ? 1 : 0 );
@ -550,7 +542,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
Standard_Boolean amty = amas.MaterialType(Graphic3d_MATERIAL_PHYSIC) ; Standard_Boolean amty = amas.MaterialType(Graphic3d_MATERIAL_PHYSIC) ;
MyCGroup.ContextFillArea.Front.IsPhysic = ( amty ? 1 : 0 ); MyCGroup.ContextFillArea.Front.IsPhysic = ( amty ? 1 : 0 );
// Specular color // Specular color
MyCGroup.ContextFillArea.Front.ColorSpec.r = MyCGroup.ContextFillArea.Front.ColorSpec.r =
float (((CTX->FrontMaterial ()).SpecularColor ()).Red ()); float (((CTX->FrontMaterial ()).SpecularColor ()).Red ());
MyCGroup.ContextFillArea.Front.ColorSpec.g = MyCGroup.ContextFillArea.Front.ColorSpec.g =
@ -558,7 +550,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Front.ColorSpec.b = MyCGroup.ContextFillArea.Front.ColorSpec.b =
float (((CTX->FrontMaterial ()).SpecularColor ()).Blue ()); float (((CTX->FrontMaterial ()).SpecularColor ()).Blue ());
// Ambient color // Ambient color
MyCGroup.ContextFillArea.Front.ColorAmb.r = MyCGroup.ContextFillArea.Front.ColorAmb.r =
float (((CTX->FrontMaterial ()).AmbientColor ()).Red ()); float (((CTX->FrontMaterial ()).AmbientColor ()).Red ());
MyCGroup.ContextFillArea.Front.ColorAmb.g = MyCGroup.ContextFillArea.Front.ColorAmb.g =
@ -566,7 +558,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Front.ColorAmb.b = MyCGroup.ContextFillArea.Front.ColorAmb.b =
float (((CTX->FrontMaterial ()).AmbientColor ()).Blue ()); float (((CTX->FrontMaterial ()).AmbientColor ()).Blue ());
// Diffuse color // Diffuse color
MyCGroup.ContextFillArea.Front.ColorDif.r = MyCGroup.ContextFillArea.Front.ColorDif.r =
float (((CTX->FrontMaterial ()).DiffuseColor ()).Red ()); float (((CTX->FrontMaterial ()).DiffuseColor ()).Red ());
MyCGroup.ContextFillArea.Front.ColorDif.g = MyCGroup.ContextFillArea.Front.ColorDif.g =
@ -582,21 +574,15 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectFillArea
MyCGroup.ContextFillArea.Front.ColorEms.b = MyCGroup.ContextFillArea.Front.ColorEms.b =
float (((CTX->FrontMaterial ()).EmissiveColor ()).Blue ()); float (((CTX->FrontMaterial ()).EmissiveColor ()).Blue ());
MyCGroup.ContextFillArea.Front.EnvReflexion = MyCGroup.ContextFillArea.Front.EnvReflexion =
float ((CTX->FrontMaterial ()).EnvReflexion()); float ((CTX->FrontMaterial ()).EnvReflexion());
MyCGroup.ContextFillArea.IsDef = 1; // Material definition ok MyCGroup.ContextFillArea.IsDef = 1; // Material definition ok
Handle(Graphic3d_TextureMap) GroupTextureMap = CTX->TextureMap(); MyCGroup.ContextFillArea.Texture.TextureMap = CTX->TextureMap();
if (! GroupTextureMap.IsNull() ) MyCGroup.ContextFillArea.Texture.doTextureMap = CTX->TextureMapState() ? 1 : 0;
MyCGroup.ContextFillArea.Texture.TexId = GroupTextureMap->TextureId();
else
MyCGroup.ContextFillArea.Texture.TexId = -1;
MyCGroup.ContextFillArea.Texture.doTextureMap = // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
CTX->TextureMapState () ? 1 : 0;
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
Standard_Integer aPolyMode; Standard_Integer aPolyMode;
Standard_ShortReal aPolyFactor, aPolyUnits; Standard_ShortReal aPolyFactor, aPolyUnits;
CTX->PolygonOffsets(aPolyMode, aPolyFactor, aPolyUnits); CTX->PolygonOffsets(aPolyMode, aPolyFactor, aPolyUnits);
@ -661,7 +647,7 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectText3d)&
Quantity_Color AColor; Quantity_Color AColor;
Aspect_TypeOfStyleText AStyle; Aspect_TypeOfStyleText AStyle;
Aspect_TypeOfDisplayText ADisplayType; Aspect_TypeOfDisplayText ADisplayType;
Quantity_Color AColorSubTitle; Quantity_Color AColorSubTitle;
Standard_Boolean ATextZoomable; Standard_Boolean ATextZoomable;
Standard_Real ATextAngle; Standard_Real ATextAngle;
Font_FontAspect ATextFontAspect; Font_FontAspect ATextFontAspect;
@ -681,9 +667,9 @@ void Graphic3d_Group::SetPrimitivesAspect (const Handle(Graphic3d_AspectText3d)&
MyCGroup.ContextText.ColorSubTitle.r = float (Rs); MyCGroup.ContextText.ColorSubTitle.r = float (Rs);
MyCGroup.ContextText.ColorSubTitle.g = float (Gs); MyCGroup.ContextText.ColorSubTitle.g = float (Gs);
MyCGroup.ContextText.ColorSubTitle.b = float (Bs); MyCGroup.ContextText.ColorSubTitle.b = float (Bs);
MyCGroup.ContextText.TextZoomable = ATextZoomable; MyCGroup.ContextText.TextZoomable = ATextZoomable;
MyCGroup.ContextText.TextAngle = float (ATextAngle); MyCGroup.ContextText.TextAngle = float (ATextAngle);
MyCGroup.ContextText.TextFontAspect = (int)ATextFontAspect; MyCGroup.ContextText.TextFontAspect = (int)ATextFontAspect;
MyCGroup.ContextText.IsDef = 1; MyCGroup.ContextText.IsDef = 1;
int noinsert = 0; int noinsert = 0;
@ -703,7 +689,7 @@ Standard_Boolean Graphic3d_Group::IsGroupPrimitivesAspectSet (const Graphic3d_Gr
case Graphic3d_ASPECT_FILL_AREA: return MyCGroup.ContextFillArea.IsSet; case Graphic3d_ASPECT_FILL_AREA: return MyCGroup.ContextFillArea.IsSet;
default: return Standard_False; default: return Standard_False;
} }
} }
void Graphic3d_Group::GroupPrimitivesAspect (const Handle(Graphic3d_AspectLine3d)& CTXL, const Handle(Graphic3d_AspectText3d)& CTXT, const Handle(Graphic3d_AspectMarker3d)& CTXM, const Handle(Graphic3d_AspectFillArea3d)& CTXF) const { void Graphic3d_Group::GroupPrimitivesAspect (const Handle(Graphic3d_AspectLine3d)& CTXL, const Handle(Graphic3d_AspectText3d)& CTXT, const Handle(Graphic3d_AspectMarker3d)& CTXM, const Handle(Graphic3d_AspectFillArea3d)& CTXF) const {
@ -947,19 +933,21 @@ void Graphic3d_Group::GroupPrimitivesAspect (const Handle(Graphic3d_AspectLine3d
else else
CTXF->AllowBackFace (); CTXF->AllowBackFace ();
// Texture // Texture
// Pb sur les textures CTXF->SetTextureMap (MyCGroup.ContextFillArea.Texture.TextureMap);
//if (MyCGroup.ContextFillArea.Texture.TexId == -1)
//else
if (MyCGroup.ContextFillArea.Texture.doTextureMap == 1) if (MyCGroup.ContextFillArea.Texture.doTextureMap == 1)
CTXF->SetTextureMapOn (); {
CTXF->SetTextureMapOn();
}
else else
CTXF->SetTextureMapOff (); {
CTXF->SetTextureMapOff();
}
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
CTXF->SetPolygonOffsets(MyCGroup.ContextFillArea.PolygonOffsetMode, CTXF->SetPolygonOffsets(MyCGroup.ContextFillArea.PolygonOffsetMode,
MyCGroup.ContextFillArea.PolygonOffsetFactor, MyCGroup.ContextFillArea.PolygonOffsetFactor,
MyCGroup.ContextFillArea.PolygonOffsetUnits); MyCGroup.ContextFillArea.PolygonOffsetUnits);
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
} }
else { else {
// Interior // Interior
@ -1097,16 +1085,21 @@ void Graphic3d_Group::GroupPrimitivesAspect (const Handle(Graphic3d_AspectLine3d
else else
CTXF->AllowBackFace (); CTXF->AllowBackFace ();
// Texture // Texture
CTXF->SetTextureMap (MyCGroup.Struct->ContextFillArea.Texture.TextureMap);
if (MyCGroup.Struct->ContextFillArea.Texture.doTextureMap == 1) if (MyCGroup.Struct->ContextFillArea.Texture.doTextureMap == 1)
CTXF->SetTextureMapOn (); {
CTXF->SetTextureMapOn();
}
else else
CTXF->SetTextureMapOff (); {
CTXF->SetTextureMapOff();
}
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
CTXF->SetPolygonOffsets(MyCGroup.Struct->ContextFillArea.PolygonOffsetMode, CTXF->SetPolygonOffsets(MyCGroup.Struct->ContextFillArea.PolygonOffsetMode,
MyCGroup.Struct->ContextFillArea.PolygonOffsetFactor, MyCGroup.Struct->ContextFillArea.PolygonOffsetFactor,
MyCGroup.Struct->ContextFillArea.PolygonOffsetUnits); MyCGroup.Struct->ContextFillArea.PolygonOffsetUnits);
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
} }
CTXF->SetInteriorStyle (AStyle); CTXF->SetInteriorStyle (AStyle);
CTXF->SetInteriorColor (AnIntColor); CTXF->SetInteriorColor (AnIntColor);

View File

@ -971,16 +971,13 @@ is
---Purpose: Updates the c structure associated to <me>. ---Purpose: Updates the c structure associated to <me>.
---Category: Private methods ---Category: Private methods
CStructure ( me ) CStructure ( me : mutable )
returns Address from Standard returns CStructure from Graphic3d
is static; is static;
---Level: Internal ---Level: Internal
---Purpose: Returns the c structure associated to <me>. ---Purpose: Returns the c structure associated to <me>.
---Category: Private methods ---Category: Private methods
---C++: return *
--
--
fields fields

View File

@ -742,18 +742,14 @@ void Graphic3d_Structure::GraphicClear (const Standard_Boolean WithDestruction)
} }
} }
void Graphic3d_Structure::GraphicConnect (const Handle(Graphic3d_Structure)& ADaughter) { void Graphic3d_Structure::GraphicConnect (const Handle(Graphic3d_Structure)& theDaughter)
{
MyGraphicDriver->Connect MyGraphicDriver->Connect (MyCStructure, theDaughter->MyCStructure);
(MyCStructure, *((CALL_DEF_STRUCTURE *)ADaughter->CStructure()));
} }
void Graphic3d_Structure::GraphicDisconnect (const Handle(Graphic3d_Structure)& ADaughter) { void Graphic3d_Structure::GraphicDisconnect (const Handle(Graphic3d_Structure)& theDaughter)
{
MyGraphicDriver->Disconnect MyGraphicDriver->Disconnect (MyCStructure, theDaughter->MyCStructure);
(MyCStructure, *((CALL_DEF_STRUCTURE *)ADaughter->CStructure()));
} }
Handle(Graphic3d_AspectLine3d) Graphic3d_Structure::Line3dAspect () const { Handle(Graphic3d_AspectLine3d) Graphic3d_Structure::Line3dAspect () const {
@ -996,13 +992,15 @@ Graphic3d_MATERIAL_PHYSIC : Graphic3d_MATERIAL_ASPECT;
else else
CTXF->AllowBackFace (); CTXF->AllowBackFace ();
// Texture // Texture
// Pb sur les textures CTXF->SetTextureMap (MyCStructure.ContextFillArea.Texture.TextureMap);
//if (MyCStructure.ContextFillArea.Texture.TexId == -1)
//else
if (MyCStructure.ContextFillArea.Texture.doTextureMap == 1) if (MyCStructure.ContextFillArea.Texture.doTextureMap == 1)
CTXF->SetTextureMapOn (); {
CTXF->SetTextureMapOn();
}
else else
CTXF->SetTextureMapOff (); {
CTXF->SetTextureMapOff();
}
#ifdef G003 #ifdef G003
Aspect_TypeOfDegenerateModel dMode = Aspect_TypeOfDegenerateModel( Aspect_TypeOfDegenerateModel dMode = Aspect_TypeOfDegenerateModel(
MyCStructure.ContextFillArea.DegenerationMode); MyCStructure.ContextFillArea.DegenerationMode);
@ -1245,13 +1243,8 @@ void Graphic3d_Structure::SetPrimitivesAspect (const Handle(Graphic3d_AspectFill
MyCStructure.ContextFillArea.IsDef = 1; // Definition material ok MyCStructure.ContextFillArea.IsDef = 1; // Definition material ok
Handle(Graphic3d_TextureMap) TempTextureMap = CTX->TextureMap(); MyCStructure.ContextFillArea.Texture.TextureMap = CTX->TextureMap();
if (! TempTextureMap.IsNull() ) MyCStructure.ContextFillArea.Texture.doTextureMap = CTX->TextureMapState() ? 1 : 0;
MyCStructure.ContextFillArea.Texture.TexId = TempTextureMap->TextureId();
else
MyCStructure.ContextFillArea.Texture.TexId = -1;
MyCStructure.ContextFillArea.Texture.doTextureMap = CTX->TextureMapState() ? 1:0;
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
Standard_Integer aPolyMode; Standard_Integer aPolyMode;
@ -2322,13 +2315,8 @@ void Graphic3d_Structure::UpdateStructure (const Handle(Graphic3d_AspectLine3d)&
MyCStructure.ContextFillArea.Front.EnvReflexion = MyCStructure.ContextFillArea.Front.EnvReflexion =
float ((CTXF->FrontMaterial ()).EnvReflexion()); float ((CTXF->FrontMaterial ()).EnvReflexion());
Handle(Graphic3d_TextureMap) TempTextureMap = CTXF->TextureMap(); MyCStructure.ContextFillArea.Texture.TextureMap = CTXF->TextureMap();
if (! TempTextureMap.IsNull() ) MyCStructure.ContextFillArea.Texture.doTextureMap = CTXF->TextureMapState() ? 1 : 0;
MyCStructure.ContextFillArea.Texture.TexId = TempTextureMap->TextureId();
else
MyCStructure.ContextFillArea.Texture.TexId = -1;
MyCStructure.ContextFillArea.Texture.doTextureMap = CTXF->TextureMapState() ? 1:0;
// OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets // OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets
Standard_Integer aPolyMode; Standard_Integer aPolyMode;
@ -2517,10 +2505,14 @@ Standard_Boolean Graphic3d_Structure::HLRValidation () const {
} }
Standard_Address Graphic3d_Structure::CStructure () const { //=======================================================================
//function : CStructure
return Standard_Address (&MyCStructure); //purpose :
//=======================================================================
Graphic3d_CStructure* Graphic3d_Structure::CStructure()
{
return &MyCStructure;
} }
//======================================================================= //=======================================================================

View File

@ -18,57 +18,51 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
-- Modified : GG 10/01/2000 IMP deferred class Texture1D from Graphic3d
-- Add NumberOfTextures() and TextureName() methods
-- Add Name(),IsSmoothed() and ISModulate() methods
-- GG IMP140300
-- Add Repeat methods.
deferred class Texture1D from Graphic3d inherits TextureMap from Graphic3d
inherits TextureMap from Graphic3d
---Purpose: This is an abstract class for managing 1D textures.
---Purpose: This is an abstract class for managing 1D textures.
uses uses
TypeOfTexture from Graphic3d,
NameOfTexture1D from Graphic3d, TypeOfTexture from Graphic3d,
StructureManager from Graphic3d NameOfTexture1D from Graphic3d,
AsciiString from TCollection
raises raises
OutOfRange from Standard
is OutOfRange from Standard
Initialize(SM : StructureManager from Graphic3d;
aFileName: CString from Standard;
aType : TypeOfTexture from Graphic3d);
Initialize(SM : StructureManager from Graphic3d;
aName : NameOfTexture1D from Graphic3d;
aType : TypeOfTexture from Graphic3d);
Name(me) returns NameOfTexture1D from Graphic3d; is
---Purpose:
-- Returns the name of the predefined textures or NOT_1D_UNKNOWN
-- when the name is given as a filename.
---Level: Public
NumberOfTextures(myclass) returns Integer from Standard; Initialize (theFileName : AsciiString from TCollection;
---Purpose: theType : TypeOfTexture from Graphic3d);
-- Returns the number of predefined textures.
---Level: Public
TextureName(myclass; aRank: Integer from Standard) Initialize (theName : NameOfTexture1D from Graphic3d;
returns CString from Standard theType : TypeOfTexture from Graphic3d);
raises OutOfRange from Standard;
---Purpose: Name (me) returns NameOfTexture1D from Graphic3d;
-- Returns the name of the predefined texture of rank <aRank> ---Purpose:
---Trigger: when <aRank> is < 1 or > NumberOfTextures. -- Returns the name of the predefined textures or NOT_1D_UNKNOWN
---Level: Public -- when the name is given as a filename.
---Level: Public
NumberOfTextures (myclass) returns Integer from Standard;
---Purpose:
-- Returns the number of predefined textures.
---Level: Public
TextureName (myclass; aRank: Integer from Standard)
returns AsciiString from TCollection
raises OutOfRange from Standard;
---Purpose:
-- Returns the name of the predefined texture of rank <aRank>
---Trigger: when <aRank> is < 1 or > NumberOfTextures.
---Level: Public
fields fields
myName: NameOfTexture1D from Graphic3d;
end Texture1D; myName : NameOfTexture1D from Graphic3d;
end Texture1D;

View File

@ -18,106 +18,69 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
// Modified 22-12-97 : FMN ; Ajout Modulate
// Modified : GG 10/01/2000 IMP
// Adds Name(),NumberOfTextures() and TextureName() methods
#include <Graphic3d_Texture1D.ixx> #include <Graphic3d_Texture1D.ixx>
#include <stdlib.h>
#include <TCollection_AsciiString.hxx> #include <TCollection_AsciiString.hxx>
#include <OSD_Directory.hxx>
#include <OSD_File.hxx>
#include <OSD_Path.hxx>
static const char *NameOfTexture_to_FileName[] = static const char *NameOfTexture_to_FileName[] =
{ {
"1d_elevation.rgb" "1d_elevation.rgb"
}; };
// =======================================================================
static TCollection_AsciiString GetEnvir ( ) { // function : Graphic3d_Texture1D
// purpose :
static Standard_Boolean IsDefined=Standard_False ; // =======================================================================
static TCollection_AsciiString VarName; Graphic3d_Texture1D::Graphic3d_Texture1D (const TCollection_AsciiString& theFileName,
if ( !IsDefined ) { const Graphic3d_TypeOfTexture theType)
char *envir, *casroot ; : Graphic3d_TextureMap (theFileName, theType),
envir = getenv("CSF_MDTVTexturesDirectory") ; myName (Graphic3d_NOT_1D_UNKNOWN)
Standard_Boolean HasDefinition = Standard_False ;
if ( !envir ) {
casroot = getenv("CASROOT");
if ( casroot ) {
VarName = TCollection_AsciiString (casroot);
VarName += "/src/Textures" ;
HasDefinition = Standard_True ;
}
} else {
VarName = TCollection_AsciiString (envir);
HasDefinition = Standard_True ;
}
if ( HasDefinition ) {
OSD_Path aPath ( VarName );
OSD_Directory aDir(aPath);
if ( aDir.Exists () ) {
TCollection_AsciiString aTexture = VarName + "/2d_MatraDatavision.rgb" ;
OSD_File TextureFile ( aTexture );
if ( !TextureFile.Exists() ) {
cout << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << endl;
cout << " not all files are found in : "<<VarName.ToCString() << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
} else {
cout << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << endl;
cout << " Directory : "<< VarName.ToCString() << " not exist " << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
return VarName ;
} else {
cout << " CSF_MDTVTexturesDirectory and CASROOT not setted " << endl;
cout << " one of these variable are mandatory to use this fonctionnality" << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory and CASROOT not setted " );
}
IsDefined = Standard_True ;
}
return VarName ;
}
Graphic3d_Texture1D::Graphic3d_Texture1D(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString FileName,const Graphic3d_TypeOfTexture Type)
: Graphic3d_TextureMap(SM,"", FileName, Type),
myName(Graphic3d_NOT_1D_UNKNOWN)
{ {
} }
// =======================================================================
Graphic3d_Texture1D::Graphic3d_Texture1D(const Handle(Graphic3d_StructureManager)& SM,const Graphic3d_NameOfTexture1D NOT, const Graphic3d_TypeOfTexture Type) // function : Graphic3d_Texture1D
: Graphic3d_TextureMap(SM, GetEnvir().ToCString(), NameOfTexture_to_FileName[NOT], Type), // purpose :
myName(NOT) // =======================================================================
Graphic3d_Texture1D::Graphic3d_Texture1D (const Graphic3d_NameOfTexture1D theNOT,
const Graphic3d_TypeOfTexture theType)
: Graphic3d_TextureMap (NameOfTexture_to_FileName[theNOT], theType),
myName (theNOT)
{ {
myPath.SetTrek (Graphic3d_TextureRoot::TexturesFolder());
myTexId = TCollection_AsciiString ("Graphic3d_Texture1D_")
+ NameOfTexture_to_FileName[theNOT];
} }
Graphic3d_NameOfTexture1D Graphic3d_Texture1D::Name() const { // =======================================================================
// function : Name
// purpose :
// =======================================================================
Graphic3d_NameOfTexture1D Graphic3d_Texture1D::Name() const
{
return myName; return myName;
} }
Standard_Integer Graphic3d_Texture1D::NumberOfTextures() { // =======================================================================
// function : NumberOfTextures
// purpose :
// =======================================================================
Standard_Integer Graphic3d_Texture1D::NumberOfTextures()
{
return sizeof(NameOfTexture_to_FileName)/sizeof(char*); return sizeof(NameOfTexture_to_FileName)/sizeof(char*);
} }
Standard_CString Graphic3d_Texture1D::TextureName(const Standard_Integer aRank) // =======================================================================
{ // function : TextureName
// purpose :
// =======================================================================
TCollection_AsciiString Graphic3d_Texture1D::TextureName (const Standard_Integer theRank)
{
if (theRank < 1 || theRank > NumberOfTextures())
{
Standard_OutOfRange::Raise ("BAD index of texture");
}
if( aRank < 1 || aRank > NumberOfTextures() ) TCollection_AsciiString aFileName (NameOfTexture_to_FileName[theRank - 1]);
Standard_OutOfRange::Raise(" BAD index of texture"); Standard_Integer i = aFileName.SearchFromEnd (".");
TCollection_AsciiString filename(NameOfTexture_to_FileName[aRank-1]); return aFileName.SubString (4, i - 1);
Standard_Integer i = filename.SearchFromEnd(".");
static TCollection_AsciiString name;
name = filename.SubString(4,i-1);
return name.ToCString();
} }

View File

@ -18,31 +18,24 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
class Texture1Dmanual from Graphic3d
class Texture1Dmanual from Graphic3d inherits Texture1D from Graphic3d
inherits Texture1D from Graphic3d ---Purpose: This class provides the implementation of a manual 1D texture.
-- you MUST provides texture coordinates on your facets if you want to see your texture.
---Purpose: This class provides the implementation of
-- a manual 1D texture.
-- you MUST provides texture coordinates on
-- your facets if you want to see your
-- texture.
uses
uses NameOfTexture1D from Graphic3d,
NameOfTexture1D from Graphic3d, AsciiString from TCollection
StructureManager from Graphic3d
is is
Create(SM : StructureManager from Graphic3d;
FileName : CString from Standard) returns mutable Texture1Dmanual from Graphic3d;
---Purpose: Creates a texture from the file FileName.
Create (theFileName : AsciiString from TCollection) returns mutable Texture1Dmanual from Graphic3d;
---Purpose: Creates a texture from the file FileName.
Create(SM : StructureManager from Graphic3d; Create (theNOT : NameOfTexture1D from Graphic3d) returns mutable Texture1Dmanual from Graphic3d;
NOT : NameOfTexture1D from Graphic3d) returns mutable Texture1Dmanual from Graphic3d; ---Purpose: Create a texture from a predefined texture name set.
---Purpose: Create a texture from a predefined texture name set.
end Texture1Dmanual;
end Texture1Dmanual;

View File

@ -18,54 +18,25 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <Graphic3d_Texture1Dmanual.ixx> #include <Graphic3d_Texture1Dmanual.ixx>
#include <Graphic3d_TypeOfTextureMode.hxx> #include <Graphic3d_TypeOfTextureMode.hxx>
Graphic3d_Texture1Dmanual::Graphic3d_Texture1Dmanual(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString FileName) // =======================================================================
: Graphic3d_Texture1D(SM, FileName, Graphic3d_TOT_1D) // function : Graphic3d_Texture1Dmanual
// purpose :
// =======================================================================
Graphic3d_Texture1Dmanual::Graphic3d_Texture1Dmanual (const TCollection_AsciiString& theFileName)
: Graphic3d_Texture1D (theFileName, Graphic3d_TOT_1D)
{ {
MyCInitTexture.doModulate = 0; //
MyCInitTexture.doRepeat = 0;
MyCInitTexture.Mode = (int)Graphic3d_TOTM_MANUAL;
MyCInitTexture.doLinear = 0;
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
// =======================================================================
Graphic3d_Texture1Dmanual::Graphic3d_Texture1Dmanual(const Handle(Graphic3d_StructureManager)& SM,const Graphic3d_NameOfTexture1D NOT) // function : Graphic3d_Texture1Dmanual
: Graphic3d_Texture1D(SM, NOT, Graphic3d_TOT_1D) // purpose :
// =======================================================================
Graphic3d_Texture1Dmanual::Graphic3d_Texture1Dmanual (const Graphic3d_NameOfTexture1D theNOT)
: Graphic3d_Texture1D (theNOT, Graphic3d_TOT_1D)
{ {
MyCInitTexture.doModulate = 0; //
MyCInitTexture.doRepeat = 0;
MyCInitTexture.Mode = (int)Graphic3d_TOTM_MANUAL;
MyCInitTexture.doLinear = 0;
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }

View File

@ -18,50 +18,46 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
class Texture1Dsegment from Graphic3d
class Texture1Dsegment from Graphic3d inherits Texture1D from Graphic3d
inherits Texture1D from Graphic3d
---Purpose: This class provides the implementation
---Purpose: This class provides the implementation -- of a 1D texture applyable along a segment.
-- of a 1D texture applyable along a segment. -- You might use the SetSegment() method
-- You might use the SetSegment() method -- to set the way the texture is "streched" on facets.
-- to set the way the texture is "streched" on facets.
uses
uses NameOfTexture1D from Graphic3d,
NameOfTexture1D from Graphic3d, AsciiString from TCollection
StructureManager from Graphic3d
is is
Create(VM : StructureManager from Graphic3d;
FileName : CString from Standard) returns mutable Texture1Dsegment from Graphic3d;
---Purpose: Creates a texture from a file
Create (theFileName : AsciiString from TCollection) returns mutable Texture1Dsegment from Graphic3d;
---Purpose: Creates a texture from a file
Create(VM : StructureManager from Graphic3d; Create (theNOT : NameOfTexture1D from Graphic3d) returns mutable Texture1Dsegment from Graphic3d;
NOT : NameOfTexture1D from Graphic3d) returns mutable Texture1Dsegment from Graphic3d; ---Purpose: Creates a texture from a predefined texture name set.
---Purpose: Creates a texture from a predefined texture name set.
SetSegment(me : mutable;
X1,Y1,Z1 : ShortReal from Standard;
X2,Y2,Z2 : ShortReal from Standard);
---Purpose: Sets the texture application bounds. Defines the way
-- the texture is stretched across facets.
-- Default values are <0.0, 0.0, 0.0> , <0.0, 0.0, 1.0>
SetSegment (me : mutable;
-- theX1, theY1, theZ1 : ShortReal from Standard;
-- inquire methods theX2, theY2, theZ2 : ShortReal from Standard);
-- ---Purpose: Sets the texture application bounds. Defines the way
Segment(me; -- the texture is stretched across facets.
X1,Y1,Z1, X2,Y2,Z2 : out ShortReal from Standard); -- Default values are <0.0, 0.0, 0.0> , <0.0, 0.0, 1.0>
---Purpose: Returns the values of the current segment X1, Y1, Z1 , X2, Y2, Z2.
--
fields -- inquire methods
MyX1,MyY1,MyZ1 : ShortReal from Standard; --
MyX2,MyY2,MyZ2 : ShortReal from Standard; Segment (me;
theX1, theY1, theZ1 : out ShortReal from Standard;
theX2, theY2, theZ2 : out ShortReal from Standard);
---Purpose: Returns the values of the current segment X1, Y1, Z1 , X2, Y2, Z2.
fields
myX1, myY1, myZ1 : ShortReal from Standard;
myX2, myY2, myZ2 : ShortReal from Standard;
end Texture1Dsegment; end Texture1Dsegment;

View File

@ -18,96 +18,97 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <Graphic3d_Texture1Dsegment.ixx> #include <Graphic3d_Texture1Dsegment.ixx>
#include <Graphic3d_TypeOfTextureMode.hxx> #include <Graphic3d_TypeOfTextureMode.hxx>
#include <Graphic3d_TextureParams.hxx>
// =======================================================================
Graphic3d_Texture1Dsegment::Graphic3d_Texture1Dsegment(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString FileName) // function : Graphic3d_Texture1Dsegment
: Graphic3d_Texture1D(SM, FileName, Graphic3d_TOT_1D) // purpose :
// =======================================================================
Graphic3d_Texture1Dsegment::Graphic3d_Texture1Dsegment (const TCollection_AsciiString& theFileName)
: Graphic3d_Texture1D (theFileName, Graphic3d_TOT_1D),
myX1 (0.0f),
myY1 (0.0f),
myZ1 (0.0f),
myX2 (0.0f),
myY2 (0.0f),
myZ2 (0.0f)
{ {
MyCInitTexture.doModulate = 0; myParams->SetRepeat (Standard_True);
MyCInitTexture.doRepeat = 1; myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
MyCInitTexture.Mode = (int)Graphic3d_TOTM_OBJECT; Graphic3d_Vec4 (0.0f, 0.0f, 1.0f, 0.0f),
MyCInitTexture.doLinear = 0; Graphic3d_Vec4 (0.0f, 0.0f, 0.0f, 0.0f));
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 1.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
// =======================================================================
Graphic3d_Texture1Dsegment::Graphic3d_Texture1Dsegment(const Handle(Graphic3d_StructureManager)& SM,const Graphic3d_NameOfTexture1D NOT) // function : Graphic3d_Texture1Dsegment
: Graphic3d_Texture1D(SM, NOT, Graphic3d_TOT_1D) // purpose :
// =======================================================================
Graphic3d_Texture1Dsegment::Graphic3d_Texture1Dsegment (const Graphic3d_NameOfTexture1D theNOT)
: Graphic3d_Texture1D (theNOT, Graphic3d_TOT_1D),
myX1 (0.0f),
myY1 (0.0f),
myZ1 (0.0f),
myX2 (0.0f),
myY2 (0.0f),
myZ2 (0.0f)
{ {
MyCInitTexture.doModulate = 0; myParams->SetRepeat (Standard_True);
MyCInitTexture.doRepeat = 1; myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
MyCInitTexture.Mode = (int)Graphic3d_TOTM_OBJECT; Graphic3d_Vec4 (0.0f, 0.0f, 1.0f, 0.0f),
MyCInitTexture.doLinear = 0; Graphic3d_Vec4 (0.0f, 0.0f, 0.0f, 0.0f));
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 1.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
// =======================================================================
void Graphic3d_Texture1Dsegment::SetSegment(const Standard_ShortReal X1,const Standard_ShortReal Y1,const Standard_ShortReal Z1,const Standard_ShortReal X2,const Standard_ShortReal Y2,const Standard_ShortReal Z2) // function : SetSegment
// purpose :
// =======================================================================
void Graphic3d_Texture1Dsegment::SetSegment (const Standard_ShortReal X1,
const Standard_ShortReal Y1,
const Standard_ShortReal Z1,
const Standard_ShortReal X2,
const Standard_ShortReal Y2,
const Standard_ShortReal Z2)
{ {
Standard_ShortReal sq_norme; myX1 = X1;
myY1 = Y1;
myZ1 = Z1;
myX2 = X2;
myY2 = Y2;
myZ2 = Z2;
Graphic3d_Vec4 aPlaneX (X2 - X1, Y2 - Y1, Z2 - Z1, 0.0f);
MyX1 = X1; Standard_ShortReal aSqNorm = aPlaneX.x() * aPlaneX.x()
MyY1 = Y1; + aPlaneX.y() * aPlaneX.y()
MyZ1 = Z1; + aPlaneX.z() * aPlaneX.z();
MyX2 = X2; aPlaneX.x() /= aSqNorm;
MyY2 = Y2; aPlaneX.y() /= aSqNorm;
MyZ2 = Z2; aPlaneX.z() /= aSqNorm;
aPlaneX.w() = -aPlaneX.x() * X1
-aPlaneX.y() * Y1
-aPlaneX.z() * Z1;
MyCInitTexture.sparams[0] = X2-X1; myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
MyCInitTexture.sparams[1] = Y2-Y1; aPlaneX,
MyCInitTexture.sparams[2] = Z2-Z1; Graphic3d_Vec4 (0.0f, 0.0f, 0.0f, 0.0f));
sq_norme = MyCInitTexture.sparams[0]*MyCInitTexture.sparams[0]
+ MyCInitTexture.sparams[1]*MyCInitTexture.sparams[1]
+ MyCInitTexture.sparams[2]*MyCInitTexture.sparams[2];
MyCInitTexture.sparams[0] /= sq_norme;
MyCInitTexture.sparams[1] /= sq_norme;
MyCInitTexture.sparams[2] /= sq_norme;
MyCInitTexture.sparams[3] = - MyCInitTexture.sparams[0]*X1
- MyCInitTexture.sparams[1]*Y1
- MyCInitTexture.sparams[2]*Z1;
Update();
} }
// =======================================================================
// function : Segment
void Graphic3d_Texture1Dsegment::Segment(Standard_ShortReal& X1,Standard_ShortReal& Y1,Standard_ShortReal& Z1,Standard_ShortReal& X2,Standard_ShortReal& Y2,Standard_ShortReal& Z2) const // purpose :
// =======================================================================
void Graphic3d_Texture1Dsegment::Segment (Standard_ShortReal& X1,
Standard_ShortReal& Y1,
Standard_ShortReal& Z1,
Standard_ShortReal& X2,
Standard_ShortReal& Y2,
Standard_ShortReal& Z2) const
{ {
X1 = MyX1; X1 = myX1;
Y1 = MyY1; Y1 = myY1;
Z1 = MyZ1; Z1 = myZ1;
X2 = MyX2; X2 = myX2;
Y2 = MyY2; Y2 = myY2;
Z2 = MyZ2; Z2 = myZ2;
} }

View File

@ -18,55 +18,50 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
-- Modified : GG 10/01/2000 IMP deferred class Texture2D from Graphic3d
-- Add NumberOfTextures() and TextureName() methods
-- Add Name() and IsRepeat() method
deferred class Texture2D from Graphic3d inherits TextureMap from Graphic3d
inherits TextureMap from Graphic3d
---Purpose: This abstract class for managing 2D textures ---Purpose: This abstract class for managing 2D textures
uses uses
TypeOfTexture from Graphic3d,
NameOfTexture2D from Graphic3d, TypeOfTexture from Graphic3d,
StructureManager from Graphic3d NameOfTexture2D from Graphic3d,
AsciiString from TCollection
raises raises
OutOfRange from Standard
is
Initialize(SM : StructureManager from Graphic3d;
aFileName : CString from Standard;
aType : TypeOfTexture from Graphic3d);
Initialize(SM : StructureManager from Graphic3d;
aName : NameOfTexture2D from Graphic3d;
aType : TypeOfTexture from Graphic3d);
Name(me) returns NameOfTexture2D from Graphic3d; OutOfRange from Standard
---Purpose:
-- Returns the name of the predefined textures or NOT_2D_UNKNOWN
-- when the name is given as a filename.
---Level: Public
NumberOfTextures(myclass) returns Integer from Standard; is
---Purpose:
-- Returns the number of predefined textures.
---Level: Public
TextureName(myclass; aRank: Integer from Standard) Initialize (theFileName : AsciiString from TCollection;
returns CString from Standard theType : TypeOfTexture from Graphic3d);
raises OutOfRange from Standard;
---Purpose: Initialize (theName : NameOfTexture2D from Graphic3d;
-- Returns the name of the predefined texture of rank <aRank> theType : TypeOfTexture from Graphic3d);
---Trigger: when <aRank> is < 1 or > NumberOfTextures.
---Level: Public Name (me) returns NameOfTexture2D from Graphic3d;
---Purpose:
-- Returns the name of the predefined textures or NOT_2D_UNKNOWN
-- when the name is given as a filename.
---Level: Public
NumberOfTextures (myclass) returns Integer from Standard;
---Purpose:
-- Returns the number of predefined textures.
---Level: Public
TextureName (myclass; theRank: Integer from Standard) returns AsciiString from TCollection
raises OutOfRange from Standard;
---Purpose:
-- Returns the name of the predefined texture of rank <aRank>
---Trigger: when <aRank> is < 1 or > NumberOfTextures.
---Level: Public
fields fields
myName: NameOfTexture2D from Graphic3d;
end Texture2D; myName : NameOfTexture2D from Graphic3d;
end Texture2D;

View File

@ -18,69 +18,8 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
// Modified : GG 10/01/2000 IMP
// Adds Name(),NumberOfTextures() and TextureName() methods
#include <Graphic3d_Texture2D.ixx> #include <Graphic3d_Texture2D.ixx>
#include <stdlib.h>
#include <TCollection_AsciiString.hxx> #include <TCollection_AsciiString.hxx>
#include <OSD_Directory.hxx>
#include <OSD_File.hxx>
#include <OSD_Path.hxx>
static TCollection_AsciiString GetEnvir ( ) {
static Standard_Boolean IsDefined=Standard_False ;
static TCollection_AsciiString VarName;
if ( !IsDefined ) {
char *envir, *casroot ;
envir = getenv("CSF_MDTVTexturesDirectory") ;
Standard_Boolean HasDefinition = Standard_False ;
if ( !envir ) {
casroot = getenv("CASROOT");
if ( casroot ) {
VarName = TCollection_AsciiString (casroot);
VarName += "/src/Textures" ;
HasDefinition = Standard_True ;
}
} else {
VarName = TCollection_AsciiString (envir);
HasDefinition = Standard_True ;
}
if ( HasDefinition ) {
OSD_Path aPath ( VarName );
OSD_Directory aDir(aPath);
if ( aDir.Exists () ) {
TCollection_AsciiString aTexture = VarName + "/2d_MatraDatavision.rgb" ;
OSD_File TextureFile ( aTexture );
if ( !TextureFile.Exists() ) {
cout << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << endl;
cout << " not all files are found in : "<<VarName.ToCString() << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
} else {
cout << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << endl;
cout << " Directory : "<< VarName.ToCString() << " not exist " << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
return VarName ;
} else {
cout << " CSF_MDTVTexturesDirectory and CASROOT not setted " << endl;
cout << " one of these variable are mandatory to use this fonctionnality" << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory and CASROOT not setted " );
}
IsDefined = Standard_True ;
}
return VarName ;
}
static const char *NameOfTexture_to_FileName[] = static const char *NameOfTexture_to_FileName[] =
{ {
@ -107,40 +46,61 @@ static const char *NameOfTexture_to_FileName[] =
"2d_rain.rgb" "2d_rain.rgb"
}; };
// =======================================================================
Graphic3d_Texture2D::Graphic3d_Texture2D(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString FileName,const Graphic3d_TypeOfTexture Type) // function : Graphic3d_Texture2D
: Graphic3d_TextureMap(SM, "", FileName, Type), // purpose :
myName(Graphic3d_NOT_2D_UNKNOWN) // =======================================================================
Graphic3d_Texture2D::Graphic3d_Texture2D (const TCollection_AsciiString& theFileName,
const Graphic3d_TypeOfTexture theType)
: Graphic3d_TextureMap (theFileName, theType),
myName (Graphic3d_NOT_2D_UNKNOWN)
{ {
} }
// =======================================================================
Graphic3d_Texture2D::Graphic3d_Texture2D(const Handle(Graphic3d_StructureManager)& SM,const Graphic3d_NameOfTexture2D NOT, const Graphic3d_TypeOfTexture Type) // function : Graphic3d_Texture2D
: Graphic3d_TextureMap(SM, GetEnvir().ToCString() , NameOfTexture_to_FileName[NOT], Type), // purpose :
myName(NOT) // =======================================================================
Graphic3d_Texture2D::Graphic3d_Texture2D (const Graphic3d_NameOfTexture2D theNOT,
const Graphic3d_TypeOfTexture theType)
: Graphic3d_TextureMap (NameOfTexture_to_FileName[theNOT], theType),
myName (theNOT)
{ {
myPath.SetTrek (Graphic3d_TextureRoot::TexturesFolder());
myTexId = TCollection_AsciiString ("Graphic3d_Texture2D_")
+ NameOfTexture_to_FileName[theNOT];
} }
Standard_Integer Graphic3d_Texture2D::NumberOfTextures() { // =======================================================================
// function : NumberOfTextures
// purpose :
// =======================================================================
Standard_Integer Graphic3d_Texture2D::NumberOfTextures()
{
return sizeof(NameOfTexture_to_FileName)/sizeof(char*); return sizeof(NameOfTexture_to_FileName)/sizeof(char*);
} }
Graphic3d_NameOfTexture2D Graphic3d_Texture2D::Name() const { // =======================================================================
// function : Name
// purpose :
// =======================================================================
Graphic3d_NameOfTexture2D Graphic3d_Texture2D::Name() const
{
return myName; return myName;
} }
Standard_CString Graphic3d_Texture2D::TextureName(const Standard_Integer aRank) // =======================================================================
{ // function : TextureName
// purpose :
// =======================================================================
TCollection_AsciiString Graphic3d_Texture2D::TextureName (const Standard_Integer theRank)
{
if (theRank < 1 || theRank > NumberOfTextures())
{
Standard_OutOfRange::Raise ("BAD index of texture");
}
if( aRank < 1 || aRank > NumberOfTextures() ) TCollection_AsciiString aFileName (NameOfTexture_to_FileName[theRank - 1]);
Standard_OutOfRange::Raise(" BAD index of texture"); Standard_Integer i = aFileName.SearchFromEnd (".");
TCollection_AsciiString filename(NameOfTexture_to_FileName[aRank-1]); return aFileName.SubString (4, i - 1);
Standard_Integer i = filename.SearchFromEnd(".");
static TCollection_AsciiString name;
name = filename.SubString(4,i-1);
return name.ToCString();
} }

View File

@ -18,27 +18,25 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
class Texture2Dmanual from Graphic3d
class Texture2Dmanual from Graphic3d inherits Texture2D from Graphic3d
---Purpose: This class defined a manual texture 2D
inherits Texture2D from Graphic3d -- facets MUST define texture coordinate
---Purpose: This class defined a manual texture 2D -- if you want to see somethings on.
-- facets MUST define texture coordinate
-- if you want to see somethings on.
uses uses
NameOfTexture2D from Graphic3d,
StructureManager from Graphic3d
NameOfTexture2D from Graphic3d,
AsciiString from TCollection
is is
Create(SM : StructureManager from Graphic3d;
FileName : CString from Standard) returns mutable Texture2Dmanual from Graphic3d; Create (theFileName : AsciiString from TCollection) returns mutable Texture2Dmanual from Graphic3d;
---Purpose: Creates a texture from a file ---Purpose: Creates a texture from a file
Create(SM : StructureManager from Graphic3d; Create (theNOT : NameOfTexture2D from Graphic3d) returns mutable Texture2Dmanual from Graphic3d;
NOT : NameOfTexture2D from Graphic3d) returns mutable Texture2Dmanual from Graphic3d; ---Purpose: Creates a texture from a predefined texture name set.
---Purpose: Creates a texture from a predefined texture name set.
end Texture2Dmanual;
end Texture2Dmanual;

View File

@ -18,56 +18,30 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <Graphic3d_Texture2Dmanual.ixx> #include <Graphic3d_Texture2Dmanual.ixx>
#include <Graphic3d_TypeOfTextureMode.hxx> #include <Graphic3d_TypeOfTextureMode.hxx>
#include <Graphic3d_TextureParams.hxx>
// =======================================================================
Graphic3d_Texture2Dmanual::Graphic3d_Texture2Dmanual(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString FileName) // function : Graphic3d_Texture2Dmanual
: Graphic3d_Texture2D(SM, FileName, Graphic3d_TOT_2D_MIPMAP) // purpose :
// =======================================================================
Graphic3d_Texture2Dmanual::Graphic3d_Texture2Dmanual (const TCollection_AsciiString& theFileName)
: Graphic3d_Texture2D (theFileName, Graphic3d_TOT_2D_MIPMAP)
{ {
MyCInitTexture.doModulate = 1; myParams->SetModulate (Standard_True);
MyCInitTexture.doRepeat = 1; myParams->SetRepeat (Standard_True);
MyCInitTexture.Mode = (int)Graphic3d_TOTM_MANUAL; myParams->SetFilter (Graphic3d_TOTF_TRILINEAR);
MyCInitTexture.doLinear = 1;
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
// =======================================================================
Graphic3d_Texture2Dmanual::Graphic3d_Texture2Dmanual(const Handle(Graphic3d_StructureManager)& SM,const Graphic3d_NameOfTexture2D NOT) // function : Graphic3d_Texture2Dmanual
: Graphic3d_Texture2D(SM, NOT, Graphic3d_TOT_2D_MIPMAP) // purpose :
// =======================================================================
Graphic3d_Texture2Dmanual::Graphic3d_Texture2Dmanual (const Graphic3d_NameOfTexture2D theNOT)
: Graphic3d_Texture2D (theNOT, Graphic3d_TOT_2D_MIPMAP)
{ {
MyCInitTexture.doModulate = 1; myParams->SetModulate (Standard_True);
MyCInitTexture.doRepeat = 1; myParams->SetRepeat (Standard_True);
MyCInitTexture.Mode = (int)Graphic3d_TOTM_MANUAL; myParams->SetFilter (Graphic3d_TOTF_TRILINEAR);
MyCInitTexture.doLinear = 1;
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }

View File

@ -18,115 +18,103 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
-- Modified : GG IMP280200 class Texture2Dplane from Graphic3d
-- Add Plane(),ScaleT(),ScaleS() methods
class Texture2Dplane from Graphic3d inherits Texture2D from Graphic3d
inherits Texture2D from Graphic3d
---Purpose: This class allows the management of a 2D texture defined from a plane equation ---Purpose: This class allows the management of a 2D texture defined from a plane equation
-- Use the SetXXX() methods for positioning the texture as you want. -- Use the SetXXX() methods for positioning the texture as you want.
uses uses
NameOfTexture2D from Graphic3d,
NameOfTexturePlane from Graphic3d,
StructureManager from Graphic3d
NameOfTexture2D from Graphic3d,
NameOfTexturePlane from Graphic3d,
AsciiString from TCollection
is is
Create(SM : StructureManager from Graphic3d;
FileName : CString from Standard) returns mutable Texture2Dplane from Graphic3d;
---Purpose: Creates a texture from a file
Create (theFileName : AsciiString from TCollection) returns mutable Texture2Dplane from Graphic3d;
---Purpose: Creates a texture from a file
Create(SM : StructureManager from Graphic3d; Create (theNOT : NameOfTexture2D from Graphic3d) returns mutable Texture2Dplane from Graphic3d;
NOT : NameOfTexture2D from Graphic3d) returns mutable Texture2Dplane from Graphic3d; ---Purpose: Creates a texture from a predefined texture name set.
---Purpose: Creates a texture from a predefined texture name set.
SetPlaneS(me : mutable; A,B,C,D : ShortReal from Standard); SetPlaneS (me : mutable; A, B, C, D : ShortReal from Standard);
---Purpose: Defines the texture projection plane for texture coordinate S ---Purpose: Defines the texture projection plane for texture coordinate S
-- default is <1.0, 0.0, 0.0, 0.0> -- default is <1.0, 0.0, 0.0, 0.0>
SetPlaneT(me : mutable; A,B,C,D : ShortReal from Standard); SetPlaneT (me : mutable; A, B, C, D : ShortReal from Standard);
---Purpose: Defines the texture projection plane for texture coordinate T ---Purpose: Defines the texture projection plane for texture coordinate T
-- default is <0.0, 1.0, 0.0, 0.0> -- default is <0.0, 1.0, 0.0, 0.0>
SetPlane(me : mutable; APlane : NameOfTexturePlane from Graphic3d); SetPlane (me : mutable; thePlane : NameOfTexturePlane from Graphic3d);
---Purpose: Defines the texture projection plane for both S and T texture coordinate ---Purpose: Defines the texture projection plane for both S and T texture coordinate
-- default is NOTP_XY meaning: -- default is NOTP_XY meaning:
-- <1.0, 0.0, 0.0, 0.0> for S -- <1.0, 0.0, 0.0, 0.0> for S
-- and <0.0, 1.0, 0.0, 0.0> for T -- and <0.0, 1.0, 0.0, 0.0> for T
SetScaleS(me : mutable; val : ShortReal from Standard);
---Purpose: Defines the texture scale for the S texture coordinate
-- much easier than recomputing the S plane equation
-- but the result is the same
-- default to 1.0
SetScaleT(me : mutable; val : ShortReal from Standard); SetScaleS (me : mutable; theVal : ShortReal from Standard);
---Purpose: Defines the texture scale for the T texture coordinate ---Purpose: Defines the texture scale for the S texture coordinate
-- much easier than recompution the T plane equation -- much easier than recomputing the S plane equation
-- but the result is the same -- but the result is the same
-- default to 1.0 -- default to 1.0
SetTranslateS(me : mutable; val : ShortReal from Standard);
---Purpose: Defines the texture translation for the S texture coordinate
-- you can obtain the same effect by modifying the S plane
-- equation but its not easier.
-- default to 0.0
SetTranslateT(me : mutable; val : ShortReal from Standard); SetScaleT (me : mutable; theVal : ShortReal from Standard);
---Purpose: Defines the texture translation for the T texture coordinate ---Purpose: Defines the texture scale for the T texture coordinate
-- you can obtain the same effect by modifying the T plane -- much easier than recompution the T plane equation
-- equation but its not easier. -- but the result is the same
-- default to 0.0 -- default to 1.0
SetRotation(me : mutable; val : ShortReal from Standard);
---Purpose: Sets the rotation angle of the whole texture.
-- the same result might be achieved by recomputing the
-- S and T plane equation but it's not the easiest way...
-- the angle is expressed in degres
-- default is 0.0
SetTranslateS (me : mutable; theVal : ShortReal from Standard);
---Purpose: Defines the texture translation for the S texture coordinate
-- you can obtain the same effect by modifying the S plane
-- equation but its not easier.
-- default to 0.0
SetTranslateT (me : mutable; theVal : ShortReal from Standard);
---Purpose: Defines the texture translation for the T texture coordinate
-- you can obtain the same effect by modifying the T plane
-- equation but its not easier.
-- default to 0.0
SetRotation (me : mutable; theVal : ShortReal from Standard);
---Purpose: Sets the rotation angle of the whole texture.
-- the same result might be achieved by recomputing the
-- S and T plane equation but it's not the easiest way...
-- the angle is expressed in degrees
-- default is 0.0
-- --
-- inquire methods -- inquire methods
-- --
Plane(me) returns NameOfTexturePlane from Graphic3d; Plane (me) returns NameOfTexturePlane from Graphic3d;
---Purpose: Returns the current texture plane name or NOTP_UNKNOWN ---Purpose: Returns the current texture plane name or NOTP_UNKNOWN
-- when the plane is user defined. -- when the plane is user defined.
PlaneS(me; A,B,C,D : out ShortReal from Standard); PlaneS (me; A, B, C, D : out ShortReal from Standard);
---Purpose: Returns the current texture plane S equation ---Purpose: Returns the current texture plane S equation
PlaneT(me; A,B,C,D : out ShortReal from Standard); PlaneT (me; A, B, C, D : out ShortReal from Standard);
---Purpose: Returns the current texture plane T equation ---Purpose: Returns the current texture plane T equation
TranslateS(me; val : out ShortReal from Standard); TranslateS (me; theVal : out ShortReal from Standard);
---Purpose: Returns the current texture S translation value ---Purpose: Returns the current texture S translation value
TranslateT(me; val : out ShortReal from Standard); TranslateT (me; theVal : out ShortReal from Standard);
---Purpose: Returns the current texture T translation value ---Purpose: Returns the current texture T translation value
ScaleS(me; val : out ShortReal from Standard); ScaleS (me; theVal : out ShortReal from Standard);
---Purpose: Returns the current texture S scale value ---Purpose: Returns the current texture S scale value
ScaleT(me; val : out ShortReal from Standard); ScaleT (me; theVal : out ShortReal from Standard);
---Purpose: Returns the current texture T scale value ---Purpose: Returns the current texture T scale value
Rotation(me; val : out ShortReal from Standard); Rotation (me; theVal : out ShortReal from Standard);
---Purpose: Returns the current texture rotation angle ---Purpose: Returns the current texture rotation angle
fields fields
myPlaneName: NameOfTexturePlane from Graphic3d; myPlaneName : NameOfTexturePlane from Graphic3d;
end Texture2Dplane;
end Texture2Dplane;

View File

@ -18,218 +18,240 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#define IMP280200 //GG Add Plane(),ScaleT(),ScaleS() methods
#include <Graphic3d_Texture2Dplane.ixx> #include <Graphic3d_Texture2Dplane.ixx>
#include <Graphic3d_TypeOfTextureMode.hxx> #include <Graphic3d_TypeOfTextureMode.hxx>
#include <Graphic3d_TextureParams.hxx>
// =======================================================================
Graphic3d_Texture2Dplane::Graphic3d_Texture2Dplane(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString FileName) // function : Graphic3d_Texture2Dplane
: Graphic3d_Texture2D(SM, FileName, Graphic3d_TOT_2D_MIPMAP) // purpose :
// =======================================================================
Graphic3d_Texture2Dplane::Graphic3d_Texture2Dplane (const TCollection_AsciiString& theFileName)
: Graphic3d_Texture2D (theFileName, Graphic3d_TOT_2D_MIPMAP)
{ {
MyCInitTexture.doModulate = 1; myParams->SetModulate (Standard_True);
MyCInitTexture.doRepeat = 1; myParams->SetRepeat (Standard_True);
MyCInitTexture.Mode = (int)Graphic3d_TOTM_OBJECT; myParams->SetFilter (Graphic3d_TOTF_TRILINEAR);
MyCInitTexture.doLinear = 1; myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
MyCInitTexture.sx = 1.0F; Graphic3d_Vec4 (1.0f, 0.0f, 0.0f, 0.0f),
MyCInitTexture.sy = 1.0F; Graphic3d_Vec4 (0.0f, 1.0f, 0.0f, 0.0f));
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 1.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 1.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
// =======================================================================
// function : Graphic3d_Texture2Dplane
Graphic3d_Texture2Dplane::Graphic3d_Texture2Dplane(const Handle(Graphic3d_StructureManager)& SM,const Graphic3d_NameOfTexture2D NOT) // purpose :
: Graphic3d_Texture2D(SM, NOT, Graphic3d_TOT_2D_MIPMAP) // =======================================================================
Graphic3d_Texture2Dplane::Graphic3d_Texture2Dplane (const Graphic3d_NameOfTexture2D theNOT)
: Graphic3d_Texture2D (theNOT, Graphic3d_TOT_2D_MIPMAP)
{ {
MyCInitTexture.doModulate = 1; myParams->SetModulate (Standard_True);
MyCInitTexture.doRepeat = 1; myParams->SetRepeat (Standard_True);
MyCInitTexture.Mode = (int)Graphic3d_TOTM_OBJECT; myParams->SetFilter (Graphic3d_TOTF_TRILINEAR);
MyCInitTexture.doLinear = 1; myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
MyCInitTexture.sx = 1.0F; Graphic3d_Vec4 (1.0f, 0.0f, 0.0f, 0.0f),
MyCInitTexture.sy = 1.0F; Graphic3d_Vec4 (0.0f, 1.0f, 0.0f, 0.0f));
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 1.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 1.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetPlaneS(const Standard_ShortReal A,const Standard_ShortReal B,const Standard_ShortReal C,const Standard_ShortReal D) // function : SetPlaneS
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetPlaneS (const Standard_ShortReal theA,
const Standard_ShortReal theB,
const Standard_ShortReal theC,
const Standard_ShortReal theD)
{ {
MyCInitTexture.sparams[0] = A; const Graphic3d_Vec4 aPlaneS (theA, theB, theC, theD);
MyCInitTexture.sparams[1] = B; const Graphic3d_Vec4 aPlaneT = myParams->GenPlaneT();
MyCInitTexture.sparams[2] = C; myParams->SetGenMode (Graphic3d_TOTM_OBJECT, aPlaneS, aPlaneT);
MyCInitTexture.sparams[3] = D;
#ifdef IMP280200
myPlaneName = Graphic3d_NOTP_UNKNOWN; myPlaneName = Graphic3d_NOTP_UNKNOWN;
#endif
Update();
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetPlaneT(const Standard_ShortReal A,const Standard_ShortReal B,const Standard_ShortReal C,const Standard_ShortReal D) // function : SetPlaneT
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetPlaneT (const Standard_ShortReal theA,
const Standard_ShortReal theB,
const Standard_ShortReal theC,
const Standard_ShortReal theD)
{ {
MyCInitTexture.tparams[0] = A; const Graphic3d_Vec4 aPlaneS = myParams->GenPlaneS();
MyCInitTexture.tparams[1] = B; const Graphic3d_Vec4 aPlaneT (theA, theB, theC, theD);
MyCInitTexture.tparams[2] = C; myParams->SetGenMode (Graphic3d_TOTM_OBJECT, aPlaneS, aPlaneT);
MyCInitTexture.tparams[3] = D;
#ifdef IMP280200
myPlaneName = Graphic3d_NOTP_UNKNOWN; myPlaneName = Graphic3d_NOTP_UNKNOWN;
#endif
Update();
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetPlane(const Graphic3d_NameOfTexturePlane APlane) // function : SetPlane
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetPlane (const Graphic3d_NameOfTexturePlane thePlane)
{ {
switch (APlane) switch (thePlane)
{ {
case Graphic3d_NOTP_XY: case Graphic3d_NOTP_XY:
MyCInitTexture.sparams[0] = 1.0F; {
MyCInitTexture.sparams[1] = 0.0F; myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
MyCInitTexture.sparams[2] = 0.0F; Graphic3d_Vec4 (1.0f, 0.0f, 0.0f, 0.0f),
MyCInitTexture.sparams[3] = 0.0F; Graphic3d_Vec4 (0.0f, 1.0f, 0.0f, 0.0f));
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 1.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
break;
case Graphic3d_NOTP_YZ:
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 1.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 1.0F;
MyCInitTexture.tparams[3] = 0.0F;
break;
case Graphic3d_NOTP_ZX:
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 1.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 1.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
break;
default:
break; break;
} }
case Graphic3d_NOTP_YZ:
{
myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
Graphic3d_Vec4 (0.0f, 1.0f, 0.0f, 0.0f),
Graphic3d_Vec4 (0.0f, 0.0f, 1.0f, 0.0f));
break;
}
case Graphic3d_NOTP_ZX:
{
myParams->SetGenMode (Graphic3d_TOTM_OBJECT,
Graphic3d_Vec4 (0.0f, 0.0f, 1.0f, 0.0f),
Graphic3d_Vec4 (1.0f, 0.0f, 0.0f, 0.0f));
break;
}
default: break;
}
#ifdef IMP280200 myPlaneName = thePlane;
myPlaneName = APlane;
#endif
Update();
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetScaleS(const Standard_ShortReal val) // function : SetScaleS
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetScaleS (const Standard_ShortReal theVal)
{ {
MyCInitTexture.sx = val; Graphic3d_Vec2 aScale = myParams->Scale();
Update(); aScale.x() = theVal;
myParams->SetScale (aScale);
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetScaleT(const Standard_ShortReal val) // function : SetScaleT
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetScaleT (const Standard_ShortReal theVal)
{ {
MyCInitTexture.sy = val; Graphic3d_Vec2 aScale = myParams->Scale();
Update(); aScale.y() = theVal;
myParams->SetScale (aScale);
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetTranslateS(const Standard_ShortReal val) // function : SetTranslateS
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetTranslateS (const Standard_ShortReal theVal)
{ {
MyCInitTexture.tx = val; Graphic3d_Vec2 aVec = myParams->Translation();
Update(); aVec.x() = theVal;
myParams->SetTranslation (aVec);
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetTranslateT(const Standard_ShortReal val) // function : SetTranslateT
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetTranslateT (const Standard_ShortReal theVal)
{ {
MyCInitTexture.ty = val; Graphic3d_Vec2 aVec = myParams->Translation();
Update(); aVec.y() = theVal;
myParams->SetTranslation (aVec);
} }
// =======================================================================
void Graphic3d_Texture2Dplane::SetRotation(const Standard_ShortReal val) // function : SetRotation
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::SetRotation (const Standard_ShortReal theAngleDegrees)
{ {
MyCInitTexture.angle = val; myParams->SetRotation (theAngleDegrees);
Update();
} }
void Graphic3d_Texture2Dplane::PlaneS(Standard_ShortReal& A,Standard_ShortReal& B,Standard_ShortReal& C,Standard_ShortReal& D) const // =======================================================================
// function : PlaneS
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::PlaneS (Standard_ShortReal& theA,
Standard_ShortReal& theB,
Standard_ShortReal& theC,
Standard_ShortReal& theD) const
{ {
A = MyCInitTexture.sparams[0]; const Graphic3d_Vec4& aPlaneS = myParams->GenPlaneS();
B = MyCInitTexture.sparams[1]; theA = aPlaneS.x();
C = MyCInitTexture.sparams[2]; theB = aPlaneS.y();
D = MyCInitTexture.sparams[3]; theC = aPlaneS.z();
theD = aPlaneS.w();
} }
void Graphic3d_Texture2Dplane::PlaneT(Standard_ShortReal& A,Standard_ShortReal& B,Standard_ShortReal& C,Standard_ShortReal& D) const // =======================================================================
// function : PlaneT
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::PlaneT (Standard_ShortReal& theA,
Standard_ShortReal& theB,
Standard_ShortReal& theC,
Standard_ShortReal& theD) const
{ {
A = MyCInitTexture.tparams[0]; const Graphic3d_Vec4& aPlaneT = myParams->GenPlaneT();
B = MyCInitTexture.tparams[1]; theA = aPlaneT.x();
C = MyCInitTexture.tparams[2]; theB = aPlaneT.y();
D = MyCInitTexture.tparams[3]; theC = aPlaneT.z();
theD = aPlaneT.w();
} }
void Graphic3d_Texture2Dplane::TranslateS(Standard_ShortReal& val) const // =======================================================================
// function : TranslateS
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::TranslateS (Standard_ShortReal& theVal) const
{ {
val = MyCInitTexture.tx; theVal = myParams->Translation().x();
} }
void Graphic3d_Texture2Dplane::TranslateT(Standard_ShortReal& val) const // =======================================================================
// function : TranslateT
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::TranslateT (Standard_ShortReal& theVal) const
{ {
val = MyCInitTexture.ty; theVal = myParams->Translation().y();
} }
void Graphic3d_Texture2Dplane::Rotation(Standard_ShortReal& val) const // =======================================================================
// function : Rotation
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::Rotation (Standard_ShortReal& theVal) const
{ {
val = MyCInitTexture.angle; theVal = myParams->Rotation();
} }
#ifdef IMP280200 // =======================================================================
Graphic3d_NameOfTexturePlane Graphic3d_Texture2Dplane::Plane() const { // function : Plane
// purpose :
// =======================================================================
Graphic3d_NameOfTexturePlane Graphic3d_Texture2Dplane::Plane() const
{
return myPlaneName; return myPlaneName;
} }
void Graphic3d_Texture2Dplane::ScaleS(Standard_ShortReal& val) const // =======================================================================
// function : ScaleS
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::ScaleS (Standard_ShortReal& theVal) const
{ {
val = MyCInitTexture.sx; theVal = myParams->Scale().x();
} }
void Graphic3d_Texture2Dplane::ScaleT(Standard_ShortReal& val) const // =======================================================================
// function : ScaleT
// purpose :
// =======================================================================
void Graphic3d_Texture2Dplane::ScaleT (Standard_ShortReal& theVal) const
{ {
val = MyCInitTexture.sy; theVal = myParams->Scale().y();
} }
#endif

View File

@ -18,56 +18,50 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
-- Modified : GG 10/01/2000 IMP class TextureEnv from Graphic3d
-- Add NumberOfTextures() and TextureName() methods
-- Add Name() method
class TextureEnv from Graphic3d inherits TextureRoot from Graphic3d
inherits TextureRoot from Graphic3d
---Purpose: This class provides environment texture usable only in Visual3d_ContextView ---Purpose: This class provides environment texture usable only in Visual3d_ContextView
uses uses
NameOfTextureEnv from Graphic3d,
StructureManager from Graphic3d NameOfTextureEnv from Graphic3d,
AsciiString from TCollection
raises raises
OutOfRange from Standard
is OutOfRange from Standard
Create(SM : StructureManager from Graphic3d;
aFileName : CString from Standard)
returns mutable TextureEnv from Graphic3d;
---Purpose: Creates an environment texture from a file
Create(SM : StructureManager from Graphic3d; is
aName: NameOfTextureEnv from Graphic3d)
returns mutable TextureEnv from Graphic3d;
---Purpose: Creates an environment texture from a predefined texture name set.
Name(me) returns NameOfTextureEnv from Graphic3d; Create (theFileName : AsciiString from TCollection) returns mutable TextureEnv from Graphic3d;
---Purpose: ---Purpose: Creates an environment texture from a file.
-- Returns the name of the predefined textures or NOT_ENV_UNKNOWN
-- when the name is given as a filename.
---Level: Public
NumberOfTextures(myclass) returns Integer from Standard; Create (theName : NameOfTextureEnv from Graphic3d) returns mutable TextureEnv from Graphic3d;
---Purpose: ---Purpose: Creates an environment texture from a predefined texture name set.
-- Returns the number of predefined textures.
---Level: Public
TextureName(myclass; aRank: Integer from Standard) Name (me) returns NameOfTextureEnv from Graphic3d;
returns CString from Standard ---Purpose:
raises OutOfRange from Standard; -- Returns the name of the predefined textures or NOT_ENV_UNKNOWN
---Purpose: -- when the name is given as a filename.
-- Returns the name of the predefined texture of rank <aRank> ---Level: Public
---Trigger: when <aRank> is < 1 or > NumberOfTextures.
---Level: Public NumberOfTextures (myclass) returns Integer from Standard;
---Purpose:
-- Returns the number of predefined textures.
---Level: Public
TextureName (myclass; theRank: Integer from Standard)
returns AsciiString from TCollection
raises OutOfRange from Standard;
---Purpose:
-- Returns the name of the predefined texture of rank <aRank>
---Trigger: when <aRank> is < 1 or > NumberOfTextures.
---Level: Public
fields fields
myName: NameOfTextureEnv from Graphic3d;
end TextureEnv;
myName : NameOfTextureEnv from Graphic3d;
end TextureEnv;

View File

@ -18,69 +18,11 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
// Modified : GG 10/01/2000 IMP
// Adds Name(),NumberOfTextures() and TextureName() methods
#include <Graphic3d_TextureEnv.ixx> #include <Graphic3d_TextureEnv.ixx>
#include <Graphic3d_TypeOfTexture.hxx> #include <Graphic3d_TypeOfTexture.hxx>
#include <Graphic3d_TypeOfTextureMode.hxx> #include <Graphic3d_TypeOfTextureMode.hxx>
#include <Graphic3d_TextureParams.hxx>
#include <TCollection_AsciiString.hxx> #include <TCollection_AsciiString.hxx>
#include <OSD_Directory.hxx>
#include <OSD_File.hxx>
#include <OSD_Path.hxx>
#include <stdlib.h>
static TCollection_AsciiString GetEnvir ( ) {
static Standard_Boolean IsDefined=Standard_False ;
static TCollection_AsciiString VarName;
if ( !IsDefined ) {
char *envir, *casroot ;
envir = getenv("CSF_MDTVTexturesDirectory") ;
Standard_Boolean HasDefinition = Standard_False ;
if ( !envir ) {
casroot = getenv("CASROOT");
if ( casroot ) {
VarName = TCollection_AsciiString (casroot);
VarName += "/src/Textures" ;
HasDefinition = Standard_True ;
}
} else {
VarName = TCollection_AsciiString (envir);
HasDefinition = Standard_True ;
}
if ( HasDefinition ) {
OSD_Path aPath ( VarName );
OSD_Directory aDir(aPath);
if ( aDir.Exists () ) {
TCollection_AsciiString aTexture = VarName + "/2d_MatraDatavision.rgb" ;
OSD_File TextureFile ( aTexture );
if ( !TextureFile.Exists() ) {
cout << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << endl;
cout << " not all files are found in : "<<VarName.ToCString() << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
} else {
cout << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << endl;
cout << " Directory : "<< VarName.ToCString() << " not exist " << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
return VarName ;
} else {
cout << " CSF_MDTVTexturesDirectory and CASROOT not setted " << endl;
cout << " one of these variable are mandatory to use this fonctionnality" << endl;
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory and CASROOT not setted " );
}
IsDefined = Standard_True ;
}
return VarName ;
}
static const char *NameOfTexture_to_FileName[] = static const char *NameOfTexture_to_FileName[] =
{ {
@ -94,74 +36,68 @@ static const char *NameOfTexture_to_FileName[] =
"env_road.rgb" "env_road.rgb"
}; };
// =======================================================================
Graphic3d_TextureEnv::Graphic3d_TextureEnv(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString FileName) // function : Graphic3d_TextureEnv
: Graphic3d_TextureRoot(SM, "", FileName, Graphic3d_TOT_2D_MIPMAP), // purpose :
myName(Graphic3d_NOT_ENV_UNKNOWN) // =======================================================================
Graphic3d_TextureEnv::Graphic3d_TextureEnv (const TCollection_AsciiString& theFileName)
: Graphic3d_TextureRoot (theFileName, Graphic3d_TOT_2D_MIPMAP),
myName (Graphic3d_NOT_ENV_UNKNOWN)
{ {
MyCInitTexture.doModulate = 0; myParams->SetFilter (Graphic3d_TOTF_TRILINEAR);
MyCInitTexture.doRepeat = 0; myParams->SetGenMode (Graphic3d_TOTM_SPHERE,
MyCInitTexture.Mode = (int)Graphic3d_TOTM_SPHERE; Graphic3d_Vec4 (1.0f, 0.0f, 0.0f, 0.0f),
MyCInitTexture.doLinear = 1; Graphic3d_Vec4 (0.0f, 1.0f, 0.0f, 0.0f));
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 1.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 1.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
// =======================================================================
Graphic3d_TextureEnv::Graphic3d_TextureEnv(const Handle(Graphic3d_StructureManager)& SM,const Graphic3d_NameOfTextureEnv NOT) // function : Graphic3d_TextureEnv
: Graphic3d_TextureRoot(SM, GetEnvir().ToCString() , NameOfTexture_to_FileName[NOT], Graphic3d_TOT_2D_MIPMAP), // purpose :
myName(NOT) // =======================================================================
Graphic3d_TextureEnv::Graphic3d_TextureEnv (const Graphic3d_NameOfTextureEnv theNOT)
: Graphic3d_TextureRoot (NameOfTexture_to_FileName[theNOT], Graphic3d_TOT_2D_MIPMAP),
myName (theNOT)
{ {
MyCInitTexture.doModulate = 0; myPath.SetTrek (Graphic3d_TextureRoot::TexturesFolder());
MyCInitTexture.doRepeat = 0; myTexId = TCollection_AsciiString ("Graphic3d_TextureEnv_")
MyCInitTexture.Mode = (int)Graphic3d_TOTM_SPHERE; + NameOfTexture_to_FileName[theNOT];
MyCInitTexture.doLinear = 1;
MyCInitTexture.sx = 1.0F; myParams->SetFilter (Graphic3d_TOTF_TRILINEAR);
MyCInitTexture.sy = 1.0F; myParams->SetGenMode (Graphic3d_TOTM_SPHERE,
MyCInitTexture.tx = 0.0F; Graphic3d_Vec4 (1.0f, 0.0f, 0.0f, 0.0f),
MyCInitTexture.ty = 0.0F; Graphic3d_Vec4 (0.0f, 1.0f, 0.0f, 0.0f));
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 1.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 1.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
} }
Graphic3d_NameOfTextureEnv Graphic3d_TextureEnv::Name() const { // =======================================================================
// function : Name
// purpose :
// =======================================================================
Graphic3d_NameOfTextureEnv Graphic3d_TextureEnv::Name() const
{
return myName; return myName;
} }
Standard_Integer Graphic3d_TextureEnv::NumberOfTextures() { // =======================================================================
// function : NumberOfTextures
// purpose :
// =======================================================================
Standard_Integer Graphic3d_TextureEnv::NumberOfTextures()
{
return sizeof(NameOfTexture_to_FileName)/sizeof(char*); return sizeof(NameOfTexture_to_FileName)/sizeof(char*);
} }
Standard_CString Graphic3d_TextureEnv::TextureName(const Standard_Integer aRank) { // =======================================================================
// function : TextureName
// purpose :
// =======================================================================
TCollection_AsciiString Graphic3d_TextureEnv::TextureName (const Standard_Integer theRank)
{
if(theRank < 1 || theRank > NumberOfTextures())
{
Standard_OutOfRange::Raise ("BAD index of texture");
}
if( aRank < 1 || aRank > NumberOfTextures() ) TCollection_AsciiString aFileName (NameOfTexture_to_FileName[theRank - 1]);
Standard_OutOfRange::Raise(" BAD index of texture"); Standard_Integer i = aFileName.SearchFromEnd(".");
TCollection_AsciiString filename(NameOfTexture_to_FileName[aRank-1]); return aFileName.SubString (5, i - 1);
Standard_Integer i = filename.SearchFromEnd(".");
static TCollection_AsciiString name;
name = filename.SubString(5,i-1);
return name.ToCString();
} }

View File

@ -18,71 +18,81 @@
-- purpose or non-infringement. Please see the License for the specific terms -- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License. -- and conditions governing the rights and limitations under the License.
deferred class TextureMap from Graphic3d
deferred class TextureMap from Graphic3d inherits TextureRoot from Graphic3d
inherits TextureRoot from Graphic3d ---Purpose: This is an abstract class for managing texture applyable on polygons.
---Purpose: This is an abstract class for managing texture applyable on polygons.
uses uses
TypeOfTexture from Graphic3d,
StructureManager from Graphic3d
TypeOfTexture from Graphic3d,
TextureParams from Graphic3d,
LevelOfTextureAnisotropy from Graphic3d,
AsciiString from TCollection
is is
Initialize(SM : StructureManager from Graphic3d;
Path : CString from Standard;
FileName : CString from Standard;
Type : TypeOfTexture from Graphic3d);
EnableSmooth(me : mutable);
---Level: public
---Purpose:
-- enable texture smoothing
IsSmoothed(me) returns Boolean from Standard; Initialize (theFileName : AsciiString from TCollection;
---Level: public theType : TypeOfTexture from Graphic3d);
---Purpose:
-- Returns TRUE if the texture is smoothed.
DisableSmooth(me : mutable);
---Level: public
---Purpose:
-- disable texture smoothing
EnableModulate(me : mutable); EnableSmooth (me : mutable);
---Level: public ---Level: public
---Purpose: ---Purpose:
-- enable texture modulate mode. -- enable texture smoothing
-- the image is modulate with the shading of the surface.
DisableModulate(me : mutable); IsSmoothed (me) returns Boolean from Standard;
---Level: public ---Level: public
---Purpose: ---Purpose:
-- disable texture modulate mode. -- Returns TRUE if the texture is smoothed.
-- the image is directly decal on the surface.
IsModulate(me) returns Boolean from Standard; DisableSmooth (me : mutable);
---Level: public ---Level: public
---Purpose: ---Purpose:
-- Returns TRUE if the texture is modulate. -- disable texture smoothing
EnableRepeat(me : mutable); EnableModulate (me : mutable);
---Level: public ---Level: public
---Purpose: ---Purpose:
-- use this methods if you want to enable -- enable texture modulate mode.
-- texture repetition on your objects. -- the image is modulate with the shading of the surface.
DisableRepeat(me : mutable); DisableModulate (me : mutable);
---Level: public ---Level: public
---Purpose: ---Purpose:
-- use this methods if you want to disable -- disable texture modulate mode.
-- texture repetition on your objects. -- the image is directly decal on the surface.
IsRepeat(me) returns Boolean from Standard; IsModulate (me) returns Boolean from Standard;
---Level: public ---Level: public
---Purpose: ---Purpose:
-- Returns TRUE if the texture repeat is enable. -- Returns TRUE if the texture is modulate.
end TextureMap from Graphic3d; EnableRepeat (me : mutable);
---Level: public
---Purpose:
-- use this methods if you want to enable
-- texture repetition on your objects.
DisableRepeat (me : mutable);
---Level: public
---Purpose:
-- use this methods if you want to disable
-- texture repetition on your objects.
IsRepeat (me) returns Boolean from Standard;
---Level: public
---Purpose:
-- Returns TRUE if the texture repeat is enable.
AnisoFilter (me) returns LevelOfTextureAnisotropy from Graphic3d;
---Level : public
---Purpose : @return level of anisontropy texture filter.
-- Default value is Graphic3d_LOTA_OFF.
SetAnisoFilter (me : mutable;
theLevel : LevelOfTextureAnisotropy from Graphic3d);
---Level : public
---Purpose : @param theLevel level of anisontropy texture filter.
end TextureMap from Graphic3d;

View File

@ -18,56 +18,114 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
// Modified : GG 09/11/00 smooth,modulate,repeat texture attributes
// must be available both for textures 1D & 2D.
#include <Graphic3d_TextureMap.ixx> #include <Graphic3d_TextureMap.ixx>
#include <Graphic3d_TextureParams.hxx>
Graphic3d_TextureMap::Graphic3d_TextureMap(const Handle(Graphic3d_StructureManager)& SM,const Standard_CString Path,const Standard_CString FileName,const Graphic3d_TypeOfTexture Type) // =======================================================================
: Graphic3d_TextureRoot(SM, Path, FileName, Type) // function : Graphic3d_TextureMap
// purpose :
// =======================================================================
Graphic3d_TextureMap::Graphic3d_TextureMap (const TCollection_AsciiString& theFileName,
const Graphic3d_TypeOfTexture theType)
: Graphic3d_TextureRoot (theFileName, theType)
{ {
} }
void Graphic3d_TextureMap::EnableSmooth() { // =======================================================================
MyCInitTexture.doLinear = 1; // function : EnableSmooth
Update(); // purpose :
// =======================================================================
void Graphic3d_TextureMap::EnableSmooth()
{
myParams->SetFilter (Graphic3d_TOTF_TRILINEAR);
} }
void Graphic3d_TextureMap::DisableSmooth() { // =======================================================================
MyCInitTexture.doLinear = 0; // function : DisableSmooth
Update(); // purpose :
// =======================================================================
void Graphic3d_TextureMap::DisableSmooth()
{
myParams->SetFilter (Graphic3d_TOTF_NEAREST);
} }
Standard_Boolean Graphic3d_TextureMap::IsSmoothed() const { // =======================================================================
return (MyCInitTexture.doLinear != 0); // function : IsSmoothed
// purpose :
// =======================================================================
Standard_Boolean Graphic3d_TextureMap::IsSmoothed() const
{
return myParams->Filter() != Graphic3d_TOTF_NEAREST;
} }
void Graphic3d_TextureMap::EnableModulate() { // =======================================================================
MyCInitTexture.doModulate = 1; // function : EnableModulate
Update(); // purpose :
// =======================================================================
void Graphic3d_TextureMap::EnableModulate()
{
myParams->SetModulate (Standard_True);
} }
void Graphic3d_TextureMap::DisableModulate() { // =======================================================================
MyCInitTexture.doModulate = 0; // function : DisableModulate
Update(); // purpose :
// =======================================================================
void Graphic3d_TextureMap::DisableModulate()
{
myParams->SetModulate (Standard_False);
} }
Standard_Boolean Graphic3d_TextureMap::IsModulate() const { // =======================================================================
return (MyCInitTexture.doModulate != 0); // function : IsModulate
// purpose :
// =======================================================================
Standard_Boolean Graphic3d_TextureMap::IsModulate() const
{
return myParams->IsModulate();
} }
void Graphic3d_TextureMap::EnableRepeat() { // =======================================================================
MyCInitTexture.doRepeat = 1; // function : EnableRepeat
Update(); // purpose :
// =======================================================================
void Graphic3d_TextureMap::EnableRepeat()
{
myParams->SetRepeat (Standard_True);
} }
void Graphic3d_TextureMap::DisableRepeat() { // =======================================================================
MyCInitTexture.doRepeat = 0; // function : DisableRepeat
Update(); // purpose :
// =======================================================================
void Graphic3d_TextureMap::DisableRepeat()
{
myParams->SetRepeat (Standard_False);
} }
Standard_Boolean Graphic3d_TextureMap::IsRepeat() const { // =======================================================================
return (MyCInitTexture.doRepeat != 0); // function : IsRepeat
// purpose :
// =======================================================================
Standard_Boolean Graphic3d_TextureMap::IsRepeat() const
{
return myParams->IsRepeat();
} }
// =======================================================================
// function : AnisoFilter
// purpose :
// =======================================================================
Graphic3d_LevelOfTextureAnisotropy Graphic3d_TextureMap::AnisoFilter() const
{
return myParams->AnisoFilter();
}
// =======================================================================
// function : SetAnisoFilter
// purpose :
// =======================================================================
void Graphic3d_TextureMap::SetAnisoFilter (const Graphic3d_LevelOfTextureAnisotropy theLevel)
{
myParams->SetAnisoFilter (theLevel);
}

View File

@ -0,0 +1,171 @@
-- Copyright (c) 2012 OPEN CASCADE SAS
--
-- The content of this file is subject to the Open CASCADE Technology Public
-- License Version 6.5 (the "License"). You may not use the content of this file
-- except in compliance with the License. Please obtain a copy of the License
-- at http://www.opencascade.org and read it completely before using this file.
--
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
--
-- The Original Code and all software distributed under the License is
-- distributed on an "AS IS" basis, without warranty of any kind, and the
-- Initial Developer hereby disclaims all such warranties, including without
-- limitation, any warranties of merchantability, fitness for a particular
-- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License.
class TextureParams from Graphic3d
inherits Transient from Standard
---Purpose: This class describes texture parameters.
uses
Vec2 from Graphic3d,
Vec4 from Graphic3d,
TypeOfTextureMode from Graphic3d,
TypeOfTextureFilter from Graphic3d,
LevelOfTextureAnisotropy from Graphic3d
is
Create
returns TextureParams from Graphic3d;
---Purpose: Default constructor.
Destroy (me);
---C++ : alias ~
--
-- public methods
--
IsModulate (me) returns Boolean from Standard;
---Level : public
---Purpose : @return TRUE if the texture is modulate.
-- Default value is FALSE.
SetModulate (me : mutable;
theToModulate : Boolean from Standard);
---Level : public
---Purpose : @param theToModulate turn modulation on/off.
IsRepeat (me) returns Boolean from Standard;
---Level : public
---Purpose : @return TRUE if the texture repeat is enabled.
-- Default value is FALSE.
SetRepeat (me : mutable;
theToRepeat : Boolean from Standard);
---Level : public
---Purpose : @param theToRepeat turn texture repeat mode ON or OFF (clamping).
Filter (me) returns TypeOfTextureFilter from Graphic3d;
---Level : public
---Purpose : @return texture interpolation filter.
-- Default value is Graphic3d_TOTF_NEAREST.
SetFilter (me : mutable;
theFilter : TypeOfTextureFilter from Graphic3d);
---Level : public
---Purpose : @param theFilter texture interpolation filter.
AnisoFilter (me) returns LevelOfTextureAnisotropy from Graphic3d;
---Level : public
---Purpose : @return level of anisontropy texture filter.
-- Default value is Graphic3d_LOTA_OFF.
SetAnisoFilter (me : mutable;
theLevel : LevelOfTextureAnisotropy from Graphic3d);
---Level : public
---Purpose : @param theLevel level of anisontropy texture filter.
Rotation (me) returns ShortReal from Standard;
---Level : public
---Purpose : @return rotation angle in degrees
-- Default value is 0.
SetRotation (me : mutable;
theAngleDegrees : ShortReal from Standard);
---Level : public
---Purpose : @param theAngleDegrees rotation angle.
Scale (me) returns Vec2 from Graphic3d;
---Level : public
---Purpose : @return scale factor
-- Default value is no scaling (1.0; 1.0).
---C++ : return const &
SetScale (me : mutable;
theScale : Vec2 from Graphic3d);
---Level : public
---Purpose : @param theScale scale factor.
Translation (me) returns Vec2 from Graphic3d;
---Level : public
---Purpose : @return translation vector
-- Default value is no translation (0.0; 0.0).
---C++ : return const &
SetTranslation (me : mutable;
theVec : Vec2 from Graphic3d);
---Level : public
---Purpose : @param theVec translation vector.
GenMode (me) returns TypeOfTextureMode from Graphic3d;
---Level : public
---Purpose : @return texture coordinates generation mode.
-- Default value is Graphic3d_TOTM_MANUAL.
GenPlaneS (me) returns Vec4 from Graphic3d;
---Level : public
---Purpose : @return texture coordinates generation plane S.
---C++ : return const &
GenPlaneT (me) returns Vec4 from Graphic3d;
---Level : public
---Purpose : @return texture coordinates generation plane T.
---C++ : return const &
SetGenMode (me : mutable;
theMode : TypeOfTextureMode from Graphic3d;
thePlaneS : Vec4 from Graphic3d;
thePlaneT : Vec4 from Graphic3d);
---Level : public
---Purpose : Setup texture coordinates generation mode.
fields
-- apply lighting on texture or not
myToModulate : Boolean from Standard;
-- texture wrapping mode
myToRepeat : Boolean from Standard;
-- texture filter
myFilter : TypeOfTextureFilter from Graphic3d;
-- level of anisontropy texture filter
myAnisoLevel : LevelOfTextureAnisotropy from Graphic3d;
-- texture mapping - rotation angle in degrees around OZ axis
myRotAngle : ShortReal from Standard;
-- texture coordinate scale factor
myScale : Vec2 from Graphic3d;
-- texture coordinate translation vector
myTranslation: Vec2 from Graphic3d;
-- texture coordinates generation mode
myGenMode : TypeOfTextureMode from Graphic3d;
-- plane definition for s(x) coordinate (for Graphic3d_TOTM_EYE and Graphic3d_TOTM_OBJECT generation modes)
myGenPlaneS : Vec4 from Graphic3d;
-- plane definition for t(y) coordinate (for Graphic3d_TOTM_EYE and Graphic3d_TOTM_OBJECT generation modes)
myGenPlaneT : Vec4 from Graphic3d;
end TextureParams;

View File

@ -0,0 +1,212 @@
// Copyright (c) 2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
#include <Graphic3d_TextureParams.ixx>
// =======================================================================
// function : Graphic3d_TextureParams
// purpose :
// =======================================================================
Graphic3d_TextureParams::Graphic3d_TextureParams()
: myToModulate (Standard_False),
myToRepeat (Standard_False),
myFilter (Graphic3d_TOTF_NEAREST),
myAnisoLevel (Graphic3d_LOTA_OFF),
myRotAngle (0.0f),
myScale (1.0f, 1.0f),
myTranslation(0.0f, 0.0f),
myGenMode (Graphic3d_TOTM_MANUAL),
myGenPlaneS (0.0f, 0.0f, 0.0f, 0.0f),
myGenPlaneT (0.0f, 0.0f, 0.0f, 0.0f)
{
//
}
// =======================================================================
// function : Destroy
// purpose :
// =======================================================================
void Graphic3d_TextureParams::Destroy() const
{
//
}
// =======================================================================
// function : IsModulate
// purpose :
// =======================================================================
Standard_Boolean Graphic3d_TextureParams::IsModulate() const
{
return myToModulate;
}
// =======================================================================
// function : SetModulate
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetModulate (const Standard_Boolean theToModulate)
{
myToModulate = theToModulate;
}
// =======================================================================
// function : IsRepeat
// purpose :
// =======================================================================
Standard_Boolean Graphic3d_TextureParams::IsRepeat() const
{
return myToRepeat;
}
// =======================================================================
// function : SetRepeat
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetRepeat (const Standard_Boolean theToRepeat)
{
myToRepeat = theToRepeat;
}
// =======================================================================
// function : Filter
// purpose :
// =======================================================================
Graphic3d_TypeOfTextureFilter Graphic3d_TextureParams::Filter() const
{
return myFilter;
}
// =======================================================================
// function : SetFilter
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetFilter (const Graphic3d_TypeOfTextureFilter theFilter)
{
myFilter = theFilter;
}
// =======================================================================
// function : AnisoFilter
// purpose :
// =======================================================================
Graphic3d_LevelOfTextureAnisotropy Graphic3d_TextureParams::AnisoFilter() const
{
return myAnisoLevel;
}
// =======================================================================
// function : SetAnisoFilter
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetAnisoFilter (const Graphic3d_LevelOfTextureAnisotropy theLevel)
{
myAnisoLevel = theLevel;
}
// =======================================================================
// function : Rotation
// purpose :
// =======================================================================
Standard_ShortReal Graphic3d_TextureParams::Rotation() const
{
return myRotAngle;
}
// =======================================================================
// function : SetRotation
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetRotation (const Standard_ShortReal theAngleDegrees)
{
myRotAngle = theAngleDegrees;
}
// =======================================================================
// function : Scale
// purpose :
// =======================================================================
const Graphic3d_Vec2& Graphic3d_TextureParams::Scale() const
{
return myScale;
}
// =======================================================================
// function : SetScale
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetScale (const Graphic3d_Vec2 theScale)
{
myScale = theScale;
}
// =======================================================================
// function : Translation
// purpose :
// =======================================================================
const Graphic3d_Vec2& Graphic3d_TextureParams::Translation() const
{
return myTranslation;
}
// =======================================================================
// function : SetTranslation
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetTranslation (const Graphic3d_Vec2 theVec)
{
myTranslation = theVec;
}
// =======================================================================
// function : GenMode
// purpose :
// =======================================================================
Graphic3d_TypeOfTextureMode Graphic3d_TextureParams::GenMode() const
{
return myGenMode;
}
// =======================================================================
// function : GenPlaneS
// purpose :
// =======================================================================
const Graphic3d_Vec4& Graphic3d_TextureParams::GenPlaneS() const
{
return myGenPlaneS;
}
// =======================================================================
// function : GenPlaneT
// purpose :
// =======================================================================
const Graphic3d_Vec4& Graphic3d_TextureParams::GenPlaneT() const
{
return myGenPlaneT;
}
// =======================================================================
// function : SetGenMode
// purpose :
// =======================================================================
void Graphic3d_TextureParams::SetGenMode (const Graphic3d_TypeOfTextureMode theMode,
const Graphic3d_Vec4 thePlaneS,
const Graphic3d_Vec4 thePlaneT)
{
myGenMode = theMode;
myGenPlaneS = thePlaneS;
myGenPlaneT = thePlaneT;
}

View File

@ -22,87 +22,93 @@ deferred class TextureRoot from Graphic3d
inherits TShared from MMgt inherits TShared from MMgt
---Purpose: This is the texture root class enable the dialog with the GraphicDriver ---Purpose: This is the texture root class enable the dialog with the GraphicDriver allows the loading of texture.
-- allows the loading of texture.
uses uses
CInitTexture from Graphic3d, TextureParams from Graphic3d,
GraphicDriver from Graphic3d, TypeOfTexture from Graphic3d,
StructureManager from Graphic3d, PixMap from Image,
TypeOfTexture from Graphic3d, PixMap_Handle from Image,
PixMap from Image, Path from OSD,
Path from OSD, AsciiString from TCollection
HArray1OfReal from TColStd
is is
Initialize (theSM : StructureManager from Graphic3d; Initialize (theFileName : AsciiString from TCollection;
thePath : CString from Standard; theType : TypeOfTexture from Graphic3d);
theFileName : CString from Standard; ---Purpose: Creates a texture from a file
theType : TypeOfTexture from Graphic3d); -- Warning: Note that if <FileName> is NULL the texture must be realized
---Purpose: Creates a texture from a file -- using LoadTexture(image) method.
-- Warning: Note that if <FileName> is NULL the texture must be realized
-- using LoadTexture(image) method.
Destroy (me); Destroy (me);
---C++ : alias ~ ---C++ : alias ~
-- --
-- public methods -- public methods
-- --
IsDone (me) returns Boolean from Standard; IsDone (me) returns Boolean from Standard
---Level: public is virtual;
---Purpose: Checks if a texture class is valid or not ---Level: public
-- returns true if the construction of the class is correct ---Purpose: Checks if a texture class is valid or not.
-- @return true if the construction of the class is correct
IsValid (me) returns Boolean from Standard; Path (me) returns Path from OSD;
---Level: public ---Level: public
---Purpose: Checks if a texture class is valid or not ---Purpose:
-- returns true if the construction of the class is correct -- Returns the full path of the defined texture.
-- It could be empty path if GetImage() is overridden to load image not from file.
---C++: return const &
Path (me) returns Path from OSD; Type (me) returns TypeOfTexture from Graphic3d;
---Level: public ---Level: public
---Purpose: ---Purpose: @return the texture type.
-- Returns the full path of the defined texture.
---C++: return const &
Type (me) returns TypeOfTexture from Graphic3d; GetId (me) returns AsciiString from TCollection;
---Level: public ---Level: advanced
---Purpose: ---Purpose:
-- Returns the texture type. -- This ID will be used to manage resource in graphic driver.
-- .
-- Default implementation generates unique ID although inheritors may re-initialize it.
-- .
-- Multiple Graphic3d_TextureRoot instancies with same ID
-- will be treated as single texture with different parameters
-- to optimize memory usage though this will be more natural
-- to use same instance of Graphic3d_TextureRoot when possible.
-- .
-- Notice that inheritor may set this ID to empty string.
-- In this case independent graphical resource will be created
-- for each instance of Graphic3d_AspectFillArea3d where texture will be used.
-- .
-- @return texture identifier.
LoadTexture (me : mutable; theImage : PixMap from Image) returns Boolean from Standard; GetImage (me) returns PixMap_Handle from Image
---Level: advanced is virtual;
---Purpose: ---Level : Public
-- Updates the current texture from a requested image. ---Purpose :
-- This method will be called by graphic driver each time when texture resource should be created.
-- Default implementation will dynamically load image from specified path within this method
-- (and no copy will be preserved in this class instance).
-- Inheritors may dynamically generate the image or return cached instance.
-- @return the image for texture.
TextureId (me) returns Integer from Standard; GetParams (me) returns TextureParams from Graphic3d;
---Level: advanced ---Level: public
---Purpose: ---Purpose: @return low-level texture parameters
-- returns the Texture ID which references the ---C++: return const &
-- texture to use for drawing. Used by the graphic driver.
GetTexUpperBounds(me) returns HArray1OfReal from TColStd; TexturesFolder (myclass) returns AsciiString from TCollection;
---Level: advanced ---Level : Public
---Purpose: ---Purpose :
---Gets upper bounds of texture coordinates. This is used when sizes -- The path to textures determined from CSF_MDTVTexturesDirectory or CASROOT environment variables.
---of texture are not equal to the powers of two -- @return the root folder with default textures.
--
-- private methods
--
Update (me) is protected;
fields fields
myGraphicDriver : GraphicDriver from Graphic3d; myParams : TextureParams from Graphic3d is protected;
myTexId : Integer from Standard; myTexId : AsciiString from TCollection is protected;
MyCInitTexture : CInitTexture from Graphic3d is protected; myPath : Path from OSD is protected;
myPath : Path from OSD; myType : TypeOfTexture from Graphic3d;
myType : TypeOfTexture from Graphic3d;
myTexUpperBounds : HArray1OfReal from TColStd;
end TextureRoot; end TextureRoot;

View File

@ -24,44 +24,76 @@
#include <Image_AlienPixMap.hxx> #include <Image_AlienPixMap.hxx>
#include <OSD_Directory.hxx>
#include <OSD_Environment.hxx>
#include <OSD_Path.hxx>
#include <OSD_Protection.hxx> #include <OSD_Protection.hxx>
#include <OSD_File.hxx> #include <OSD_File.hxx>
#include <stdio.h> #include <Standard_Atomic.hxx>
namespace
{
static volatile Standard_Integer THE_TEXTURE_COUNTER = 0;
};
// =======================================================================
// function : TexturesFolder
// purpose :
// =======================================================================
TCollection_AsciiString Graphic3d_TextureRoot::TexturesFolder()
{
static Standard_Boolean IsDefined = Standard_False;
static TCollection_AsciiString VarName;
if (!IsDefined)
{
IsDefined = Standard_True;
OSD_Environment aTexDirEnv ("CSF_MDTVTexturesDirectory");
VarName = aTexDirEnv.Value();
if (VarName.IsEmpty())
{
OSD_Environment aCasRootEnv ("CASROOT");
VarName = aCasRootEnv.Value();
if (!VarName.IsEmpty())
{
VarName += "/src/Textures";
}
}
if (VarName.IsEmpty())
{
std::cerr << " CSF_MDTVTexturesDirectory and CASROOT not setted\n";
std::cerr << " one of these variable are mandatory to use this functionality\n";
Standard_Failure::Raise ("CSF_MDTVTexturesDirectory and CASROOT not setted");
return VarName;
}
const OSD_Path aDirPath (VarName);
OSD_Directory aDir (aDirPath);
const TCollection_AsciiString aTexture = VarName + "/2d_MatraDatavision.rgb";
OSD_File aTextureFile (aTexture);
if (!aDir.Exists() || !aTextureFile.Exists())
{
std::cerr << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted\n";
std::cerr << " not all files are found in : "<< VarName.ToCString() << std::endl;
Standard_Failure::Raise ("CSF_MDTVTexturesDirectory or CASROOT not correctly setted");
return VarName;
}
}
return VarName;
}
// ======================================================================= // =======================================================================
// function : Graphic3d_TextureRoot // function : Graphic3d_TextureRoot
// purpose : // purpose :
// ======================================================================= // =======================================================================
Graphic3d_TextureRoot::Graphic3d_TextureRoot (const Handle(Graphic3d_StructureManager)& theSM, Graphic3d_TextureRoot::Graphic3d_TextureRoot (const TCollection_AsciiString& theFileName,
const Standard_CString thePath, const Graphic3d_TypeOfTexture theType)
const Standard_CString theFileName, : myParams (new Graphic3d_TextureParams()),
const Graphic3d_TypeOfTexture theType) myPath (theFileName),
: myGraphicDriver (Handle(Graphic3d_GraphicDriver)::DownCast (theSM->GraphicDevice()->GraphicDriver())), myType (theType)
myTexId (-1),
myPath (theFileName),
myType (theType),
myTexUpperBounds (new TColStd_HArray1OfReal (1, 2)) // currently always allocating an array for two texture bounds...
{ {
if (thePath != NULL && (strlen (thePath) > 0)) myTexId = TCollection_AsciiString ("Graphic3d_TextureRoot_") //DynamicType()->Name()
{ + TCollection_AsciiString (Standard_Atomic_Increment (&THE_TEXTURE_COUNTER));
myPath.SetTrek (TCollection_AsciiString (thePath));
}
if (theFileName == NULL || (strlen (theFileName) <= 0))
{
return;
}
TCollection_AsciiString aFilePath;
myPath.SystemName (aFilePath);
Image_AlienPixMap anImage;
if (!anImage.Load (aFilePath))
{
return;
}
myTexId = myGraphicDriver->CreateTexture (myType, anImage, theFileName, myTexUpperBounds);
Update();
} }
// ======================================================================= // =======================================================================
@ -70,40 +102,47 @@ Graphic3d_TextureRoot::Graphic3d_TextureRoot (const Handle(Graphic3d_StructureMa
// ======================================================================= // =======================================================================
void Graphic3d_TextureRoot::Destroy() const void Graphic3d_TextureRoot::Destroy() const
{ {
if (IsValid()) //
{
myGraphicDriver->DestroyTexture (myTexId);
}
} }
// ======================================================================= // =======================================================================
// function : TextureId // function : GetId
// purpose : // purpose :
// ======================================================================= // =======================================================================
Standard_Integer Graphic3d_TextureRoot::TextureId() const TCollection_AsciiString Graphic3d_TextureRoot::GetId() const
{ {
return myTexId; return myTexId;
} }
// ======================================================================= // =======================================================================
// function : Update // function : GetParams
// purpose : // purpose :
// ======================================================================= // =======================================================================
void Graphic3d_TextureRoot::Update() const const Handle(Graphic3d_TextureParams)& Graphic3d_TextureRoot::GetParams() const
{ {
if (IsValid()) return myParams;
{
myGraphicDriver->ModifyTexture (myTexId, MyCInitTexture);
}
} }
// ======================================================================= // =======================================================================
// function : IsValid // function : GetImage
// purpose : // purpose :
// ======================================================================= // =======================================================================
Standard_Boolean Graphic3d_TextureRoot::IsValid() const Handle(Image_PixMap) Graphic3d_TextureRoot::GetImage() const
{ {
return myTexId >= 0; TCollection_AsciiString aFilePath;
myPath.SystemName (aFilePath);
if (aFilePath.IsEmpty())
{
return Handle(Image_PixMap)();
}
Handle(Image_AlienPixMap) anImage = new Image_AlienPixMap();
if (!anImage->Load (aFilePath))
{
return Handle(Image_PixMap)();
}
return anImage;
} }
// ======================================================================= // =======================================================================
@ -112,23 +151,8 @@ Standard_Boolean Graphic3d_TextureRoot::IsValid() const
// ======================================================================= // =======================================================================
Standard_Boolean Graphic3d_TextureRoot::IsDone() const Standard_Boolean Graphic3d_TextureRoot::IsDone() const
{ {
return myTexId >= 0; OSD_File aTextureFile (myPath);
} return aTextureFile.Exists();
// =======================================================================
// function : LoadTexture
// purpose :
// =======================================================================
Standard_Boolean Graphic3d_TextureRoot::LoadTexture (const Image_PixMap& theImage)
{
if (myTexId >= 0)
{
myGraphicDriver->DestroyTexture (myTexId);
}
myTexId = myGraphicDriver->CreateTexture (myType, theImage, "", myTexUpperBounds);
Update();
return IsValid();
} }
// ======================================================================= // =======================================================================
@ -148,12 +172,3 @@ Graphic3d_TypeOfTexture Graphic3d_TextureRoot::Type() const
{ {
return myType; return myType;
} }
// =======================================================================
// function : GetTexUpperBounds
// purpose :
// =======================================================================
Handle(TColStd_HArray1OfReal) Graphic3d_TextureRoot::GetTexUpperBounds() const
{
return myTexUpperBounds;
}

View File

@ -1,4 +1,4 @@
// Copyright (c) 1999-2012 OPEN CASCADE SAS // Copyright (c) 2012 OPEN CASCADE SAS
// //
// The content of this file is subject to the Open CASCADE Technology Public // The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file // License Version 6.5 (the "License"). You may not use the content of this file
@ -15,13 +15,12 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _Graphic3d_Vec2_HeaderFile
#define _Graphic3d_Vec2_HeaderFile
#include <NCollection_Vec2.hxx>
#include <Standard_TypeDef.hxx>
#include <Graphic3d_CInitTexture.hxx> typedef NCollection_Vec2<Standard_ShortReal> Graphic3d_Vec2;
const Handle(Standard_Type)& TYPE(Graphic3d_CInitTexture) #endif // _Graphic3d_Vec2_HeaderFile
{
static Handle(Standard_Type) _atype =
new Standard_Type ("Graphic3d_CInitTexture", sizeof (Graphic3d_CInitTexture));
return _atype;
}

View File

@ -0,0 +1,26 @@
// Copyright (c) 2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
#ifndef _Graphic3d_Vec3_HeaderFile
#define _Graphic3d_Vec3_HeaderFile
#include <NCollection_Vec3.hxx>
#include <Standard_TypeDef.hxx>
typedef NCollection_Vec3<Standard_ShortReal> Graphic3d_Vec3;
#endif // _Graphic3d_Vec3_HeaderFile

View File

@ -0,0 +1,26 @@
// Copyright (c) 2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
#ifndef _Graphic3d_Vec4_HeaderFile
#define _Graphic3d_Vec4_HeaderFile
#include <NCollection_Vec4.hxx>
#include <Standard_TypeDef.hxx>
typedef NCollection_Vec4<Standard_ShortReal> Graphic3d_Vec4;
#endif // _Graphic3d_Vec4_HeaderFile

View File

@ -8,6 +8,7 @@ Image.edl
Image_CMPLRS.edl Image_CMPLRS.edl
Image_PixMap.hxx Image_PixMap.hxx
Image_PixMap.cxx Image_PixMap.cxx
Image_PixMap_Handle.hxx
Image_PixMapData.hxx Image_PixMapData.hxx
Image_Color.hxx Image_Color.hxx
Image_AlienPixMap.hxx Image_AlienPixMap.hxx

View File

@ -21,6 +21,7 @@
#define _Image_PixMap_H__ #define _Image_PixMap_H__
#include <Image_PixMapData.hxx> #include <Image_PixMapData.hxx>
#include <Image_PixMap_Handle.hxx>
#include <Standard_Transient.hxx> #include <Standard_Transient.hxx>
#include <Quantity_Color.hxx> #include <Quantity_Color.hxx>
@ -289,6 +290,4 @@ public:
}; };
DEFINE_STANDARD_HANDLE(Image_PixMap, Standard_Transient)
#endif // _Image_PixMap_H__ #endif // _Image_PixMap_H__

View File

@ -0,0 +1,28 @@
// Copyright (c) 2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
#ifndef _Image_PixMap_Handle_H__
#define _Image_PixMap_Handle_H__
#include <Standard_DefineHandle.hxx>
#include <Handle_Standard_Transient.hxx>
class Image_PixMap;
DEFINE_STANDARD_HANDLE(Image_PixMap, Standard_Transient)
typedef Handle(Image_PixMap) Image_PixMap_Handle;
#endif // _Image_PixMap_Handle_H__

View File

@ -16,31 +16,14 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
/*
* modified 27/08/97 ; PCT : ajout texture mapping
* modified 08/04/98 ; FGU : ajout parametres d emission (CALL_DEF_MATERIAL)
* modified 30/11/98 ; FMN : ajout parametres pour les textes visibles
* modified 24/01/00 ; EUG : G003 add DegenerationMode flag and SkipRatio value in
* CALL_DEF_STRUCTURE.
* modified 22/03/04 ; SAN : OCC4895 High-level interface for controlling polygon offsets
*
*/
#ifndef InterfaceGraphic_Graphic3dHeader #ifndef InterfaceGraphic_Graphic3dHeader
#define InterfaceGraphic_Graphic3dHeader #define InterfaceGraphic_Graphic3dHeader
#include <InterfaceGraphic_PrimitiveArray.hxx> #include <InterfaceGraphic_PrimitiveArray.hxx>
#include <Standard_Transient.hxx>
#define G003 /*EUG 26-01-00 Degeneration management
*/
#define OCC1174 /*SAV 08/01/03 CONTEXTFILLAREA extended with back face interior color*/
#define OCC2934 /* SAN 22/01/04 Texture mapped fonts on WNT */
#ifdef THIS #ifdef THIS
#undef THIS #undef THIS
#endif #endif
#define CALL_DEF_STRUCTHIGHLIGHTED 1 #define CALL_DEF_STRUCTHIGHLIGHTED 1
@ -259,7 +242,7 @@ typedef struct {
int HAlign; int HAlign;
int VAlign; int VAlign;
bool Zoomable; bool Zoomable;
} CALL_DEF_TEXT; } CALL_DEF_TEXT;
@ -378,90 +361,16 @@ typedef struct {
float Shininess; float Shininess;
float EnvReflexion; float EnvReflexion;
int IsPhysic; int IsPhysic;
/* Attribut couleur eclairage */ /* Attribut couleur eclairage */
CALL_DEF_COLOR ColorAmb, ColorDif, ColorSpec, ColorEms, Color; CALL_DEF_COLOR ColorAmb, ColorDif, ColorSpec, ColorEms, Color;
} CALL_DEF_MATERIAL; } CALL_DEF_MATERIAL;
/* TEXTURE */
typedef struct
{
int doModulate;
int doRepeat;
int Mode;
int doLinear;
float sx, sy;
float tx, ty;
float angle;
float sparams[4];
float tparams[4];
} CALL_DEF_INIT_TEXTURE;
typedef struct
{
int TexId;
int doTextureMap;
} CALL_DEF_TEXTURE;
/* CONTEXTE POLYGONE */
typedef struct {
int IsDef;
int IsSet;
int Style;
CALL_DEF_COLOR IntColor;
#ifdef OCC1174
CALL_DEF_COLOR BackIntColor;
#endif
CALL_DEF_COLOR EdgeColor;
int LineType;
float Width;
int Hatch;
int Distinguish;
int BackFace;
int Edge;
CALL_DEF_MATERIAL Front;
CALL_DEF_MATERIAL Back;
CALL_DEF_TEXTURE Texture;
#ifdef G003
int DegenerationMode;
float SkipRatio;
#endif
/* OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets */
int PolygonOffsetMode;
float PolygonOffsetFactor;
float PolygonOffsetUnits;
/* OCC4895 SAN 22/03/04 High-level interface for controlling polygon offsets */
} CALL_DEF_CONTEXTFILLAREA;
/* CONTEXTE MARKER */ /* CONTEXTE MARKER */
typedef struct { typedef struct {
@ -494,20 +403,20 @@ typedef struct {
float Expan; float Expan;
CALL_DEF_COLOR Color; CALL_DEF_COLOR Color;
int Style; int Style;
int DisplayType; int DisplayType;
CALL_DEF_COLOR ColorSubTitle; CALL_DEF_COLOR ColorSubTitle;
int TextZoomable; int TextZoomable;
float TextAngle; float TextAngle;
int TextFontAspect; int TextFontAspect;
} CALL_DEF_CONTEXTTEXT; } CALL_DEF_CONTEXTTEXT;
/* Transform persistence struct */ /* Transform persistence struct */
@ -519,72 +428,6 @@ typedef struct
CALL_DEF_POINT Point; CALL_DEF_POINT Point;
} CALL_DEF_TRANSFORM_PERSISTENCE; } CALL_DEF_TRANSFORM_PERSISTENCE;
/* STRUCTURE */
typedef struct {
int Id;
void *ptrStructure;
int Priority;
int PreviousPriority;
int GroupBegin;
int GroupEnd;
CALL_DEF_CONTEXTLINE ContextLine;
CALL_DEF_CONTEXTFILLAREA ContextFillArea;
CALL_DEF_CONTEXTMARKER ContextMarker;
CALL_DEF_CONTEXTTEXT ContextText;
CALL_DEF_BOUNDBOX BoundBox;
float Transformation[4][4];
int Composition;
int ContainsFacet;
unsigned IsDeleted :1;
unsigned IsOpen :1;
unsigned IsInfinite :1;
unsigned stick :1;
unsigned highlight :1;
unsigned visible :1;
unsigned pick :1;
unsigned HLRValidation :1;
/* ABD 29/10/04 Transform Persistence of Presentation( pan, zoom, rotate ) */
/*int TransformPersistenceFlag;
CALL_DEF_POINT TransformPersistencePoint;
*/
CALL_DEF_TRANSFORM_PERSISTENCE TransformPersistence;
/* ABD 29/10/04 Transform Persistence of Presentation( pan, zoom, rotate ) */
} CALL_DEF_STRUCTURE;
/* GROUPE */
typedef struct {
int LabelBegin;
int LabelEnd;
void *ptrGroup;
int StructureEnd;
CALL_DEF_CONTEXTLINE ContextLine;
CALL_DEF_CONTEXTFILLAREA ContextFillArea;
CALL_DEF_CONTEXTMARKER ContextMarker;
CALL_DEF_CONTEXTTEXT ContextText;
CALL_DEF_STRUCTURE *Struct;
CALL_DEF_PICKID PickId;
unsigned IsDeleted :1;
unsigned IsOpen :1;
/*int TransformPersistenceFlag;*/
} CALL_DEF_GROUP;
/* BOUNDING BOX */ /* BOUNDING BOX */
typedef struct { typedef struct {
@ -592,7 +435,7 @@ typedef struct {
float XMin; float XMin;
float YMin; float YMin;
float ZMin; float ZMin;
float XMax; float XMax;
float YMax; float YMax;
float ZMax; float ZMax;

View File

@ -16,40 +16,14 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef InterfaceGraphic_Visual3dHeader #ifndef InterfaceGraphic_Visual3dHeader
#define InterfaceGraphic_Visual3dHeader #define InterfaceGraphic_Visual3dHeader
/* CAL 02/08/94
* #include <InterfaceGraphic_X11.hxx>
* Retrait de InterfaceGraphic_X11.hxx et declaration de Window
* a la mode X11 dans les structures CALL_DEF_VIEW et CALL_DEF_PICK.
* En effet, un #define Opposite 4 se trouve dans X11/X.h
* et rentre en conflit avec la methode Opposite de math_Matrix.
*
* PCT 05/08/97
* ajout support texture mapping
*
* EUG 21/09/99 G003
* degenerated mode support
Add fields IsDegenerates,IsDegeneratesPrev,Backfacing
in CALL_DEF_VIEW structure.
* VKH 25/01/00 G004
* Dump a view
Add CALL_DEF_BITMAP reference in CALL_DEF_VIEW
*/
#ifndef RIC120302
#define RIC120302 /*GG Add NEW fields in CALL_DEF_VIEW structure
// to manage graphic context and call back
*/
#endif
#include <InterfaceGraphic_Aspect.hxx> #include <InterfaceGraphic_Aspect.hxx>
#ifdef RIC120302 #include <InterfaceGraphic_Graphic3d.hxx>
#include <Aspect_RenderingContext.hxx> #include <Aspect_RenderingContext.hxx>
#include <Aspect_GraphicCallbackProc.hxx> #include <Aspect_GraphicCallbackProc.hxx>
#endif #include <Standard_Transient.hxx>
typedef float CALL_DEF_MATRIX4X4[4][4]; typedef float CALL_DEF_MATRIX4X4[4][4];
@ -151,80 +125,6 @@ typedef struct {
} CALL_DEF_VIEWMAPPING; } CALL_DEF_VIEWMAPPING;
/* CONTEXT */
typedef struct {
int Aliasing;
int BackZClipping;
int FrontZClipping;
int DepthCueing;
float ZClipFrontPlane;
float ZClipBackPlane;
float DepthFrontPlane;
float DepthBackPlane;
int ZBufferActivity;
int Model;
int Visualization;
int NbActiveLight;
CALL_DEF_LIGHT *ActiveLight;
int NbActivePlane;
CALL_DEF_PLANE *ActivePlane;
int TexEnvId;
int SurfaceDetail;
} CALL_DEF_VIEWCONTEXT;
/* VUE */
typedef struct {
int WsId;
int ViewId;
void *ptrView;
int IsDeleted;
int IsOpen;
int Active;
CALL_DEF_VIEWORIENTATION Orientation;
CALL_DEF_VIEWMAPPING Mapping;
CALL_DEF_VIEWORIENTATION OrientationReset;
CALL_DEF_VIEWMAPPING MappingReset;
CALL_DEF_VIEWCONTEXT Context;
CALL_DEF_WINDOW DefWindow;
void *ptrUnderLayer;
void *ptrOverLayer;
int IsDegenerates;
int IsDegeneratesPrev;
int Backfacing;
#ifdef RIC120302
Aspect_RenderingContext GContext;
Aspect_GraphicCallbackProc GDisplayCB;
void* GClientData;
#endif
void *ptrFBO;
} CALL_DEF_VIEW;
/* REPERAGE */ /* REPERAGE */
typedef struct { typedef struct {

View File

@ -30,6 +30,7 @@
#include <Graphic3d_Vertex.hxx> #include <Graphic3d_Vertex.hxx>
#include <Graphic3d_Group.hxx> #include <Graphic3d_Group.hxx>
#include <Graphic3d_Array1OfVertex.hxx> #include <Graphic3d_Array1OfVertex.hxx>
#include <Graphic3d_TextureParams.hxx>
#include <Prs3d_ShadingAspect.hxx> #include <Prs3d_ShadingAspect.hxx>
#include <Prs3d_Root.hxx> #include <Prs3d_Root.hxx>
@ -69,48 +70,46 @@
*/ */
class MeshVS_ImageTexture2D : public Graphic3d_Texture2D class MeshVS_ImageTexture2D : public Graphic3d_Texture2D
{ {
public:
MeshVS_ImageTexture2D (Handle(Graphic3d_StructureManager) theSM,
const Image_PixMap& theImg);
virtual ~MeshVS_ImageTexture2D();
public: public:
MeshVS_ImageTexture2D (const Handle(Image_PixMap)& theImg)
: Graphic3d_Texture2D ("", Graphic3d_TOT_2D),
myImage (theImg)
{
myParams->SetModulate (Standard_True);
myParams->SetFilter (Graphic3d_TOTF_BILINEAR);
}
virtual ~MeshVS_ImageTexture2D()
{
//
}
virtual Standard_Boolean IsDone() const
{
return !myImage.IsNull() && !myImage->IsEmpty();
}
virtual Handle(Image_PixMap) GetImage() const
{
return myImage;
}
private:
Handle(Image_PixMap) myImage;
public:
DEFINE_STANDARD_RTTI(MeshVS_ImageTexture2D) DEFINE_STANDARD_RTTI(MeshVS_ImageTexture2D)
}; };
DEFINE_STANDARD_HANDLE (MeshVS_ImageTexture2D, Graphic3d_Texture2D) DEFINE_STANDARD_HANDLE (MeshVS_ImageTexture2D, Graphic3d_Texture2D)
IMPLEMENT_STANDARD_HANDLE (MeshVS_ImageTexture2D, Graphic3d_Texture2D) IMPLEMENT_STANDARD_HANDLE (MeshVS_ImageTexture2D, Graphic3d_Texture2D)
IMPLEMENT_STANDARD_RTTIEXT(MeshVS_ImageTexture2D, Graphic3d_Texture2D) IMPLEMENT_STANDARD_RTTIEXT(MeshVS_ImageTexture2D, Graphic3d_Texture2D)
MeshVS_ImageTexture2D::MeshVS_ImageTexture2D (Handle(Graphic3d_StructureManager) theSM,
const Image_PixMap& theImg)
: Graphic3d_Texture2D (theSM, "", Graphic3d_TOT_2D)
{
MyCInitTexture.doModulate = 1;
MyCInitTexture.doRepeat = 0;
MyCInitTexture.Mode = (int)Graphic3d_TOTM_MANUAL;
MyCInitTexture.doLinear = 1;
MyCInitTexture.sx = 1.0F;
MyCInitTexture.sy = 1.0F;
MyCInitTexture.tx = 0.0F;
MyCInitTexture.ty = 0.0F;
MyCInitTexture.angle = 0.0F;
MyCInitTexture.sparams[0] = 0.0F;
MyCInitTexture.sparams[1] = 0.0F;
MyCInitTexture.sparams[2] = 0.0F;
MyCInitTexture.sparams[3] = 0.0F;
MyCInitTexture.tparams[0] = 0.0F;
MyCInitTexture.tparams[1] = 0.0F;
MyCInitTexture.tparams[2] = 0.0F;
MyCInitTexture.tparams[3] = 0.0F;
Update();
LoadTexture(theImg);
}
MeshVS_ImageTexture2D::~MeshVS_ImageTexture2D()
{
}
//================================================================ //================================================================
// Function : getNearestPow2 // Function : getNearestPow2
// Purpose : Returns the nearest power of two greater than the // Purpose : Returns the nearest power of two greater than the
@ -723,21 +722,15 @@ Handle(Graphic3d_Texture2D) MeshVS_NodalColorPrsBuilder::CreateTexture() const
return NULL; return NULL;
} }
Handle(PrsMgr_PresentationManager3d) aPrsMgr = GetPresentationManager();
if (aPrsMgr.IsNull())
{
return NULL;
}
// create and fill image with colors // create and fill image with colors
Image_PixMap anImage; Handle(Image_PixMap) anImage = new Image_PixMap();
if (!anImage.InitTrash (Image_PixMap::ImgRGBA, Standard_Size(getNearestPow2 (aColorsNb)), 2)) if (!anImage->InitTrash (Image_PixMap::ImgRGBA, Standard_Size(getNearestPow2 (aColorsNb)), 2))
{ {
return NULL; return NULL;
} }
anImage.SetTopDown (false); anImage->SetTopDown (false);
Image_PixMapData<Image_ColorRGBA>& aData = anImage.EditData<Image_ColorRGBA>(); Image_PixMapData<Image_ColorRGBA>& aData = anImage->EditData<Image_ColorRGBA>();
for (Standard_Size aCol = 0; aCol < Standard_Size(aColorsNb); ++aCol) for (Standard_Size aCol = 0; aCol < Standard_Size(aColorsNb); ++aCol)
{ {
const Quantity_Color& aSrcColor = myTextureColorMap.Value (Standard_Integer(aCol) + 1); const Quantity_Color& aSrcColor = myTextureColorMap.Value (Standard_Integer(aCol) + 1);
@ -759,7 +752,7 @@ Handle(Graphic3d_Texture2D) MeshVS_NodalColorPrsBuilder::CreateTexture() const
}}; }};
// fill second row // fill second row
for (Standard_Size aCol = (Standard_Size )aColorsNb; aCol < anImage.SizeX(); ++aCol) for (Standard_Size aCol = (Standard_Size )aColorsNb; aCol < anImage->SizeX(); ++aCol)
{ {
aData.ChangeValue (0, aCol) = aLastColor; aData.ChangeValue (0, aCol) = aLastColor;
} }
@ -771,11 +764,11 @@ Handle(Graphic3d_Texture2D) MeshVS_NodalColorPrsBuilder::CreateTexture() const
int(255.0 * myInvalidColor.Blue()), int(255.0 * myInvalidColor.Blue()),
0xFF 0xFF
}}; }};
for (Standard_Size aCol = 0; aCol < anImage.SizeX(); ++aCol) for (Standard_Size aCol = 0; aCol < anImage->SizeX(); ++aCol)
{ {
aData.ChangeValue (1, aCol) = anInvalidColor; aData.ChangeValue (1, aCol) = anInvalidColor;
} }
// create texture // create texture
return new MeshVS_ImageTexture2D (aPrsMgr->StructureManager(), anImage); return new MeshVS_ImageTexture2D (anImage);
} }

View File

@ -19,11 +19,13 @@
#ifndef _NCollection_Vec2_H__ #ifndef _NCollection_Vec2_H__
#define _NCollection_Vec2_H__ #define _NCollection_Vec2_H__
#include <cmath> // std::sqrt()
//! Auxiliary macros to define couple of similar access components as vector methods. //! Auxiliary macros to define couple of similar access components as vector methods.
//! @return 2 components by their names in specified order //! @return 2 components by their names in specified order
#define NCOLLECTION_VEC_COMPONENTS_2D(theX, theY) \ #define NCOLLECTION_VEC_COMPONENTS_2D(theX, theY) \
const NCollection_Vec2<Element_t> theX##theY##() const { return NCollection_Vec2<Element_t>(theX##(), theY##()); } \ const NCollection_Vec2<Element_t> theX##theY() const { return NCollection_Vec2<Element_t>(theX(), theY()); } \
const NCollection_Vec2<Element_t> theY##theX##() const { return NCollection_Vec2<Element_t>(theY##(), theX##()); } const NCollection_Vec2<Element_t> theY##theX() const { return NCollection_Vec2<Element_t>(theY(), theX()); }
//! Defines the 2D-vector template. //! Defines the 2D-vector template.
//! The main target for this class - to handle raw low-level arrays (from/to graphic driver etc.). //! The main target for this class - to handle raw low-level arrays (from/to graphic driver etc.).

View File

@ -25,12 +25,12 @@
//! Auxiliary macros to define couple of similar access components as vector methods //! Auxiliary macros to define couple of similar access components as vector methods
#define NCOLLECTION_VEC_COMPONENTS_3D(theX, theY, theZ) \ #define NCOLLECTION_VEC_COMPONENTS_3D(theX, theY, theZ) \
const NCollection_Vec3<Element_t> theX##theY##theZ##() const { return NCollection_Vec3<Element_t>(theX##(), theY##(), theZ##()); } \ const NCollection_Vec3<Element_t> theX##theY##theZ() const { return NCollection_Vec3<Element_t>(theX(), theY(), theZ()); } \
const NCollection_Vec3<Element_t> theX##theZ##theY##() const { return NCollection_Vec3<Element_t>(theX##(), theZ##(), theY##()); } \ const NCollection_Vec3<Element_t> theX##theZ##theY() const { return NCollection_Vec3<Element_t>(theX(), theZ(), theY()); } \
const NCollection_Vec3<Element_t> theY##theX##theZ##() const { return NCollection_Vec3<Element_t>(theY##(), theX##(), theZ##()); } \ const NCollection_Vec3<Element_t> theY##theX##theZ() const { return NCollection_Vec3<Element_t>(theY(), theX(), theZ()); } \
const NCollection_Vec3<Element_t> theY##theZ##theX##() const { return NCollection_Vec3<Element_t>(theY##(), theZ##(), theX##()); } \ const NCollection_Vec3<Element_t> theY##theZ##theX() const { return NCollection_Vec3<Element_t>(theY(), theZ(), theX()); } \
const NCollection_Vec3<Element_t> theZ##theY##theX##() const { return NCollection_Vec3<Element_t>(theZ##(), theY##(), theX##()); } \ const NCollection_Vec3<Element_t> theZ##theY##theX() const { return NCollection_Vec3<Element_t>(theZ(), theY(), theX()); } \
const NCollection_Vec3<Element_t> theZ##theX##theY##() const { return NCollection_Vec3<Element_t>(theZ##(), theX##(), theY##()); } const NCollection_Vec3<Element_t> theZ##theX##theY() const { return NCollection_Vec3<Element_t>(theZ(), theX(), theY()); }
//! Generic 3-components vector. //! Generic 3-components vector.
//! To be used as RGB color pixel or XYZ 3D-point. //! To be used as RGB color pixel or XYZ 3D-point.

View File

@ -86,12 +86,11 @@ OpenGl_telem_view.cxx
OpenGl_telem_view.hxx OpenGl_telem_view.hxx
OpenGl_FrameBuffer.hxx OpenGl_FrameBuffer.hxx
OpenGl_FrameBuffer.cxx OpenGl_FrameBuffer.cxx
OpenGl_TextureBox.cxx OpenGl_Texture.cxx
OpenGl_TextureBox.hxx OpenGl_Texture.hxx
Handle_OpenGl_Texture.hxx
OpenGl_Resource.hxx OpenGl_Resource.hxx
OpenGl_Resource.cxx OpenGl_Resource.cxx
OpenGl_ResourceTexture.hxx
OpenGl_ResourceTexture.cxx
OpenGl_telem_util.hxx OpenGl_telem_util.hxx
OpenGl_telem_util.cxx OpenGl_telem_util.cxx
OpenGl_transform_persistence.hxx OpenGl_transform_persistence.hxx

View File

@ -1,6 +1,4 @@
// Created on: 2011-03-18 // Copyright (c) 2012 OPEN CASCADE SAS
// Created by: Anton POLETAEV
// Copyright (c) 2011-2012 OPEN CASCADE SAS
// //
// The content of this file is subject to the Open CASCADE Technology Public // The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file // License Version 6.5 (the "License"). You may not use the content of this file
@ -17,41 +15,12 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _Handle_OpenGl_Texture_Header
#ifndef _OPENGL_RESOURCETEXTURE_H #define _Handle_OpenGl_Texture_Header
#define _OPENGL_RESOURCETEXTURE_H
#include <OpenGl_Resource.hxx> #include <OpenGl_Resource.hxx>
#include <Standard.hxx>
class OpenGl_Resource; class OpenGl_Texture;
DEFINE_STANDARD_HANDLE(OpenGl_Texture, OpenGl_Resource)
//! OpenGl_ResourceTexture represents the texture resource #endif // _Handle_OpenGl_Texture_Header
//! for OpenGl_ResourceCleaner
class OpenGl_ResourceTexture : public OpenGl_Resource
{
public:
//! Constructor
Standard_EXPORT OpenGl_ResourceTexture (const GLuint theId);
//! Destructor
Standard_EXPORT virtual ~OpenGl_ResourceTexture();
//! Destroy object - will release GPU memory if any.
Standard_EXPORT virtual void Release (const OpenGl_Context* theGlCtx);
protected:
GLuint myTextureId; //!< Texture name (index)
public:
DEFINE_STANDARD_RTTI(OpenGl_ResourceTexture) // Type definition
};
DEFINE_STANDARD_HANDLE(OpenGl_ResourceTexture,OpenGl_Resource)
#endif

View File

@ -17,219 +17,275 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_AspectFace.hxx> #include <OpenGl_AspectFace.hxx>
#include <OpenGl_Texture.hxx>
#include <OpenGl_Workspace.hxx>
#include <OpenGl_Context.hxx>
#include <InterfaceGraphic_Graphic3d.hxx>
#include <Aspect_PolygonOffsetMode.hxx> #include <Aspect_PolygonOffsetMode.hxx>
#include <Graphic3d_CGroup.hxx>
#include <Graphic3d_TextureMap.hxx>
/*----------------------------------------------------------------------*/ namespace
static const TEL_CONTEXT_FACE myDefaultAspectFace =
{ {
Aspect_IS_SOLID,
TOn, TEL_HS_SOLID, TOn, TelCullNone, static OPENGL_SURF_PROP THE_DEFAULT_MATERIAL =
{ 0.2F, 0.8F, 0.1F, 0.0F, /* amb, diff, spec, emsv */ {
1.0F, 10.0F, 0.0F, /* trans, shine, env_reflexion */ 0.2F, 0.8F, 0.1F, 0.0F, // amb, diff, spec, emsv
0, /* isphysic */ 1.0F, 10.0F, 0.0F, // trans, shine, env_reflexion
(OPENGL_AMBIENT_MASK | OPENGL_DIFFUSE_MASK | OPENGL_SPECULAR_MASK), /* color_mask */ 0, // isphysic
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* ambient color */ (OPENGL_AMBIENT_MASK | OPENGL_DIFFUSE_MASK | OPENGL_SPECULAR_MASK), // color_mask
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* diffuse color */ {{ 1.0F, 1.0F, 1.0F, 1.0F }}, // ambient color
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* specular color */ {{ 1.0F, 1.0F, 1.0F, 1.0F }}, // diffuse color
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* emissive color */ {{ 1.0F, 1.0F, 1.0F, 1.0F }}, // specular color
{{ 1.0F, 1.0F, 1.0F, 1.0F }} /* material color */ {{ 1.0F, 1.0F, 1.0F, 1.0F }}, // emissive color
}, {{ 1.0F, 1.0F, 1.0F, 1.0F }} // material color
{ 0.2F, 0.8F, 0.1F, 0.0F, /* amb, diff, spec, emsv */ };
1.0F, 10.0F, 0.0F, /* trans, shine, env_reflexion */
0, /* isphysic */ static TEL_POFFSET_PARAM THE_DEFAULT_POFFSET = { Aspect_POM_Fill, 1.0F, 0.0F };
(OPENGL_AMBIENT_MASK | OPENGL_DIFFUSE_MASK | OPENGL_SPECULAR_MASK), /* color_mask */
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* ambient color */
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* diffuse color */
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* specular color */
{{ 1.0F, 1.0F, 1.0F, 1.0F }}, /* emissive color */
{{ 1.0F, 1.0F, 1.0F, 1.0F }} /* material color */
},
0, -1, { Aspect_POM_Fill, 1.0F, 0.0F }
}; };
/*----------------------------------------------------------------------*/ // =======================================================================
// function : convertMaterial
static void ConvertMaterial (const CALL_DEF_MATERIAL &material, OPENGL_SURF_PROP &surface) // purpose :
// =======================================================================
void OpenGl_AspectFace::convertMaterial (const CALL_DEF_MATERIAL& theMat,
OPENGL_SURF_PROP& theSurf)
{ {
/* Cas par cas pour l evaluation */ theSurf.amb = theMat.IsAmbient ? theMat.Ambient : 0.0f;
surface.amb = material.IsAmbient? material.Ambient : 0.F; theSurf.diff = theMat.IsDiffuse ? theMat.Diffuse : 0.0f;
surface.diff = material.IsDiffuse? material.Diffuse : 0.F; theSurf.spec = theMat.IsSpecular ? theMat.Specular : 0.0f;
surface.spec = material.IsSpecular? material.Specular : 0.F; theSurf.emsv = theMat.IsEmission ? theMat.Emission : 0.0f;
surface.emsv = material.IsEmission? material.Emission : 0.F;
/* type de materiel */ theSurf.isphysic = theMat.IsPhysic ? 1 : 0; // type of material
surface.isphysic = material.IsPhysic? 1 : 0;
/* Couleur du materiel */ // color of material
surface.color_mask = 0; theSurf.color_mask = 0;
if ( material.IsAmbient ) if (theMat.IsAmbient)
surface.color_mask |= OPENGL_AMBIENT_MASK; {
if ( material.IsDiffuse ) theSurf.color_mask |= OPENGL_AMBIENT_MASK;
surface.color_mask |= OPENGL_DIFFUSE_MASK; }
if ( material.IsSpecular ) if (theMat.IsDiffuse)
surface.color_mask |= OPENGL_SPECULAR_MASK; {
if ( material.IsEmission ) theSurf.color_mask |= OPENGL_DIFFUSE_MASK;
surface.color_mask |= OPENGL_EMISSIVE_MASK; }
if (theMat.IsSpecular)
{
theSurf.color_mask |= OPENGL_SPECULAR_MASK;
}
if (theMat.IsEmission)
{
theSurf.color_mask |= OPENGL_EMISSIVE_MASK;
}
/* Couleur eclairage ambient */ // ambient color
surface.ambcol.rgb[0] = material.ColorAmb.r; theSurf.ambcol.rgb[0] = theMat.ColorAmb.r;
surface.ambcol.rgb[1] = material.ColorAmb.g; theSurf.ambcol.rgb[1] = theMat.ColorAmb.g;
surface.ambcol.rgb[2] = material.ColorAmb.b; theSurf.ambcol.rgb[2] = theMat.ColorAmb.b;
surface.ambcol.rgb[3] = 1.F; theSurf.ambcol.rgb[3] = 1.0f;
/* Couleur eclairage diffus */ // diffuse color
surface.difcol.rgb[0] = material.ColorDif.r; theSurf.difcol.rgb[0] = theMat.ColorDif.r;
surface.difcol.rgb[1] = material.ColorDif.g; theSurf.difcol.rgb[1] = theMat.ColorDif.g;
surface.difcol.rgb[2] = material.ColorDif.b; theSurf.difcol.rgb[2] = theMat.ColorDif.b;
surface.difcol.rgb[3] = 1.F; theSurf.difcol.rgb[3] = 1.0f;
/* Couleur eclairage speculaire */ // specular color
surface.speccol.rgb[0] = material.ColorSpec.r; theSurf.speccol.rgb[0] = theMat.ColorSpec.r;
surface.speccol.rgb[1] = material.ColorSpec.g; theSurf.speccol.rgb[1] = theMat.ColorSpec.g;
surface.speccol.rgb[2] = material.ColorSpec.b; theSurf.speccol.rgb[2] = theMat.ColorSpec.b;
surface.speccol.rgb[3] = 1.F; theSurf.speccol.rgb[3] = 1.0f;
/* Couleur d emission */ // emission color
surface.emscol.rgb[0] = material.ColorEms.r; theSurf.emscol.rgb[0] = theMat.ColorEms.r;
surface.emscol.rgb[1] = material.ColorEms.g; theSurf.emscol.rgb[1] = theMat.ColorEms.g;
surface.emscol.rgb[2] = material.ColorEms.b; theSurf.emscol.rgb[2] = theMat.ColorEms.b;
surface.emscol.rgb[3] = 1.F; theSurf.emscol.rgb[3] = 1.0f;
surface.shine = ( float )128 * material.Shininess; theSurf.shine = 128.0f * float(theMat.Shininess);
surface.env_reflexion = material.EnvReflexion; theSurf.env_reflexion = theMat.EnvReflexion;
/* Dans la couche C++ : // trans = 0. => opaque
* prop->trans = 0. => opaque // trans = 1. => transparent
* prop->trans = 1. => transparent // in OpenGl it is opposite.
* in OpenGl it is opposite. theSurf.trans = 1.0f - theMat.Transparency;
*/
surface.trans = 1.0F - material.Transparency;
} }
/*----------------------------------------------------------------------*/ // =======================================================================
// function : OpenGl_AspectFace
OpenGl_AspectFace::OpenGl_AspectFace () // purpose :
: myContext(myDefaultAspectFace) // =======================================================================
{} OpenGl_AspectFace::OpenGl_AspectFace()
: InteriorStyle (Aspect_IS_SOLID),
/*----------------------------------------------------------------------*/ Edge (Aspect_IS_SOLID),
Hatch (TOn),
void OpenGl_AspectFace::SetContext (const CALL_DEF_CONTEXTFILLAREA &AContext) DistinguishingMode (TEL_HS_SOLID),
CullingMode (TelCullNone),
doTextureMap (0)
{ {
//TelInteriorStyle IntFront = THE_DEFAULT_MATERIAL;
myContext.InteriorStyle = (Aspect_InteriorStyle) AContext.Style; IntBack = THE_DEFAULT_MATERIAL;
PolygonOffset = THE_DEFAULT_POFFSET;
}
//TelEdgeFlag // =======================================================================
myContext.Edge = AContext.Edge ? TOn : TOff; // function : Init
// purpose :
// =======================================================================
void OpenGl_AspectFace::Init (const Handle(OpenGl_Context)& theContext,
const CALL_DEF_CONTEXTFILLAREA& theAspect)
{
InteriorStyle = (Aspect_InteriorStyle )theAspect.Style;
Edge = theAspect.Edge ? TOn : TOff;
//TelInteriorStyleIndex //TelInteriorStyleIndex
switch( AContext.Hatch ) switch (theAspect.Hatch)
{ {
case 0 : /* Aspect_HS_HORIZONTAL */ case 0: /* Aspect_HS_HORIZONTAL */
myContext.Hatch = TEL_HS_HORIZONTAL; Hatch = TEL_HS_HORIZONTAL;
break; break;
case 1 : /* Aspect_HS_HORIZONTAL_WIDE */ case 1: /* Aspect_HS_HORIZONTAL_WIDE */
myContext.Hatch = TEL_HS_HORIZONTAL_SPARSE; Hatch = TEL_HS_HORIZONTAL_SPARSE;
break; break;
case 2 : /* Aspect_HS_VERTICAL */ case 2: /* Aspect_HS_VERTICAL */
myContext.Hatch = TEL_HS_VERTICAL; Hatch = TEL_HS_VERTICAL;
break; break;
case 3 : /* Aspect_HS_VERTICAL_WIDE */ case 3: /* Aspect_HS_VERTICAL_WIDE */
myContext.Hatch = TEL_HS_VERTICAL_SPARSE; Hatch = TEL_HS_VERTICAL_SPARSE;
break; break;
case 4 : /* Aspect_HS_DIAGONAL_45 */ case 4: /* Aspect_HS_DIAGONAL_45 */
myContext.Hatch = TEL_HS_DIAG_45; Hatch = TEL_HS_DIAG_45;
break; break;
case 5 : /* Aspect_HS_DIAGONAL_45_WIDE */ case 5: /* Aspect_HS_DIAGONAL_45_WIDE */
myContext.Hatch = TEL_HS_DIAG_45_SPARSE; Hatch = TEL_HS_DIAG_45_SPARSE;
break; break;
case 6 : /* Aspect_HS_DIAGONAL_135 */ case 6: /* Aspect_HS_DIAGONAL_135 */
myContext.Hatch = TEL_HS_DIAG_135; Hatch = TEL_HS_DIAG_135;
break; break;
case 7 : /* Aspect_HS_DIAGONAL_135_WIDE */ case 7: /* Aspect_HS_DIAGONAL_135_WIDE */
myContext.Hatch = TEL_HS_DIAG_135_SPARSE; Hatch = TEL_HS_DIAG_135_SPARSE;
break; break;
case 8 : /* Aspect_HS_GRID */ case 8: /* Aspect_HS_GRID */
myContext.Hatch = TEL_HS_GRID; Hatch = TEL_HS_GRID;
break; break;
case 9 : /* Aspect_HS_GRID_WIDE */ case 9: /* Aspect_HS_GRID_WIDE */
myContext.Hatch = TEL_HS_GRID_SPARSE; Hatch = TEL_HS_GRID_SPARSE;
break; break;
case 10 : /* Aspect_HS_GRID_DIAGONAL */ case 10: /* Aspect_HS_GRID_DIAGONAL */
myContext.Hatch = TEL_HS_CROSS; Hatch = TEL_HS_CROSS;
break; break;
case 11 : /* Aspect_HS_GRID_DIAGONAL_WIDE */ case 11: /* Aspect_HS_GRID_DIAGONAL_WIDE */
myContext.Hatch = TEL_HS_CROSS_SPARSE; Hatch = TEL_HS_CROSS_SPARSE;
break; break;
default : default:
myContext.Hatch = 0; Hatch = 0;
break; break;
} }
//TelFaceDistinguishingMode DistinguishingMode = theAspect.Distinguish ? TOn : TOff;
myContext.DistinguishingMode = AContext.Distinguish ? TOn : TOff; CullingMode = theAspect.BackFace ? TelCullBack : TelCullNone;
//TelFaceCullingMode convertMaterial (theAspect.Front, IntFront);
myContext.CullingMode = AContext.BackFace ? TelCullBack : TelCullNone; convertMaterial (theAspect.Back, IntBack);
//TelSurfaceAreaProperties
ConvertMaterial(AContext.Front,myContext.IntFront);
//TelBackSurfaceAreaProperties
ConvertMaterial(AContext.Back,myContext.IntBack);
//TelInteriorColour //TelInteriorColour
myContext.IntFront.matcol.rgb[0] = (float) AContext.IntColor.r; IntFront.matcol.rgb[0] = (float )theAspect.IntColor.r;
myContext.IntFront.matcol.rgb[1] = (float) AContext.IntColor.g; IntFront.matcol.rgb[1] = (float )theAspect.IntColor.g;
myContext.IntFront.matcol.rgb[2] = (float) AContext.IntColor.b; IntFront.matcol.rgb[2] = (float )theAspect.IntColor.b;
myContext.IntFront.matcol.rgb[3] = 1.f; IntFront.matcol.rgb[3] = 1.0f;
//TelBackInteriorColour //TelBackInteriorColour
myContext.IntBack.matcol.rgb[0] = (float) AContext.BackIntColor.r; IntBack.matcol.rgb[0] = (float )theAspect.BackIntColor.r;
myContext.IntBack.matcol.rgb[1] = (float) AContext.BackIntColor.g; IntBack.matcol.rgb[1] = (float )theAspect.BackIntColor.g;
myContext.IntBack.matcol.rgb[2] = (float) AContext.BackIntColor.b; IntBack.matcol.rgb[2] = (float )theAspect.BackIntColor.b;
myContext.IntBack.matcol.rgb[3] = 1.f; IntBack.matcol.rgb[3] = 1.0f;
//TelDoTextureMap // setup texture
myContext.doTextureMap = AContext.Texture.doTextureMap; doTextureMap = theAspect.Texture.doTextureMap;
const Handle(Graphic3d_TextureMap)& aNewTexture = theAspect.Texture.TextureMap;
TCollection_AsciiString aNewKey = aNewTexture.IsNull() ? TCollection_AsciiString() : aNewTexture->GetId();
TextureParams = aNewTexture.IsNull() ? NULL : aNewTexture->GetParams();
if (aNewKey.IsEmpty()
|| myTextureId != aNewKey)
{
if (!TextureRes.IsNull())
{
if (myTextureId.IsEmpty())
{
theContext->DelayedRelease (TextureRes);
TextureRes.Nullify();
}
else
{
TextureRes.Nullify(); // we need nullify all handles before ReleaseResource() call
theContext->ReleaseResource (myTextureId);
}
}
myTextureId = aNewKey;
//TelTextureId if (!aNewTexture.IsNull())
myContext.TexId = AContext.Texture.TexId; {
if (aNewKey.IsEmpty() || !theContext->GetResource<Handle(OpenGl_Texture)> (aNewKey, TextureRes))
{
TextureRes = new OpenGl_Texture (TextureParams);
Handle(Image_PixMap) anImage = aNewTexture->GetImage();
if (!anImage.IsNull())
{
TextureRes->Init (theContext, *anImage.operator->(), aNewTexture->Type());
}
if (!aNewKey.IsEmpty())
{
theContext->ShareResource (aNewKey, TextureRes);
}
}
}
}
//TelPolygonOffset //TelPolygonOffset
myContext.PolygonOffset.mode = (Aspect_PolygonOffsetMode) AContext.PolygonOffsetMode; PolygonOffset.mode = (Aspect_PolygonOffsetMode )theAspect.PolygonOffsetMode;
myContext.PolygonOffset.factor = AContext.PolygonOffsetFactor; PolygonOffset.factor = theAspect.PolygonOffsetFactor;
myContext.PolygonOffset.units = AContext.PolygonOffsetUnits; PolygonOffset.units = theAspect.PolygonOffsetUnits;
CALL_DEF_CONTEXTLINE anEdgeContext; CALL_DEF_CONTEXTLINE anEdgeContext;
anEdgeContext.Color.r = (float )theAspect.EdgeColor.r;
//TelEdgeColour anEdgeContext.Color.g = (float )theAspect.EdgeColor.g;
anEdgeContext.Color.r = (float) AContext.EdgeColor.r; anEdgeContext.Color.b = (float )theAspect.EdgeColor.b;
anEdgeContext.Color.g = (float) AContext.EdgeColor.g; anEdgeContext.LineType = (Aspect_TypeOfLine )theAspect.LineType;
anEdgeContext.Color.b = (float) AContext.EdgeColor.b; anEdgeContext.Width = (float )theAspect.Width;
myAspectEdge.SetContext (anEdgeContext);
//TelEdgeType
anEdgeContext.LineType = (Aspect_TypeOfLine) AContext.LineType;
//TelEdgeWidth
anEdgeContext.Width = (float) AContext.Width;
myAspectEdge.SetContext(anEdgeContext);
} }
/*----------------------------------------------------------------------*/ // =======================================================================
// function : Render
// purpose :
// =======================================================================
void OpenGl_AspectFace::Render (const Handle(OpenGl_Workspace)& theWorkspace) const void OpenGl_AspectFace::Render (const Handle(OpenGl_Workspace)& theWorkspace) const
{ {
theWorkspace->SetAspectFace (this); theWorkspace->SetAspectFace (this);
} }
// =======================================================================
// function : Release
// purpose :
// =======================================================================
void OpenGl_AspectFace::Release (const Handle(OpenGl_Context)& theContext) void OpenGl_AspectFace::Release (const Handle(OpenGl_Context)& theContext)
{ {
// if (!TextureRes.IsNull())
{
if (!theContext.IsNull())
{
if (myTextureId.IsEmpty())
{
theContext->DelayedRelease (TextureRes);
}
else
{
TextureRes.Nullify(); // we need nullify all handles before ReleaseResource() call
theContext->ReleaseResource (myTextureId);
}
}
TextureRes.Nullify();
}
myTextureId.Clear();
} }

View File

@ -17,20 +17,25 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_AspectFace_Header #ifndef _OpenGl_AspectFace_Header
#define _OpenGl_AspectFace_Header #define _OpenGl_AspectFace_Header
#include <InterfaceGraphic_telem.hxx> #include <InterfaceGraphic_telem.hxx>
#include <Aspect_InteriorStyle.hxx> #include <Aspect_InteriorStyle.hxx>
#include <TCollection_AsciiString.hxx>
#include <Handle_Graphic3d_TextureParams.hxx>
#include <OpenGl_AspectLine.hxx> #include <OpenGl_AspectLine.hxx>
#include <OpenGl_Element.hxx>
#include <Handle_OpenGl_Texture.hxx>
#define OPENGL_AMBIENT_MASK (1<<0) #define OPENGL_AMBIENT_MASK (1<<0)
#define OPENGL_DIFFUSE_MASK (1<<1) #define OPENGL_DIFFUSE_MASK (1<<1)
#define OPENGL_SPECULAR_MASK (1<<2) #define OPENGL_SPECULAR_MASK (1<<2)
#define OPENGL_EMISSIVE_MASK (1<<3) #define OPENGL_EMISSIVE_MASK (1<<3)
class CALL_DEF_CONTEXTFILLAREA;
struct OPENGL_SURF_PROP struct OPENGL_SURF_PROP
{ {
float amb, diff, spec, emsv; float amb, diff, spec, emsv;
@ -42,47 +47,52 @@ struct OPENGL_SURF_PROP
DEFINE_STANDARD_ALLOC DEFINE_STANDARD_ALLOC
}; };
struct TEL_CONTEXT_FACE
{
Aspect_InteriorStyle InteriorStyle;
int Edge;
int Hatch;
int DistinguishingMode;
int CullingMode;
OPENGL_SURF_PROP IntFront;
OPENGL_SURF_PROP IntBack;
int doTextureMap;
int TexId;
TEL_POFFSET_PARAM PolygonOffset;
DEFINE_STANDARD_ALLOC
};
#include <OpenGl_Element.hxx>
class OpenGl_AspectFace : public OpenGl_Element class OpenGl_AspectFace : public OpenGl_Element
{ {
public:
OpenGl_AspectFace (); public:
void SetContext (const CALL_DEF_CONTEXTFILLAREA &AContext); OpenGl_AspectFace();
void SetContext (const TEL_CONTEXT_FACE &AContext) { myContext = AContext; } void Init (const Handle(OpenGl_Context)& theContext,
void SetAspectEdge (const OpenGl_AspectLine * AnAspectEdge) { myAspectEdge = *AnAspectEdge; } const CALL_DEF_CONTEXTFILLAREA& theAspect);
const TEL_CONTEXT_FACE & Context() const { return myContext; } void SetAspectEdge (const OpenGl_AspectLine* theAspectEdge) { myAspectEdge = *theAspectEdge; }
const OpenGl_AspectLine * AspectEdge() const { return &myAspectEdge; }
const OpenGl_AspectLine* AspectEdge() const { return &myAspectEdge; }
virtual void Render (const Handle(OpenGl_Workspace)& theWorkspace) const; virtual void Render (const Handle(OpenGl_Workspace)& theWorkspace) const;
virtual void Release (const Handle(OpenGl_Context)& theContext); virtual void Release (const Handle(OpenGl_Context)& theContext);
protected: private:
TEL_CONTEXT_FACE myContext; void convertMaterial (const CALL_DEF_MATERIAL& theMat,
OpenGl_AspectLine myAspectEdge; OPENGL_SURF_PROP& theSurf);
public:
Aspect_InteriorStyle InteriorStyle;
int Edge;
int Hatch;
int DistinguishingMode;
int CullingMode;
OPENGL_SURF_PROP IntFront;
OPENGL_SURF_PROP IntBack;
TEL_POFFSET_PARAM PolygonOffset;
int doTextureMap;
Handle(OpenGl_Texture) TextureRes;
Handle(Graphic3d_TextureParams) TextureParams;
protected:
TCollection_AsciiString myTextureId;
OpenGl_AspectLine myAspectEdge;
public:
public:
DEFINE_STANDARD_ALLOC DEFINE_STANDARD_ALLOC
}; };
#endif //_OpenGl_AspectFace_Header #endif //_OpenGl_AspectFace_Header

View File

@ -17,8 +17,8 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_AspectLine.hxx> #include <OpenGl_AspectLine.hxx>
#include <OpenGl_Workspace.hxx>
static const TEL_COLOUR myDefaultColor = {{ 1.0F, 1.0F, 1.0F, 1.0F }}; static const TEL_COLOUR myDefaultColor = {{ 1.0F, 1.0F, 1.0F, 1.0F }};

View File

@ -17,11 +17,10 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_AspectLine_Header #ifndef _OpenGl_AspectLine_Header
#define _OpenGl_AspectLine_Header #define _OpenGl_AspectLine_Header
#include <InterfaceGraphic_telem.hxx> #include <InterfaceGraphic_Graphic3d.hxx>
#include <Aspect_TypeOfLine.hxx> #include <Aspect_TypeOfLine.hxx>
#include <OpenGl_Element.hxx> #include <OpenGl_Element.hxx>

View File

@ -17,8 +17,8 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_AspectMarker.hxx> #include <OpenGl_AspectMarker.hxx>
#include <OpenGl_Workspace.hxx>
static const TEL_COLOUR myDefaultColor = {{ 1.0F, 1.0F, 1.0F, 1.0F }}; static const TEL_COLOUR myDefaultColor = {{ 1.0F, 1.0F, 1.0F, 1.0F }};

View File

@ -17,11 +17,10 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef OpenGl_AspectMarker_Header #ifndef OpenGl_AspectMarker_Header
#define OpenGl_AspectMarker_Header #define OpenGl_AspectMarker_Header
#include <InterfaceGraphic_telem.hxx> #include <InterfaceGraphic_Graphic3d.hxx>
#include <Aspect_TypeOfMarker.hxx> #include <Aspect_TypeOfMarker.hxx>
#include <OpenGl_Element.hxx> #include <OpenGl_Element.hxx>

View File

@ -17,8 +17,8 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_AspectText.hxx> #include <OpenGl_AspectText.hxx>
#include <OpenGl_Workspace.hxx>
static const TEL_COLOUR myDefaultColor = {{ 1.0F, 1.0F, 1.0F, 1.0F }}; static const TEL_COLOUR myDefaultColor = {{ 1.0F, 1.0F, 1.0F, 1.0F }};

View File

@ -17,11 +17,10 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef OpenGl_AspectText_Header #ifndef OpenGl_AspectText_Header
#define OpenGl_AspectText_Header #define OpenGl_AspectText_Header
#include <InterfaceGraphic_telem.hxx> #include <InterfaceGraphic_Graphic3d.hxx>
#include <Font_FontAspect.hxx> #include <Font_FontAspect.hxx>
#include <Aspect_TypeOfStyleText.hxx> #include <Aspect_TypeOfStyleText.hxx>
#include <Aspect_TypeOfDisplayText.hxx> #include <Aspect_TypeOfDisplayText.hxx>

View File

@ -74,17 +74,22 @@ OpenGl_Context::OpenGl_Context()
core14 (NULL), core14 (NULL),
core15 (NULL), core15 (NULL),
core20 (NULL), core20 (NULL),
arbNPTW(Standard_False),
arbVBO (NULL), arbVBO (NULL),
arbTBO (NULL), arbTBO (NULL),
arbIns (NULL), arbIns (NULL),
extFBO (NULL), extFBO (NULL),
extGS (NULL), extGS (NULL),
extBgra(Standard_False),
extAnis(Standard_False),
atiMem (Standard_False), atiMem (Standard_False),
nvxMem (Standard_False), nvxMem (Standard_False),
mySharedResources (new OpenGl_ResourcesMap()), mySharedResources (new OpenGl_ResourcesMap()),
myReleaseQueue (new OpenGl_ResourcesQueue()), myReleaseQueue (new OpenGl_ResourcesQueue()),
myGlLibHandle (NULL), myGlLibHandle (NULL),
myGlCore20 (NULL), myGlCore20 (NULL),
myMaxTexDim (1024),
myAnisoMax (1),
myGlVerMajor (0), myGlVerMajor (0),
myGlVerMinor (0), myGlVerMinor (0),
myIsFeedback (Standard_False), myIsFeedback (Standard_False),
@ -130,6 +135,24 @@ OpenGl_Context::~OpenGl_Context()
delete extGS; delete extGS;
} }
// =======================================================================
// function : MaxDegreeOfAnisotropy
// purpose :
// =======================================================================
Standard_Integer OpenGl_Context::MaxDegreeOfAnisotropy() const
{
return myAnisoMax;
}
// =======================================================================
// function : MaxTextureSize
// purpose :
// =======================================================================
Standard_Integer OpenGl_Context::MaxTextureSize() const
{
return myMaxTexDim;
}
// ======================================================================= // =======================================================================
// function : Share // function : Share
// purpose : // purpose :
@ -474,8 +497,17 @@ void OpenGl_Context::init()
// read version // read version
readGlVersion(); readGlVersion();
atiMem = CheckExtension ("GL_ATI_meminfo"); arbNPTW = CheckExtension ("GL_ARB_texture_non_power_of_two");
nvxMem = CheckExtension ("GL_NVX_gpu_memory_info"); extBgra = CheckExtension ("GL_EXT_bgra");
extAnis = CheckExtension ("GL_EXT_texture_filter_anisotropic");
atiMem = CheckExtension ("GL_ATI_meminfo");
nvxMem = CheckExtension ("GL_NVX_gpu_memory_info");
glGetIntegerv (GL_MAX_TEXTURE_SIZE, &myMaxTexDim);
if (extAnis)
{
glGetIntegerv (GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT, &myAnisoMax);
}
// initialize VBO extension (ARB) // initialize VBO extension (ARB)
if (CheckExtension ("GL_ARB_vertex_buffer_object")) if (CheckExtension ("GL_ARB_vertex_buffer_object"))

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_Context_H__ #ifndef _OpenGl_Context_H__
#define _OpenGl_Context_H__ #define _OpenGl_Context_H__
@ -210,6 +209,12 @@ public:
//! Clean up the delayed release queue. //! Clean up the delayed release queue.
Standard_EXPORT void ReleaseDelayed(); Standard_EXPORT void ReleaseDelayed();
//! @return maximum degree of anisotropy texture filter
Standard_EXPORT Standard_Integer MaxDegreeOfAnisotropy() const;
//! @return value for GL_MAX_TEXTURE_SIZE
Standard_EXPORT Standard_Integer MaxTextureSize() const;
private: private:
//! Wrapper to system function to retrieve GL function pointer by name. //! Wrapper to system function to retrieve GL function pointer by name.
@ -231,13 +236,16 @@ public: // core profiles
public: // extensions public: // extensions
OpenGl_ArbVBO* arbVBO; //!< GL_ARB_vertex_buffer_object Standard_Boolean arbNPTW; //!< GL_ARB_texture_non_power_of_two
OpenGl_ArbTBO* arbTBO; //!< GL_ARB_texture_buffer_object OpenGl_ArbVBO* arbVBO; //!< GL_ARB_vertex_buffer_object
OpenGl_ArbIns* arbIns; //!< GL_ARB_draw_instanced OpenGl_ArbTBO* arbTBO; //!< GL_ARB_texture_buffer_object
OpenGl_ExtFBO* extFBO; //!< GL_EXT_framebuffer_object OpenGl_ArbIns* arbIns; //!< GL_ARB_draw_instanced
OpenGl_ExtGS* extGS; //!< GL_EXT_geometry_shader4 OpenGl_ExtFBO* extFBO; //!< GL_EXT_framebuffer_object
Standard_Boolean atiMem; //!< GL_ATI_meminfo OpenGl_ExtGS* extGS; //!< GL_EXT_geometry_shader4
Standard_Boolean nvxMem; //!< GL_NVX_gpu_memory_info Standard_Boolean extBgra; //!< GL_EXT_bgra
Standard_Boolean extAnis; //!< GL_EXT_texture_filter_anisotropic
Standard_Boolean atiMem; //!< GL_ATI_meminfo
Standard_Boolean nvxMem; //!< GL_NVX_gpu_memory_info
private: // system-dependent fields private: // system-dependent fields
@ -263,6 +271,8 @@ private: // context info
void* myGlLibHandle; //!< optional handle to GL library void* myGlLibHandle; //!< optional handle to GL library
OpenGl_GlCore20* myGlCore20; //!< common structure for GL core functions upto 2.0 OpenGl_GlCore20* myGlCore20; //!< common structure for GL core functions upto 2.0
Standard_Integer myAnisoMax; //!< maximum level of anisotropy texture filter
Standard_Integer myMaxTexDim; //!< value for GL_MAX_TEXTURE_SIZE
Standard_Integer myGlVerMajor; //!< cached GL version major number Standard_Integer myGlVerMajor; //!< cached GL version major number
Standard_Integer myGlVerMinor; //!< cached GL version minor number Standard_Integer myGlVerMinor; //!< cached GL version minor number
Standard_Boolean myIsFeedback; //!< flag indicates GL_FEEDBACK mode Standard_Boolean myIsFeedback; //!< flag indicates GL_FEEDBACK mode

View File

@ -21,7 +21,8 @@
#ifndef OpenGl_Element_Header #ifndef OpenGl_Element_Header
#define OpenGl_Element_Header #define OpenGl_Element_Header
#include <OpenGl_Workspace.hxx> #include <Handle_OpenGl_Context.hxx>
#include <Handle_OpenGl_Workspace.hxx>
class OpenGl_Element class OpenGl_Element
{ {

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_GraphicDriver_HeaderFile #ifndef _OpenGl_GraphicDriver_HeaderFile
#define _OpenGl_GraphicDriver_HeaderFile #define _OpenGl_GraphicDriver_HeaderFile
@ -32,6 +31,7 @@
#include <Quantity_PlaneAngle.hxx> #include <Quantity_PlaneAngle.hxx>
#include <Quantity_NameOfColor.hxx> #include <Quantity_NameOfColor.hxx>
#include <Handle_AlienImage_AlienImage.hxx> #include <Handle_AlienImage_AlienImage.hxx>
#include <Handle_OpenGl_View.hxx>
#include <Aspect_Display.hxx> #include <Aspect_Display.hxx>
#include <Aspect_GradientFillMethod.hxx> #include <Aspect_GradientFillMethod.hxx>
@ -55,8 +55,6 @@
#include <Graphic3d_CUserDraw.hxx> #include <Graphic3d_CUserDraw.hxx>
#include <Graphic3d_CGraduatedTrihedron.hxx> #include <Graphic3d_CGraduatedTrihedron.hxx>
#include <Graphic3d_TypeOfComposition.hxx> #include <Graphic3d_TypeOfComposition.hxx>
#include <Graphic3d_TypeOfTexture.hxx>
#include <Graphic3d_CInitTexture.hxx>
#include <Graphic3d_ExportFormat.hxx> #include <Graphic3d_ExportFormat.hxx>
#include <Graphic3d_SortType.hxx> #include <Graphic3d_SortType.hxx>
#include <Graphic3d_PtrFrameBuffer.hxx> #include <Graphic3d_PtrFrameBuffer.hxx>
@ -84,7 +82,6 @@ class TCollection_ExtendedString;
class AlienImage_AlienImage; class AlienImage_AlienImage;
class Image_PixMap; class Image_PixMap;
class TColStd_HArray1OfReal; class TColStd_HArray1OfReal;
class Handle(OpenGl_View);
class Handle(OpenGl_Workspace); class Handle(OpenGl_Workspace);
class OpenGl_Element; class OpenGl_Element;
class OpenGl_Structure; class OpenGl_Structure;
@ -92,7 +89,7 @@ class OpenGl_Structure;
//! This class defines an OpenGl graphic driver <br> //! This class defines an OpenGl graphic driver <br>
class OpenGl_GraphicDriver : public Graphic3d_GraphicDriver class OpenGl_GraphicDriver : public Graphic3d_GraphicDriver
{ {
public: public:
//! Constructor //! Constructor
Standard_EXPORT OpenGl_GraphicDriver (const Standard_CString theShrName); Standard_EXPORT OpenGl_GraphicDriver (const Standard_CString theShrName);
@ -272,12 +269,6 @@ public:
//! This method is internal and should be used by Graphic3d_Group only. <br> //! This method is internal and should be used by Graphic3d_Group only. <br>
Standard_EXPORT void RemovePrimitiveArray(const Graphic3d_CGroup& theCGroup,const Graphic3d_PrimitiveArray& thePArray); Standard_EXPORT void RemovePrimitiveArray(const Graphic3d_CGroup& theCGroup,const Graphic3d_PrimitiveArray& thePArray);
Standard_EXPORT Standard_Integer InquirePlaneLimit(); Standard_EXPORT Standard_Integer InquirePlaneLimit();
Standard_EXPORT Standard_Integer CreateTexture (const Graphic3d_TypeOfTexture theType,
const Image_PixMap& theImage,
const Standard_CString theFileName,
const Handle(TColStd_HArray1OfReal)& theTexUpperBounds) const;
Standard_EXPORT void DestroyTexture(const Standard_Integer TexId) const;
Standard_EXPORT void ModifyTexture(const Standard_Integer TexId,const Graphic3d_CInitTexture& AValue) const;
Standard_EXPORT Standard_ShortReal DefaultTextHeight() const; Standard_EXPORT Standard_ShortReal DefaultTextHeight() const;
Standard_EXPORT void FBOGetDimensions(const Graphic3d_CView& view,const Graphic3d_PtrFrameBuffer fboPtr,Standard_Integer& width,Standard_Integer& height,Standard_Integer& widthMax,Standard_Integer& heightMax); Standard_EXPORT void FBOGetDimensions(const Graphic3d_CView& view,const Graphic3d_PtrFrameBuffer fboPtr,Standard_Integer& width,Standard_Integer& height,Standard_Integer& widthMax,Standard_Integer& heightMax);
Standard_EXPORT void FBOChangeViewport(const Graphic3d_CView& view,Graphic3d_PtrFrameBuffer& fboPtr,const Standard_Integer width,const Standard_Integer height); Standard_EXPORT void FBOChangeViewport(const Graphic3d_CView& view,Graphic3d_PtrFrameBuffer& fboPtr,const Standard_Integer width,const Standard_Integer height);

View File

@ -45,7 +45,7 @@ void OpenGl_GraphicDriver::FaceContextGroup (const Graphic3d_CGroup& theCGroup,
if (!theCGroup.ContextFillArea.IsDef || theCGroup.ptrGroup == NULL) if (!theCGroup.ContextFillArea.IsDef || theCGroup.ptrGroup == NULL)
return; return;
((OpenGl_Group* )theCGroup.ptrGroup)->SetAspectFace (theCGroup.ContextFillArea, theNoInsert); ((OpenGl_Group* )theCGroup.ptrGroup)->SetAspectFace (GetSharedContext(), theCGroup.ContextFillArea, theNoInsert);
InvalidateAllWorkspaces(); InvalidateAllWorkspaces();
} }
@ -77,7 +77,7 @@ void OpenGl_GraphicDriver::MarkerContextGroup (const Graphic3d_CGroup& theCGroup
InvalidateAllWorkspaces(); InvalidateAllWorkspaces();
} }
void OpenGl_GraphicDriver::MarkerContextGroup (const Graphic3d_CGroup& theCGroup, void OpenGl_GraphicDriver::MarkerContextGroup (const Graphic3d_CGroup& theCGroup,
const Standard_Integer theNoInsert, const Standard_Integer theNoInsert,
const Standard_Integer theMarkWidth, const Standard_Integer theMarkWidth,
const Standard_Integer theMarkHeight, const Standard_Integer theMarkHeight,

View File

@ -46,7 +46,7 @@ void OpenGl_GraphicDriver::ContextStructure (const Graphic3d_CStructure& theCStr
aStructure->SetAspectLine (theCStructure.ContextLine); aStructure->SetAspectLine (theCStructure.ContextLine);
if (theCStructure.ContextFillArea.IsDef) if (theCStructure.ContextFillArea.IsDef)
aStructure->SetAspectFace (theCStructure.ContextFillArea); aStructure->SetAspectFace (GetSharedContext(), theCStructure.ContextFillArea);
if (theCStructure.ContextMarker.IsDef) if (theCStructure.ContextMarker.IsDef)
aStructure->SetAspectMarker (theCStructure.ContextMarker); aStructure->SetAspectMarker (theCStructure.ContextMarker);

View File

@ -168,7 +168,7 @@ Standard_Boolean OpenGl_GraphicDriver::UnProjectRaster (const Graphic3d_CView& A
const Standard_Integer aHeight = aCView->WS->Height(); const Standard_Integer aHeight = aCView->WS->Height();
/* /*
Patched by P.Dolbey: the window pixel height decreased by one Patched by P.Dolbey: the window pixel height decreased by one
in order for yr to remain within valid coordinate range [0; Ym -1] in order for yr to remain within valid coordinate range [0; Ym -1]
where Ym means window pixel height. where Ym means window pixel height.
*/ */
@ -430,7 +430,8 @@ void OpenGl_GraphicDriver::RemoveView (const Graphic3d_CView& theCView)
} }
} }
OpenGl_CView *aCView = (OpenGl_CView *)theCView.ptrView; OpenGl_CView* aCView = (OpenGl_CView* )theCView.ptrView;
aCView->View->ReleaseGlResources (aShareCtx);
delete aCView; delete aCView;
((Graphic3d_CView *)&theCView)->ptrView = NULL; ((Graphic3d_CView *)&theCView)->ptrView = NULL;
} }
@ -554,7 +555,7 @@ void OpenGl_GraphicDriver::SetBackFacingModel (const Graphic3d_CView& ACView)
//======================================================================= //=======================================================================
//function : AddZLayer //function : AddZLayer
//purpose : //purpose :
//======================================================================= //=======================================================================
void OpenGl_GraphicDriver::AddZLayer (const Graphic3d_CView& theCView, void OpenGl_GraphicDriver::AddZLayer (const Graphic3d_CView& theCView,

View File

@ -21,21 +21,18 @@
#include <OpenGl_CView.hxx> #include <OpenGl_CView.hxx>
#include <OpenGl_Trihedron.hxx> #include <OpenGl_Trihedron.hxx>
#include <OpenGl_GraduatedTrihedron.hxx> #include <OpenGl_GraduatedTrihedron.hxx>
#include <OpenGl_TextureBox.hxx>
#include <OpenGl_tgl_funcs.hxx> #include <OpenGl_tgl_funcs.hxx>
#include <Quantity_NameOfColor.hxx> void OpenGl_GraphicDriver::Environment(const Graphic3d_CView& theCView)
#include <TColStd_HArray1OfReal.hxx>
#include <Image_Image.hxx>
void OpenGl_GraphicDriver::Environment(const Graphic3d_CView& ACView)
{ {
const OpenGl_CView *aCView = (const OpenGl_CView *)ACView.ptrView; const OpenGl_CView* aCView = (const OpenGl_CView* )theCView.ptrView;
if (aCView) if (aCView == NULL)
{ {
aCView->View->SetTextureEnv(ACView.Context.TexEnvId); return;
aCView->View->SetSurfaceDetail((Visual3d_TypeOfSurfaceDetail)ACView.Context.SurfaceDetail);
} }
aCView->View->SetTextureEnv (GetSharedContext(), theCView.Context.TextureEnv);
aCView->View->SetSurfaceDetail ((Visual3d_TypeOfSurfaceDetail)theCView.Context.SurfaceDetail);
} }
// //
@ -138,138 +135,3 @@ void OpenGl_GraphicDriver::GraduatedTrihedronMinMaxValues(const Standard_ShortRe
{ {
OpenGl_GraduatedTrihedron::SetMinMax(xmin, ymin, zmin, xmax, ymax, zmax); OpenGl_GraduatedTrihedron::SetMinMax(xmin, ymin, zmin, xmax, ymax, zmax);
} }
// Helper function, returns the nearest power of two greater than the argument value
inline Standard_Integer GetNearestPow2(Standard_Integer theValue)
{
// Precaution against overflow
Standard_Integer aHalfMax = IntegerLast() >> 1, aRes = 1;
if ( theValue > aHalfMax ) theValue = aHalfMax;
while ( aRes < theValue ) aRes <<= 1;
return aRes;
}
Standard_Integer OpenGl_GraphicDriver::CreateTexture (const Graphic3d_TypeOfTexture theType,
const Image_PixMap& theImage,
const Standard_CString theFileName,
const Handle(TColStd_HArray1OfReal)& theTexUpperBounds) const
{
if (theImage.IsEmpty())
{
return -1;
}
Standard_Integer aGlWidth = (Standard_Integer )theImage.Width();
Standard_Integer aGlHeight = (Standard_Integer )theImage.Height();
if (theType != Graphic3d_TOT_2D_MIPMAP)
{
aGlWidth = GetNearestPow2 (aGlWidth);
aGlHeight = GetNearestPow2 (aGlHeight);
}
theTexUpperBounds->SetValue (1, Standard_Real(theImage.Width()) / Standard_Real(aGlWidth));
theTexUpperBounds->SetValue (2, Standard_Real(theImage.Height()) / Standard_Real(aGlHeight));
Image_PixMap anImage;
if (!anImage.InitTrash (Image_PixMap::ImgRGBA, Standard_Size(aGlWidth), Standard_Size(aGlHeight)))
{
return -1;
}
anImage.SetTopDown (false);
Image_PixMapData<Image_ColorRGBA>& aDataNew = anImage.EditData<Image_ColorRGBA>();
Quantity_Color aSrcColor;
for (Standard_Size aRow = 0; aRow < theImage.SizeY(); ++aRow)
{
for (Standard_Size aCol = 0; aCol < theImage.SizeX(); ++aCol)
{
aSrcColor = theImage.PixelColor (aCol, aRow);
Image_ColorRGBA& aColor = aDataNew.ChangeValue (aRow, aCol);
aColor.r() = int(255.0 * aSrcColor.Red());
aColor.g() = int(255.0 * aSrcColor.Green());
aColor.b() = int(255.0 * aSrcColor.Blue());
aColor.a() = 0xFF;
}
for (Standard_Size aCol = theImage.SizeX(); aCol < anImage.SizeX(); ++aCol)
{
Image_ColorRGBA& aColor = aDataNew.ChangeValue (aRow, aCol);
aColor.r() = 0x00;
aColor.g() = 0x00;
aColor.b() = 0x00;
aColor.a() = 0xFF;
}
}
// Padding the lower part of the texture with black
for (Standard_Size aRow = theImage.SizeY(); aRow < anImage.SizeY(); ++aRow)
{
for (Standard_Size aCol = 0; aCol < anImage.SizeX(); ++aCol)
{
Image_ColorRGBA& aColor = aDataNew.ChangeValue (aRow, aCol);
aColor.r() = 0x00;
aColor.g() = 0x00;
aColor.b() = 0x00;
aColor.a() = 0xFF;
}
}
static Standard_Integer TheTextureRank = 0;
char aTextureStrId[255];
sprintf (aTextureStrId, "Tex%d", ++TheTextureRank);
switch (theType)
{
case Graphic3d_TOT_1D: return GetTextureData1D (aTextureStrId, aGlWidth, aGlHeight, anImage.Data());
case Graphic3d_TOT_2D: return GetTextureData2D (aTextureStrId, aGlWidth, aGlHeight, anImage.Data());
case Graphic3d_TOT_2D_MIPMAP: return GetTextureData2DMipMap (aTextureStrId, aGlWidth, aGlHeight, anImage.Data());
default: return -1;
}
}
void OpenGl_GraphicDriver::DestroyTexture (const Standard_Integer theTexId) const
{
FreeTexture (GetSharedContext(), theTexId);
}
void OpenGl_GraphicDriver::ModifyTexture (const Standard_Integer theTexId,
const Graphic3d_CInitTexture& theInfo) const
{
if (theInfo.doModulate)
SetTextureModulate (theTexId);
else
SetTextureDecal (theTexId);
if (theInfo.doRepeat)
SetTextureRepeat (theTexId);
else
SetTextureClamp (theTexId);
switch (theInfo.Mode)
{
case 0:
SetModeObject (theTexId, theInfo.sparams, theInfo.tparams);
break;
case 1:
SetModeSphere (theTexId);
break;
case 2:
SetModeEye (theTexId, theInfo.sparams, theInfo.tparams);
break;
case 3:
SetModeManual (theTexId);
break;
}
if (theInfo.doLinear)
SetRenderLinear (theTexId);
else
SetRenderNearest (theTexId);
SetTexturePosition (theTexId,
theInfo.sx, theInfo.sy,
theInfo.tx, theInfo.ty,
theInfo.angle);
}

View File

@ -17,11 +17,10 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_Group.hxx> #include <OpenGl_Group.hxx>
#include <OpenGl_TextureBox.hxx>
#include <OpenGl_PrimitiveArray.hxx> #include <OpenGl_PrimitiveArray.hxx>
#include <OpenGl_Workspace.hxx>
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@ -60,19 +59,22 @@ void OpenGl_Group::SetAspectLine (const CALL_DEF_CONTEXTLINE& theContext,
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
void OpenGl_Group::SetAspectFace (const CALL_DEF_CONTEXTFILLAREA& theContext, void OpenGl_Group::SetAspectFace (const Handle(OpenGl_Context)& theCtx,
const Standard_Boolean theIsGlobal) const CALL_DEF_CONTEXTFILLAREA& theAspect,
const Standard_Boolean theIsGlobal)
{ {
if (theIsGlobal || myFirst == NULL) if (theIsGlobal || myFirst == NULL)
{ {
if (myAspectFace == NULL) if (myAspectFace == NULL)
{
myAspectFace = new OpenGl_AspectFace(); myAspectFace = new OpenGl_AspectFace();
myAspectFace->SetContext (theContext); }
myAspectFace->Init (theCtx, theAspect);
} }
else else
{ {
OpenGl_AspectFace* anAspectFace = new OpenGl_AspectFace(); OpenGl_AspectFace* anAspectFace = new OpenGl_AspectFace();
anAspectFace->SetContext (theContext); anAspectFace->Init (theCtx, theAspect);
AddElement (TelNil/*TelAspectFace*/, anAspectFace); AddElement (TelNil/*TelAspectFace*/, anAspectFace);
} }
} }
@ -141,7 +143,7 @@ void OpenGl_Group::RemovePrimitiveArray (const Handle(OpenGl_Context)& theGlCtx,
CALL_DEF_PARRAY* aCurPArray = ((const OpenGl_PrimitiveArray* )node->elem)->PArray(); CALL_DEF_PARRAY* aCurPArray = ((const OpenGl_PrimitiveArray* )node->elem)->PArray();
// validate for correct pointer // validate for correct pointer
if (aCurPArray->num_bounds == thePArray->num_bounds && if (aCurPArray->num_bounds == thePArray->num_bounds &&
aCurPArray->num_edges == thePArray->num_edges && aCurPArray->num_edges == thePArray->num_edges &&
aCurPArray->num_vertexs == thePArray->num_vertexs && aCurPArray->num_vertexs == thePArray->num_vertexs &&
aCurPArray->type == thePArray->type) aCurPArray->type == thePArray->type)
@ -160,54 +162,69 @@ void OpenGl_Group::RemovePrimitiveArray (const Handle(OpenGl_Context)& theGlCtx,
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
void OpenGl_Group::Render (const Handle(OpenGl_Workspace) &AWorkspace) const void OpenGl_Group::Render (const Handle(OpenGl_Workspace)& theWorkspace) const
{ {
// Is rendering in ADD or IMMEDIATE mode? // Is rendering in ADD or IMMEDIATE mode?
const Standard_Boolean isImmediate = (AWorkspace->NamedStatus & (OPENGL_NS_ADD | OPENGL_NS_IMMEDIATE)) != 0; const Standard_Boolean isImmediate = (theWorkspace->NamedStatus & (OPENGL_NS_ADD | OPENGL_NS_IMMEDIATE)) != 0;
// Setup aspects // Setup aspects
const OpenGl_AspectLine *aspect_line = AWorkspace->AspectLine(Standard_False); const OpenGl_AspectLine* aBackAspectLine = theWorkspace->AspectLine (Standard_False);
const OpenGl_AspectFace *aspect_face = AWorkspace->AspectFace(Standard_False); const OpenGl_AspectFace* aBackAspectFace = theWorkspace->AspectFace (Standard_False);
const OpenGl_AspectMarker *aspect_marker = AWorkspace->AspectMarker(Standard_False); const OpenGl_AspectMarker* aBackAspectMarker = theWorkspace->AspectMarker (Standard_False);
const OpenGl_AspectText *aspect_text = AWorkspace->AspectText(Standard_False); const OpenGl_AspectText* aBackAspectText = theWorkspace->AspectText (Standard_False);
if (myAspectLine) if (myAspectLine)
AWorkspace->SetAspectLine(myAspectLine); {
theWorkspace->SetAspectLine (myAspectLine);
}
if (myAspectFace) if (myAspectFace)
AWorkspace->SetAspectFace(myAspectFace); {
theWorkspace->SetAspectFace (myAspectFace);
}
if (myAspectMarker) if (myAspectMarker)
AWorkspace->SetAspectMarker(myAspectMarker); {
theWorkspace->SetAspectMarker (myAspectMarker);
}
if (myAspectText) if (myAspectText)
AWorkspace->SetAspectText(myAspectText); {
theWorkspace->SetAspectText (myAspectText);
}
// Render group elements // Render group elements
OpenGl_ElementNode *node = myFirst; Handle(OpenGl_Texture) aPrevTexture; // temporary disabled texture
while (node) for (OpenGl_ElementNode* aNodeIter = myFirst; aNodeIter != NULL; aNodeIter = aNodeIter->next)
{ {
switch (node->type) switch (aNodeIter->type)
{ {
case TelPolyline: case TelPolyline:
case TelMarker: case TelMarker:
case TelMarkerSet: case TelMarkerSet:
case TelText: case TelText:
{ {
glDisable(GL_LIGHTING); glDisable (GL_LIGHTING);
if (isImmediate) if (isImmediate)
{ {
glDepthMask(GL_FALSE); glDepthMask (GL_FALSE);
} }
else if ( (AWorkspace->NamedStatus & OPENGL_NS_ANIMATION) != 0 && else if ((theWorkspace->NamedStatus & OPENGL_NS_ANIMATION) != 0 &&
(AWorkspace->NamedStatus & OPENGL_NS_WIREFRAME) == 0 && (theWorkspace->NamedStatus & OPENGL_NS_WIREFRAME) == 0 &&
AWorkspace->DegenerateModel != 0 ) theWorkspace->DegenerateModel != 0)
{ {
glDisable( GL_DEPTH_TEST ); glDisable (GL_DEPTH_TEST);
if ( AWorkspace->NamedStatus & OPENGL_NS_TEXTURE ) DisableTexture(); if (theWorkspace->NamedStatus & OPENGL_NS_TEXTURE)
AWorkspace->NamedStatus |= OPENGL_NS_WIREFRAME; {
aPrevTexture = theWorkspace->DisableTexture();
}
theWorkspace->NamedStatus |= OPENGL_NS_WIREFRAME;
} }
node->elem->Render( AWorkspace ); if (!aPrevTexture.IsNull())
{
theWorkspace->EnableTexture (aPrevTexture);
aPrevTexture.Nullify();
}
if ( !isImmediate && (AWorkspace->NamedStatus & OPENGL_NS_TEXTURE) != 0 ) EnableTexture(); aNodeIter->elem->Render (theWorkspace);
break; break;
} }
@ -220,40 +237,41 @@ void OpenGl_Group::Render (const Handle(OpenGl_Workspace) &AWorkspace) const
{ {
glDepthMask(GL_FALSE); glDepthMask(GL_FALSE);
} }
else if ( (AWorkspace->NamedStatus & OPENGL_NS_ANIMATION) != 0 && else if ((theWorkspace->NamedStatus & OPENGL_NS_ANIMATION) != 0 &&
(AWorkspace->NamedStatus & OPENGL_NS_WIREFRAME) != 0 && (theWorkspace->NamedStatus & OPENGL_NS_WIREFRAME) != 0 &&
AWorkspace->DegenerateModel < 2 ) theWorkspace->DegenerateModel < 2)
{ {
if ( AWorkspace->NamedStatus & OPENGL_NS_TEXTURE ) EnableTexture (); glEnable (GL_DEPTH_TEST);
theWorkspace->NamedStatus &= ~OPENGL_NS_WIREFRAME;
glEnable( GL_DEPTH_TEST );
AWorkspace->NamedStatus &= ~OPENGL_NS_WIREFRAME;
} }
if ( AWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT ) if (theWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT)
AWorkspace->DisablePolygonOffset(); {
theWorkspace->DisablePolygonOffset();
}
node->elem->Render( AWorkspace ); aNodeIter->elem->Render (theWorkspace);
if ( AWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT ) if (theWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT)
AWorkspace->EnablePolygonOffset(); {
theWorkspace->EnablePolygonOffset();
}
break; break;
} }
default: default:
{ {
node->elem->Render( AWorkspace ); aNodeIter->elem->Render (theWorkspace);
break; break;
} }
} }
node = node->next;
} }
// Restore aspects // Restore aspects
AWorkspace->SetAspectLine(aspect_line); theWorkspace->SetAspectLine (aBackAspectLine);
AWorkspace->SetAspectFace(aspect_face); theWorkspace->SetAspectFace (aBackAspectFace);
AWorkspace->SetAspectMarker(aspect_marker); theWorkspace->SetAspectMarker (aBackAspectMarker);
AWorkspace->SetAspectText(aspect_text); theWorkspace->SetAspectText (aBackAspectText);
} }
void OpenGl_Group::Release (const Handle(OpenGl_Context)& theGlCtx) void OpenGl_Group::Release (const Handle(OpenGl_Context)& theGlCtx)

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_Group_Header #ifndef _OpenGl_Group_Header
#define _OpenGl_Group_Header #define _OpenGl_Group_Header
@ -48,7 +47,9 @@ public:
OpenGl_Group(); OpenGl_Group();
void SetAspectLine (const CALL_DEF_CONTEXTLINE &AContext, const Standard_Boolean IsGlobal = Standard_True); void SetAspectLine (const CALL_DEF_CONTEXTLINE &AContext, const Standard_Boolean IsGlobal = Standard_True);
void SetAspectFace (const CALL_DEF_CONTEXTFILLAREA &AContext, const Standard_Boolean IsGlobal = Standard_True); void SetAspectFace (const Handle(OpenGl_Context)& theCtx,
const CALL_DEF_CONTEXTFILLAREA& theAspect,
const Standard_Boolean IsGlobal = Standard_True);
void SetAspectMarker (const CALL_DEF_CONTEXTMARKER &AContext, const Standard_Boolean IsGlobal = Standard_True); void SetAspectMarker (const CALL_DEF_CONTEXTMARKER &AContext, const Standard_Boolean IsGlobal = Standard_True);
void SetAspectText (const CALL_DEF_CONTEXTTEXT &AContext, const Standard_Boolean IsGlobal = Standard_True); void SetAspectText (const CALL_DEF_CONTEXTTEXT &AContext, const Standard_Boolean IsGlobal = Standard_True);

View File

@ -26,6 +26,7 @@
#include <OpenGl_AspectMarker.hxx> #include <OpenGl_AspectMarker.hxx>
#include <OpenGl_Structure.hxx> #include <OpenGl_Structure.hxx>
#include <OpenGl_Display.hxx> #include <OpenGl_Display.hxx>
#include <OpenGl_Workspace.hxx>
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@ -85,7 +86,7 @@ void OpenGl_Marker::Render (const Handle(OpenGl_Workspace) &AWorkspace) const
break; break;
} }
case Aspect_TOM_USERDEFINED : case Aspect_TOM_USERDEFINED :
{ {
glCallList( openglDisplay->GetUserMarkerListIndex( (int)aspect_marker->Scale() ) ); glCallList( openglDisplay->GetUserMarkerListIndex( (int)aspect_marker->Scale() ) );
break; break;
} }

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_GlCore11.hxx> #include <OpenGl_GlCore11.hxx>
#include <OpenGl_Context.hxx> #include <OpenGl_Context.hxx>
@ -26,6 +25,7 @@
#include <OpenGl_AspectMarker.hxx> #include <OpenGl_AspectMarker.hxx>
#include <OpenGl_Structure.hxx> #include <OpenGl_Structure.hxx>
#include <OpenGl_Display.hxx> #include <OpenGl_Display.hxx>
#include <OpenGl_Workspace.hxx>
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/

View File

@ -17,16 +17,15 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_GlCore11.hxx> #include <OpenGl_GlCore11.hxx>
#include <OpenGl_Polygon.hxx> #include <OpenGl_Polygon.hxx>
#include <OpenGl_telem_util.hxx> #include <OpenGl_telem_util.hxx>
#include <OpenGl_TextureBox.hxx>
#include <OpenGl_AspectFace.hxx> #include <OpenGl_AspectFace.hxx>
#include <OpenGl_Structure.hxx> #include <OpenGl_Structure.hxx>
#include <OpenGl_Workspace.hxx>
#include <GL/glu.h> #include <GL/glu.h>
@ -113,7 +112,7 @@ void OpenGl_Polygon::draw_polygon (const Handle(OpenGl_Workspace) &AWorkspace, T
{ {
glNormal3fv( pvn[i].xyz ); glNormal3fv( pvn[i].xyz );
glVertex3fv( ptr->xyz ); glVertex3fv( ptr->xyz );
} }
} }
else else
{ {
@ -140,7 +139,7 @@ void OpenGl_Polygon::draw_polygon (const Handle(OpenGl_Workspace) &AWorkspace, T
glVertex3fv( ptr->xyz ); glVertex3fv( ptr->xyz );
} }
} }
} }
glEnd(); glEnd();
if( myData.reverse_order ) glFrontFace( GL_CCW ); if( myData.reverse_order ) glFrontFace( GL_CCW );
@ -283,7 +282,7 @@ bgntriangulate(const TEL_POLYGON_DATA *d, void ( APIENTRY * out_ver)() )
gluTessCallback( tripak, GLU_TESS_END, out_endtmesh ); gluTessCallback( tripak, GLU_TESS_END, out_endtmesh );
gluTessCallback( tripak, GLU_TESS_ERROR, (_GLUfuncptr)(out_error) ); gluTessCallback( tripak, GLU_TESS_ERROR, (_GLUfuncptr)(out_error) );
gluTessCallback( tripak, GLU_TESS_COMBINE, (_GLUfuncptr)(mycombine) ); gluTessCallback( tripak, GLU_TESS_COMBINE, (_GLUfuncptr)(mycombine) );
#else #else
gluTessCallback( tripak, GLU_TESS_BEGIN, (void (APIENTRY*)())out_bgntmesh ); gluTessCallback( tripak, GLU_TESS_BEGIN, (void (APIENTRY*)())out_bgntmesh );
gluTessCallback( tripak, GLU_TESS_VERTEX, (void (APIENTRY*)())out_ver ); gluTessCallback( tripak, GLU_TESS_VERTEX, (void (APIENTRY*)())out_ver );
gluTessCallback( tripak, GLU_TESS_END, (void (APIENTRY*)())out_endtmesh ); gluTessCallback( tripak, GLU_TESS_END, (void (APIENTRY*)())out_endtmesh );
@ -360,7 +359,7 @@ void OpenGl_Polygon::draw_polygon_concav (const Handle(OpenGl_Workspace) &AWorks
{ {
xyz[0] = ptr->xyz[0]; xyz[0] = ptr->xyz[0];
xyz[1] = ptr->xyz[1]; xyz[1] = ptr->xyz[1];
xyz[2] = ptr->xyz[2]; xyz[2] = ptr->xyz[2];
#ifndef WNT #ifndef WNT
gluTessVertex( tripak, xyz,(void * ) i ); gluTessVertex( tripak, xyz,(void * ) i );
#else #else
@ -373,8 +372,8 @@ void OpenGl_Polygon::draw_polygon_concav (const Handle(OpenGl_Workspace) &AWorks
gluTessEndContour( tripak ); gluTessEndContour( tripak );
gluTessEndPolygon( tripak ); gluTessEndPolygon( tripak );
endtriangulate(); endtriangulate();
} }
else else
{ {
if( front_lighting_model ) if( front_lighting_model )
{ {
@ -391,37 +390,39 @@ void OpenGl_Polygon::draw_polygon_concav (const Handle(OpenGl_Workspace) &AWorks
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
void OpenGl_Polygon::draw_edges (const TEL_COLOUR *edge_colour, const Aspect_InteriorStyle interior_style, const Handle(OpenGl_Workspace) &AWorkspace) const void OpenGl_Polygon::draw_edges (const TEL_COLOUR* theEdgeColor,
const Aspect_InteriorStyle theInteriorStyle,
const Handle(OpenGl_Workspace)& theWorkspace) const
{ {
const OpenGl_AspectFace *aspect_face = AWorkspace->AspectFace( Standard_True ); const OpenGl_AspectFace* anAspectFace = theWorkspace->AspectFace (Standard_True);
if ( interior_style != Aspect_IS_HIDDENLINE && aspect_face->Context().Edge == TOff ) if (theInteriorStyle != Aspect_IS_HIDDENLINE
&& anAspectFace->Edge == TOff)
{
return; return;
}
glDisable(GL_LIGHTING); glDisable (GL_LIGHTING);
const GLboolean texture_on = IsTextureEnabled(); const Handle(OpenGl_Texture) aPrevTexture = theWorkspace->DisableTexture();
if (texture_on) DisableTexture();
// Setup line aspect // Setup line aspect
const OpenGl_AspectLine *aspect_line_old = AWorkspace->SetAspectLine( aspect_face->AspectEdge() ); const OpenGl_AspectLine* aPrevAspectLine = theWorkspace->SetAspectLine (anAspectFace->AspectEdge());
AWorkspace->AspectLine( Standard_True ); theWorkspace->AspectLine (Standard_True);
Tint i; glColor3fv (theEdgeColor->rgb);
glBegin (GL_LINE_LOOP);
tel_point ptr = myData.vertices; tel_point ptr = myData.vertices;
for (Tint i = 0; i < myData.num_vertices; i++, ptr++)
glColor3fv( edge_colour->rgb );
glBegin(GL_LINE_LOOP);
for( i=0; i<myData.num_vertices; i++, ptr++ )
{ {
glVertex3fv( ptr->xyz ); glVertex3fv (ptr->xyz);
} }
glEnd(); glEnd();
// Restore line context // Restore line context
AWorkspace->SetAspectLine( aspect_line_old ); theWorkspace->SetAspectLine (aPrevAspectLine);
if (texture_on) EnableTexture(); theWorkspace->EnableTexture (aPrevTexture);
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@ -578,20 +579,20 @@ void OpenGl_Polygon::Render (const Handle(OpenGl_Workspace) &AWorkspace) const
{ {
const OpenGl_AspectFace *aspect_face = AWorkspace->AspectFace( Standard_True ); const OpenGl_AspectFace *aspect_face = AWorkspace->AspectFace( Standard_True );
Tint front_lighting_model = aspect_face->Context().IntFront.color_mask; Tint front_lighting_model = aspect_face->IntFront.color_mask;
const Aspect_InteriorStyle interior_style = aspect_face->Context().InteriorStyle; const Aspect_InteriorStyle interior_style = aspect_face->InteriorStyle;
const TEL_COLOUR *interior_colour = &aspect_face->Context().IntFront.matcol; const TEL_COLOUR *interior_colour = &aspect_face->IntFront.matcol;
const TEL_COLOUR *edge_colour = &aspect_face->AspectEdge()->Color(); const TEL_COLOUR *edge_colour = &aspect_face->AspectEdge()->Color();
// Use highlight colous // Use highlight colous
if ( AWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT ) if ( AWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT )
{ {
edge_colour = interior_colour = AWorkspace->HighlightColor; edge_colour = interior_colour = AWorkspace->HighlightColor;
front_lighting_model = 0; front_lighting_model = 0;
} }
if( interior_style != Aspect_IS_EMPTY && AWorkspace->DegenerateModel < 2 ) if( interior_style != Aspect_IS_EMPTY && AWorkspace->DegenerateModel < 2 )
{ {
if ( front_lighting_model ) if ( front_lighting_model )
glEnable(GL_LIGHTING); glEnable(GL_LIGHTING);
else else

View File

@ -17,13 +17,13 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_GlCore11.hxx> #include <OpenGl_GlCore11.hxx>
#include <OpenGl_Polyline.hxx> #include <OpenGl_Polyline.hxx>
#include <OpenGl_AspectLine.hxx> #include <OpenGl_AspectLine.hxx>
#include <OpenGl_Structure.hxx> #include <OpenGl_Structure.hxx>
#include <OpenGl_Workspace.hxx>
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/

View File

@ -25,7 +25,7 @@
#include <OpenGl_AspectFace.hxx> #include <OpenGl_AspectFace.hxx>
#include <OpenGl_GraphicDriver.hxx> #include <OpenGl_GraphicDriver.hxx>
#include <OpenGl_Structure.hxx> #include <OpenGl_Structure.hxx>
#include <OpenGl_TextureBox.hxx> #include <OpenGl_Workspace.hxx>
#include <InterfaceGraphic_PrimitiveArray.hxx> #include <InterfaceGraphic_PrimitiveArray.hxx>
@ -157,10 +157,10 @@ void OpenGl_PrimitiveArray::DrawArray (Tint theLightingModel,
for (i = 0; i < myPArray->num_vertexs; ++i) for (i = 0; i < myPArray->num_vertexs; ++i)
{ {
transp = int(theFaceProp->trans * 255.0f); transp = int(theFaceProp->trans * 255.0f);
#if defined (sparc) || defined (__sparc__) || defined (__sparc) #if defined (sparc) || defined (__sparc__) || defined (__sparc)
pvc[i] = (pvc[i] & 0xffffff00); pvc[i] = (pvc[i] & 0xffffff00);
pvc[i] += transp; pvc[i] += transp;
#else #else
pvc[i] = (pvc[i] & 0x00ffffff); pvc[i] = (pvc[i] & 0x00ffffff);
pvc[i] += transp << 24; pvc[i] += transp << 24;
#endif #endif
@ -210,7 +210,7 @@ void OpenGl_PrimitiveArray::DrawArray (Tint theLightingModel,
} }
// Sometimes the GL_LIGHTING mode is activated here // Sometimes the GL_LIGHTING mode is activated here
// without glEnable(GL_LIGHTING) call for an unknown reason, so it is necessary // without glEnable(GL_LIGHTING) call for an unknown reason, so it is necessary
// to call glEnable(GL_LIGHTING) to synchronize Light On/Off mechanism* // to call glEnable(GL_LIGHTING) to synchronize Light On/Off mechanism*
if (theLightingModel == 0 || myDrawMode <= GL_LINE_STRIP) if (theLightingModel == 0 || myDrawMode <= GL_LINE_STRIP)
glDisable (GL_LIGHTING); glDisable (GL_LIGHTING);
@ -279,7 +279,7 @@ void OpenGl_PrimitiveArray::DrawArray (Tint theLightingModel,
for (i = 0; i < myPArray->num_bounds; ++i) for (i = 0; i < myPArray->num_bounds; ++i)
{ {
glDrawElements (myDrawMode, myPArray->bounds[i], myVbos[VBOEdges]->GetDataType(), anOffset); glDrawElements (myDrawMode, myPArray->bounds[i], myVbos[VBOEdges]->GetDataType(), anOffset);
anOffset += myPArray->bounds[i]; anOffset += myPArray->bounds[i];
} }
} }
else else
@ -318,7 +318,7 @@ void OpenGl_PrimitiveArray::DrawArray (Tint theLightingModel,
glDisable (GL_COLOR_MATERIAL); glDisable (GL_COLOR_MATERIAL);
theWorkspace->NamedStatus |= OPENGL_NS_RESMAT; // Reset material theWorkspace->NamedStatus |= OPENGL_NS_RESMAT; // Reset material
} }
} }
else else
{ {
if (myPArray->num_bounds > 0) if (myPArray->num_bounds > 0)
@ -384,13 +384,13 @@ void OpenGl_PrimitiveArray::DrawArray (Tint theLightingModel,
switch (theWorkspace->DegenerateModel) switch (theWorkspace->DegenerateModel)
{ {
default: // XXX_TDM_NODE or TINY default: // XXX_TDM_NODE or TINY
// On some NVIDIA graphic cards, using glEdgeFlagPointer() in // On some NVIDIA graphic cards, using glEdgeFlagPointer() in
// combination with VBO ( edge flag data put into a VBO buffer) // combination with VBO ( edge flag data put into a VBO buffer)
// leads to a crash in a driver. Therefore, edge flags are simply // leads to a crash in a driver. Therefore, edge flags are simply
// igonored when VBOs are enabled, so all the edges are drawn if // igonored when VBOs are enabled, so all the edges are drawn if
// edge visibility is turned on. In order to draw edges selectively, // edge visibility is turned on. In order to draw edges selectively,
// either disable VBO or turn off edge visibilty in the current // either disable VBO or turn off edge visibilty in the current
// primitive array and create a separate primitive array (segments) // primitive array and create a separate primitive array (segments)
// and put edges to be drawn into it. // and put edges to be drawn into it.
if (myDrawMode > GL_LINE_STRIP) if (myDrawMode > GL_LINE_STRIP)
{ {
@ -444,7 +444,7 @@ void OpenGl_PrimitiveArray::DrawEdges (const TEL_COLOUR* theEdgeCo
/// 2) draw elements from vertice array, when bounds defines count of primitive's verts. /// 2) draw elements from vertice array, when bounds defines count of primitive's verts.
/// 3) draw primitive's edges by vertexes if no edges and bounds array is specified /// 3) draw primitive's edges by vertexes if no edges and bounds array is specified
if (toDrawVbo()) if (toDrawVbo())
{ {
myVbos[VBOVertices]->BindFixed (aGlContext, GL_VERTEX_ARRAY); myVbos[VBOVertices]->BindFixed (aGlContext, GL_VERTEX_ARRAY);
glColor3fv (theEdgeColour->rgb); glColor3fv (theEdgeColour->rgb);
if (!myVbos[VBOEdges].IsNull()) if (!myVbos[VBOEdges].IsNull())
@ -521,7 +521,7 @@ void OpenGl_PrimitiveArray::DrawEdges (const TEL_COLOUR* theEdgeCo
n += myPArray->bounds[i]; n += myPArray->bounds[i];
} }
} }
} }
else if (myPArray->num_edges > 0) else if (myPArray->num_edges > 0)
{ {
if (myPArray->edge_vis) if (myPArray->edge_vis)
@ -558,7 +558,7 @@ void OpenGl_PrimitiveArray::DrawEdges (const TEL_COLOUR* theEdgeCo
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesPointsAsPoints() const void OpenGl_PrimitiveArray::DrawDegeneratesPointsAsPoints() const
{ {
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
for (Tint aVertId = 0; aVertId < myPArray->num_vertexs; ++aVertId) for (Tint aVertId = 0; aVertId < myPArray->num_vertexs; ++aVertId)
{ {
@ -589,7 +589,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesLinesAsPoints() const
pt[2] *= 0.5f; pt[2] *= 0.5f;
glVertex3fv (pt); glVertex3fv (pt);
} }
} }
// ======================================================================= // =======================================================================
// function : DrawDegeneratesTrianglesAsPoints // function : DrawDegeneratesTrianglesAsPoints
@ -648,7 +648,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesTrianglesAsPoints() const
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesTrianglestripsAsPoints() const void OpenGl_PrimitiveArray::DrawDegeneratesTrianglestripsAsPoints() const
{ {
Tint i, j, k, n; Tint i, j, k, n;
GLfloat pt[ 3 ]; GLfloat pt[ 3 ];
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
@ -702,7 +702,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesTrianglestripsAsPoints() const
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesPolygonsAsPoints() const void OpenGl_PrimitiveArray::DrawDegeneratesPolygonsAsPoints() const
{ {
Tint j, k, n, iv; Tint j, k, n, iv;
GLfloat pt[3]; GLfloat pt[3];
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
@ -823,14 +823,14 @@ void OpenGl_PrimitiveArray::DrawDegeneratesQuadranglesAsPoints() const
glVertex3fv (pt); glVertex3fv (pt);
} }
} }
} }
// ======================================================================= // =======================================================================
// function : DrawDegeneratesAsPoints // function : DrawDegeneratesAsPoints
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesQuadranglestripsAsPoints() const void OpenGl_PrimitiveArray::DrawDegeneratesQuadranglestripsAsPoints() const
{ {
Tint i, j, k, n; Tint i, j, k, n;
GLfloat pt[3]; GLfloat pt[3];
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
@ -888,7 +888,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesAsPoints (const TEL_COLOUR* theEdgeCo
GLboolean zbuff_state = glIsEnabled (GL_DEPTH_TEST); GLboolean zbuff_state = glIsEnabled (GL_DEPTH_TEST);
glDisable (GL_LIGHTING); glDisable (GL_LIGHTING);
if (zbuff_state) if (zbuff_state)
glDisable (GL_DEPTH_TEST); glDisable (GL_DEPTH_TEST);
glColor3fv (theEdgeColour->rgb); glColor3fv (theEdgeColour->rgb);
glBegin (GL_POINTS); glBegin (GL_POINTS);
@ -1014,7 +1014,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesLinesAsLines (const float theSkipRati
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesTrianglesAsLines (const float theSkipRatio) const void OpenGl_PrimitiveArray::DrawDegeneratesTrianglesAsLines (const float theSkipRatio) const
{ {
Tint i, iv; Tint i, iv;
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
@ -1032,7 +1032,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesTrianglesAsLines (const float theSkip
{ {
iv = myPArray->edges[j]; iv = myPArray->edges[j];
if (myPArray->keys[iv] < 0) if (myPArray->keys[iv] < 0)
{ {
myPArray->keys[iv] = -myPArray->keys[iv]; myPArray->keys[iv] = -myPArray->keys[iv];
glBegin (GL_LINE_LOOP); glBegin (GL_LINE_LOOP);
for (i = 0; i < 3; ++i) for (i = 0; i < 3; ++i)
@ -1067,7 +1067,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesTrianglesAsLines (const float theSkip
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesTrianglestripsAsLines (const float theSkipRatio) const void OpenGl_PrimitiveArray::DrawDegeneratesTrianglestripsAsLines (const float theSkipRatio) const
{ {
Tint i, j, k, n, ni; Tint i, j, k, n, ni;
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
@ -1126,7 +1126,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesTrianglestripsAsLines (const float th
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesPolygonsAsLines (const float theSkipRatio) const void OpenGl_PrimitiveArray::DrawDegeneratesPolygonsAsLines (const float theSkipRatio) const
{ {
Tint i, iv; Tint i, iv;
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
@ -1203,7 +1203,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesPolygonsAsLines (const float theSkipR
} }
glEnd(); glEnd();
} }
} }
// ======================================================================= // =======================================================================
// function : DrawDegeneratesQuadranglesAsLines // function : DrawDegeneratesQuadranglesAsLines
@ -1263,7 +1263,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesQuadranglesAsLines (const float theSk
// purpose : // purpose :
// ======================================================================= // =======================================================================
void OpenGl_PrimitiveArray::DrawDegeneratesQuadranglestripsAsLines (const float theSkipRatio) const void OpenGl_PrimitiveArray::DrawDegeneratesQuadranglestripsAsLines (const float theSkipRatio) const
{ {
Tint i, j, k, n, ni; Tint i, j, k, n, ni;
tel_point pv = myPArray->vertices; tel_point pv = myPArray->vertices;
@ -1333,7 +1333,7 @@ void OpenGl_PrimitiveArray::DrawDegeneratesAsLines (const TEL_COLOUR*
glDisable (GL_LIGHTING); glDisable (GL_LIGHTING);
if (zbuff_state) if (zbuff_state)
glDisable (GL_DEPTH_TEST); glDisable (GL_DEPTH_TEST);
glColor3fv (theEdgeColour->rgb); glColor3fv (theEdgeColour->rgb);
@ -1433,8 +1433,8 @@ void OpenGl_PrimitiveArray::DrawDegeneratesAsLines (const TEL_COLOUR*
} }
if (zbuff_state) if (zbuff_state)
glEnable(GL_DEPTH_TEST); glEnable(GL_DEPTH_TEST);
} }
// ======================================================================= // =======================================================================
// function : DrawDegeneratesAsBBoxs // function : DrawDegeneratesAsBBoxs
@ -1567,7 +1567,9 @@ void OpenGl_PrimitiveArray::Release (const Handle(OpenGl_Context)& theContext)
void OpenGl_PrimitiveArray::Render (const Handle(OpenGl_Workspace)& theWorkspace) const void OpenGl_PrimitiveArray::Render (const Handle(OpenGl_Workspace)& theWorkspace) const
{ {
if (myPArray == NULL || myDrawMode == DRAW_MODE_NONE || myPArray->num_vertexs <= 0) if (myPArray == NULL || myDrawMode == DRAW_MODE_NONE || myPArray->num_vertexs <= 0)
{
return; return;
}
// create VBOs on first render call // create VBOs on first render call
if (!myIsVboInit && OpenGl_GraphicDriver::ToUseVBO() && theWorkspace->GetGlContext()->core15 != NULL) if (!myIsVboInit && OpenGl_GraphicDriver::ToUseVBO() && theWorkspace->GetGlContext()->core15 != NULL)
@ -1576,6 +1578,7 @@ void OpenGl_PrimitiveArray::Render (const Handle(OpenGl_Workspace)& theWorkspace
myIsVboInit = Standard_True; myIsVboInit = Standard_True;
} }
Standard_Boolean toDisableTexture = Standard_False;
switch (myPArray->type) switch (myPArray->type)
{ {
case TelPointsArrayType: case TelPointsArrayType:
@ -1589,8 +1592,7 @@ void OpenGl_PrimitiveArray::Render (const Handle(OpenGl_Workspace)& theWorkspace
theWorkspace->DegenerateModel) theWorkspace->DegenerateModel)
{ {
glDisable (GL_DEPTH_TEST); glDisable (GL_DEPTH_TEST);
if (theWorkspace->NamedStatus & OPENGL_NS_TEXTURE) toDisableTexture = (theWorkspace->NamedStatus & OPENGL_NS_TEXTURE);
DisableTexture();
theWorkspace->NamedStatus |= OPENGL_NS_WIREFRAME; theWorkspace->NamedStatus |= OPENGL_NS_WIREFRAME;
} }
break; break;
@ -1606,8 +1608,6 @@ void OpenGl_PrimitiveArray::Render (const Handle(OpenGl_Workspace)& theWorkspace
(theWorkspace->NamedStatus & OPENGL_NS_WIREFRAME) != 0 && (theWorkspace->NamedStatus & OPENGL_NS_WIREFRAME) != 0 &&
theWorkspace->DegenerateModel < 2) theWorkspace->DegenerateModel < 2)
{ {
if (theWorkspace->NamedStatus & OPENGL_NS_TEXTURE)
EnableTexture();
glEnable (GL_DEPTH_TEST); glEnable (GL_DEPTH_TEST);
theWorkspace->NamedStatus &= ~OPENGL_NS_WIREFRAME; theWorkspace->NamedStatus &= ~OPENGL_NS_WIREFRAME;
} }
@ -1617,39 +1617,38 @@ void OpenGl_PrimitiveArray::Render (const Handle(OpenGl_Workspace)& theWorkspace
break; break;
} }
Handle(OpenGl_Texture) aPrevTexture;
const OpenGl_AspectFace* anAspectFace = theWorkspace->AspectFace (Standard_True); const OpenGl_AspectFace* anAspectFace = theWorkspace->AspectFace (Standard_True);
const OpenGl_AspectLine* anAspectLine = theWorkspace->AspectLine (Standard_True); const OpenGl_AspectLine* anAspectLine = theWorkspace->AspectLine (Standard_True);
const OpenGl_AspectMarker* anAspectMarker = theWorkspace->AspectMarker (myPArray->type == TelPointsArrayType); const OpenGl_AspectMarker* anAspectMarker = theWorkspace->AspectMarker (myPArray->type == TelPointsArrayType);
if (toDisableTexture)
{
aPrevTexture = theWorkspace->DisableTexture();
}
Tint aFrontLightingModel = anAspectFace->Context().IntFront.color_mask; Tint aFrontLightingModel = anAspectFace->IntFront.color_mask;
const TEL_COLOUR* anInteriorColor = &anAspectFace->Context().IntFront.matcol; const TEL_COLOUR* anInteriorColor = &anAspectFace->IntFront.matcol;
const TEL_COLOUR* anEdgeColor = &anAspectFace->AspectEdge()->Color(); const TEL_COLOUR* anEdgeColor = &anAspectFace->AspectEdge()->Color();
const TEL_COLOUR* aLineColor = (myPArray->type == TelPointsArrayType) ? &anAspectMarker->Color() : &anAspectLine->Color(); const TEL_COLOUR* aLineColor = (myPArray->type == TelPointsArrayType) ? &anAspectMarker->Color() : &anAspectLine->Color();
// Use highlight colors // Use highlight colors
if (theWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT) if (theWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT)
{ {
anEdgeColor = anInteriorColor = aLineColor = theWorkspace->HighlightColor; anEdgeColor = anInteriorColor = aLineColor = theWorkspace->HighlightColor;
aFrontLightingModel = 0; aFrontLightingModel = 0;
} }
DrawArray (aFrontLightingModel, DrawArray (aFrontLightingModel,
anAspectFace->Context().InteriorStyle, anAspectFace->InteriorStyle,
anAspectFace->Context().Edge, anAspectFace->Edge,
anInteriorColor, anInteriorColor,
aLineColor, aLineColor,
anEdgeColor, anEdgeColor,
&anAspectFace->Context().IntFront, &anAspectFace->IntFront,
theWorkspace); theWorkspace);
switch (myPArray->type) if (!aPrevTexture.IsNull())
{ {
case TelPointsArrayType: theWorkspace->EnableTexture (aPrevTexture);
case TelPolylinesArrayType:
case TelSegmentsArrayType:
{
if (theWorkspace->NamedStatus & OPENGL_NS_TEXTURE)
EnableTexture();
}
} }
} }

View File

@ -17,13 +17,12 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef OpenGl_PrimitiveArray_Header #ifndef OpenGl_PrimitiveArray_Header
#define OpenGl_PrimitiveArray_Header #define OpenGl_PrimitiveArray_Header
#include <OpenGl_VertexBuffer.hxx> #include <OpenGl_VertexBuffer.hxx>
#include <InterfaceGraphic_telem.hxx> #include <InterfaceGraphic_Graphic3d.hxx>
#include <Aspect_InteriorStyle.hxx> #include <Aspect_InteriorStyle.hxx>
#include <OpenGl_Element.hxx> #include <OpenGl_Element.hxx>

View File

@ -1,58 +0,0 @@
// Created on: 2011-03-18
// Created by: Anton POLETAEV
// Copyright (c) 2011-2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
#include <OpenGl_GlCore11.hxx>
#include <OpenGl_Context.hxx>
#include <OpenGl_ResourceTexture.hxx>
IMPLEMENT_STANDARD_HANDLE (OpenGl_ResourceTexture, OpenGl_Resource)
IMPLEMENT_STANDARD_RTTIEXT(OpenGl_ResourceTexture, OpenGl_Resource)
//=======================================================================
//function : OpenGl_ResourceTexture
//purpose :
//=======================================================================
OpenGl_ResourceTexture::OpenGl_ResourceTexture (const GLuint theId)
: myTextureId (theId)
{
//
}
//=======================================================================
//function : ~OpenGl_ResourceTexture
//purpose :
//=======================================================================
OpenGl_ResourceTexture::~OpenGl_ResourceTexture()
{
Release (NULL);
}
//=======================================================================
//function : Release
//purpose : free OpenGl memory allocated for texture resource
//=======================================================================
void OpenGl_ResourceTexture::Release (const OpenGl_Context* theGlCtx)
{
if (myTextureId != 0 && theGlCtx != NULL)
{
glDeleteTextures (1, &myTextureId);
myTextureId = 0;
}
}

View File

@ -112,11 +112,14 @@ void OpenGl_Structure::SetAspectLine (const CALL_DEF_CONTEXTLINE &AContext)
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
void OpenGl_Structure::SetAspectFace (const CALL_DEF_CONTEXTFILLAREA &AContext) void OpenGl_Structure::SetAspectFace (const Handle(OpenGl_Context)& theCtx,
const CALL_DEF_CONTEXTFILLAREA& theAspect)
{ {
if (!myAspectFace) if (!myAspectFace)
{
myAspectFace = new OpenGl_AspectFace(); myAspectFace = new OpenGl_AspectFace();
myAspectFace->SetContext( AContext ); }
myAspectFace->Init (theCtx, theAspect);
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@ -485,7 +488,7 @@ void OpenGl_Structure::ReleaseGlResources (const Handle(OpenGl_Context)& theGlCt
//======================================================================= //=======================================================================
//function : SetZLayer //function : SetZLayer
//purpose : //purpose :
//======================================================================= //=======================================================================
void OpenGl_Structure::SetZLayer (const Standard_Integer theLayerIndex) void OpenGl_Structure::SetZLayer (const Standard_Integer theLayerIndex)
@ -495,7 +498,7 @@ void OpenGl_Structure::SetZLayer (const Standard_Integer theLayerIndex)
//======================================================================= //=======================================================================
//function : GetZLayer //function : GetZLayer
//purpose : //purpose :
//======================================================================= //=======================================================================
Standard_Integer OpenGl_Structure::GetZLayer () const Standard_Integer OpenGl_Structure::GetZLayer () const

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef OpenGl_Structure_Header #ifndef OpenGl_Structure_Header
#define OpenGl_Structure_Header #define OpenGl_Structure_Header
@ -32,8 +31,10 @@
#include <OpenGl_Group.hxx> #include <OpenGl_Group.hxx>
#include <OpenGl_Matrix.hxx> #include <OpenGl_Matrix.hxx>
typedef NCollection_List<const OpenGl_Structure *> OpenGl_ListOfStructure; class OpenGl_Structure;
typedef NCollection_List<const OpenGl_Group *> OpenGl_ListOfGroup;
typedef NCollection_List<const OpenGl_Structure* > OpenGl_ListOfStructure;
typedef NCollection_List<const OpenGl_Group* > OpenGl_ListOfGroup;
class OpenGl_Structure : public OpenGl_Element class OpenGl_Structure : public OpenGl_Element
{ {
@ -49,7 +50,8 @@ public:
void SetDegenerateModel (const Standard_Integer AMode, const float ASkipRatio); void SetDegenerateModel (const Standard_Integer AMode, const float ASkipRatio);
void SetAspectLine (const CALL_DEF_CONTEXTLINE &AContext); void SetAspectLine (const CALL_DEF_CONTEXTLINE &AContext);
void SetAspectFace (const CALL_DEF_CONTEXTFILLAREA &AContext); void SetAspectFace (const Handle(OpenGl_Context)& theCtx,
const CALL_DEF_CONTEXTFILLAREA& theAspect);
void SetAspectMarker (const CALL_DEF_CONTEXTMARKER &AContext); void SetAspectMarker (const CALL_DEF_CONTEXTMARKER &AContext);
void SetAspectText (const CALL_DEF_CONTEXTTEXT &AContext); void SetAspectText (const CALL_DEF_CONTEXTTEXT &AContext);

View File

@ -17,11 +17,11 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_GlCore11.hxx> #include <OpenGl_GlCore11.hxx>
#include <OpenGl_Text.hxx> #include <OpenGl_Text.hxx>
#include <OpenGl_AspectText.hxx> #include <OpenGl_AspectText.hxx>
#include <OpenGl_Structure.hxx> #include <OpenGl_Structure.hxx>
#include <OpenGl_Workspace.hxx>
#include <GL/glu.h> // gluUnProject() #include <GL/glu.h> // gluUnProject()
@ -79,7 +79,7 @@ void OpenGl_Text::Render (const Handle(OpenGl_Workspace) &AWorkspace) const
// Use highlight colours // Use highlight colours
if( AWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT ) if( AWorkspace->NamedStatus & OPENGL_NS_HIGHLIGHT )
{ {
tcolor = scolor = AWorkspace->HighlightColor; tcolor = scolor = AWorkspace->HighlightColor;
} }
else else
@ -128,33 +128,33 @@ void OpenGl_Text::Render (const Handle(OpenGl_Workspace) &AWorkspace) const
int sWidth, sAscent, sDescent; int sWidth, sAscent, sDescent;
AWorkspace->StringSize(myString, sWidth, sAscent, sDescent); AWorkspace->StringSize(myString, sWidth, sAscent, sDescent);
objrefX = (float)myAttachPnt.xyz[0]; objrefX = (float)myAttachPnt.xyz[0];
objrefY = (float)myAttachPnt.xyz[1]; objrefY = (float)myAttachPnt.xyz[1];
objrefZ = (float)myAttachPnt.xyz[2]; objrefZ = (float)myAttachPnt.xyz[2];
status = gluProject (objrefX, objrefY, objrefZ, modelMatrix, projMatrix, viewport, status = gluProject (objrefX, objrefY, objrefZ, modelMatrix, projMatrix, viewport,
&winx1, &winy1, &winz1); &winx1, &winy1, &winz1);
winx = winx1; winx = winx1;
winy = winy1-sDescent; winy = winy1-sDescent;
winz = winz1+0.00001; winz = winz1+0.00001;
status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport, status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport,
&objX, &objY, &objZ); &objX, &objY, &objZ);
winx = winx1 + sWidth; winx = winx1 + sWidth;
winy = winy1-sDescent; winy = winy1-sDescent;
winz = winz1+0.00001; /* il vaut mieux F+B / 1000000 ? */ winz = winz1+0.00001; /* il vaut mieux F+B / 1000000 ? */
status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport, status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport,
&obj1X, &obj1Y, &obj1Z); &obj1X, &obj1Y, &obj1Z);
winx = winx1 + sWidth; winx = winx1 + sWidth;
winy = winy1 + sAscent; winy = winy1 + sAscent;
winz = winz1+0.00001; winz = winz1+0.00001;
status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport, status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport,
&obj2X, &obj2Y, &obj2Z); &obj2X, &obj2Y, &obj2Z);
winx = winx1; winx = winx1;
winy = winy1+ sAscent; winy = winy1+ sAscent;
winz = winz1+0.00001; winz = winz1+0.00001;
status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport, status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport,
&obj3X, &obj3Y, &obj3Z); &obj3X, &obj3Y, &obj3Z);
@ -169,15 +169,15 @@ void OpenGl_Text::Render (const Handle(OpenGl_Workspace) &AWorkspace) const
} }
case Aspect_TODT_DEKALE: case Aspect_TODT_DEKALE:
objrefX = (float)myAttachPnt.xyz[0]; objrefX = (float)myAttachPnt.xyz[0];
objrefY = (float)myAttachPnt.xyz[1]; objrefY = (float)myAttachPnt.xyz[1];
objrefZ = (float)myAttachPnt.xyz[2]; objrefZ = (float)myAttachPnt.xyz[2];
status = gluProject (objrefX, objrefY, objrefZ, modelMatrix, projMatrix, viewport, status = gluProject (objrefX, objrefY, objrefZ, modelMatrix, projMatrix, viewport,
&winx1, &winy1, &winz1); &winx1, &winy1, &winz1);
winx = winx1+1; winx = winx1+1;
winy = winy1+1; winy = winy1+1;
winz = winz1+0.00001; winz = winz1+0.00001;
status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport, status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport,
&objX, &objY, &objZ); &objX, &objY, &objZ);
@ -192,7 +192,7 @@ void OpenGl_Text::Render (const Handle(OpenGl_Workspace) &AWorkspace) const
winx = winx1-1; winx = winx1-1;
winy = winy1+1; winy = winy1+1;
status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport, status = gluUnProject (winx, winy, winz, modelMatrix, projMatrix, viewport,
&objX, &objY, &objZ); &objX, &objY, &objZ);
AWorkspace->RenderText( myString, 0, (float)objX, (float)objY,(float)objZ ); AWorkspace->RenderText( myString, 0, (float)objX, (float)objY,(float)objZ );
winx = winx1+1; winx = winx1+1;

View File

@ -0,0 +1,412 @@
// Created by: Kirill GAVRILOV
// Copyright (c) 2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
#include <OpenGl_Texture.hxx>
#include <OpenGl_Context.hxx>
#include <Graphic3d_TextureParams.hxx>
#include <Standard_Assert.hxx>
#include <Image_PixMap.hxx>
IMPLEMENT_STANDARD_HANDLE (OpenGl_Texture, OpenGl_Resource)
IMPLEMENT_STANDARD_RTTIEXT(OpenGl_Texture, OpenGl_Resource)
//! Function for getting power of to number larger or equal to input number.
//! @param theNumber number to 'power of two'
//! @param theThreshold upper threshold
//! @return power of two number
inline GLsizei getPowerOfTwo (const GLsizei theNumber,
const GLsizei theThreshold)
{
for (GLsizei p2 = 2; p2 <= theThreshold; p2 <<= 1)
{
if (theNumber <= p2)
{
return p2;
}
}
return theThreshold;
}
// =======================================================================
// function : OpenGl_Texture
// purpose :
// =======================================================================
OpenGl_Texture::OpenGl_Texture (const Handle(Graphic3d_TextureParams)& theParams)
: OpenGl_Resource(),
myTextureId (NO_TEXTURE),
myTarget (GL_TEXTURE_2D),
mySizeX (0),
mySizeY (0),
myTextFormat (GL_FLOAT),
myHasMipmaps (Standard_False),
myParams (theParams)
{
if (myParams.IsNull())
{
myParams = new Graphic3d_TextureParams();
}
}
// =======================================================================
// function : ~OpenGl_Texture
// purpose :
// =======================================================================
OpenGl_Texture::~OpenGl_Texture()
{
Release (NULL);
}
// =======================================================================
// function : HasMipmaps
// purpose :
// =======================================================================
const Standard_Boolean OpenGl_Texture::HasMipmaps() const
{
return myHasMipmaps;
}
// =======================================================================
// function : GetParams
// purpose :
// =======================================================================
const Handle(Graphic3d_TextureParams)& OpenGl_Texture::GetParams() const
{
return myParams;
}
// =======================================================================
// function : SetParams
// purpose :
// =======================================================================
void OpenGl_Texture::SetParams (const Handle(Graphic3d_TextureParams)& theParams)
{
myParams = theParams;
}
// =======================================================================
// function : Create
// purpose :
// =======================================================================
bool OpenGl_Texture::Create (const Handle(OpenGl_Context)& )
{
if (myTextureId == NO_TEXTURE)
{
glGenTextures (1, &myTextureId);
}
return myTextureId != NO_TEXTURE;
}
// =======================================================================
// function : Release
// purpose :
// =======================================================================
void OpenGl_Texture::Release (const OpenGl_Context* theGlCtx)
{
if (myTextureId == NO_TEXTURE)
{
return;
}
// application can not handle this case by exception - this is bug in code
Standard_ASSERT_RETURN (theGlCtx != NULL,
"OpenGl_Texture destroyed without GL context! Possible GPU memory leakage...",);
glDeleteTextures (1, &myTextureId);
myTextureId = NO_TEXTURE;
mySizeX = mySizeY = 0;
}
// =======================================================================
// function : Bind
// purpose :
// =======================================================================
void OpenGl_Texture::Bind (const Handle(OpenGl_Context)& theCtx,
const GLenum theTextureUnit) const
{
if (theCtx->IsGlGreaterEqual (1, 3))
{
theCtx->core13->glActiveTexture (theTextureUnit);
}
glBindTexture (myTarget, myTextureId);
}
// =======================================================================
// function : Unbind
// purpose :
// =======================================================================
void OpenGl_Texture::Unbind (const Handle(OpenGl_Context)& theCtx,
const GLenum theTextureUnit) const
{
if (theCtx->IsGlGreaterEqual (1, 3))
{
theCtx->core13->glActiveTexture (theTextureUnit);
}
glBindTexture (myTarget, NO_TEXTURE);
}
// =======================================================================
// function : Init
// purpose :
// =======================================================================
bool OpenGl_Texture::Init (const Handle(OpenGl_Context)& theCtx,
const Image_PixMap& theImage,
const Graphic3d_TypeOfTexture theType)
{
myHasMipmaps = Standard_False;
if (theImage.IsEmpty() || !Create (theCtx))
{
return false;
}
GLenum aTextureFormat = GL_RGBA8;
GLenum aPixelFormat = 0;
GLenum aDataType = 0;
switch (theImage.Format())
{
case Image_PixMap::ImgGrayF:
{
aTextureFormat = GL_ALPHA8; // GL_R8, GL_R32F
aPixelFormat = GL_ALPHA; // GL_RED
aDataType = GL_FLOAT;
break;
}
case Image_PixMap::ImgRGBAF:
{
aTextureFormat = GL_RGBA8; // GL_RGBA32F
aPixelFormat = GL_RGBA;
aDataType = GL_FLOAT;
break;
}
case Image_PixMap::ImgBGRAF:
{
if (!theCtx->IsGlGreaterEqual (1, 2) && !theCtx->extBgra)
{
return false;
}
aTextureFormat = GL_RGBA8; // GL_RGBA32F
aPixelFormat = GL_BGRA; // equals to GL_BGRA_EXT
aDataType = GL_FLOAT;
break;
}
case Image_PixMap::ImgRGBF:
{
aTextureFormat = GL_RGB8; // GL_RGB32F
aPixelFormat = GL_RGB;
aDataType = GL_FLOAT;
break;
}
case Image_PixMap::ImgBGRF:
{
aTextureFormat = GL_RGB8; // GL_RGB32F
aPixelFormat = GL_BGR; // equals to GL_BGR_EXT
aDataType = GL_FLOAT;
break;
}
case Image_PixMap::ImgRGBA:
{
aTextureFormat = GL_RGBA8;
aPixelFormat = GL_RGBA;
aDataType = GL_UNSIGNED_BYTE;
break;
}
case Image_PixMap::ImgBGRA:
{
if (!theCtx->IsGlGreaterEqual (1, 2) && !theCtx->extBgra)
{
return false;
}
aTextureFormat = GL_RGBA8;
aPixelFormat = GL_BGRA; // equals to GL_BGRA_EXT
aDataType = GL_UNSIGNED_BYTE;
break;
}
case Image_PixMap::ImgRGB32:
{
aTextureFormat = GL_RGB8;
aPixelFormat = GL_RGBA;
aDataType = GL_UNSIGNED_BYTE;
break;
}
case Image_PixMap::ImgBGR32:
{
if (!theCtx->IsGlGreaterEqual (1, 2) && !theCtx->extBgra)
{
return false;
}
aTextureFormat = GL_RGB8;
aPixelFormat = GL_BGRA; // equals to GL_BGRA_EXT
aDataType = GL_UNSIGNED_BYTE;
break;
}
case Image_PixMap::ImgRGB:
{
aTextureFormat = GL_RGB8;
aPixelFormat = GL_RGB;
aDataType = GL_UNSIGNED_BYTE;
break;
}
case Image_PixMap::ImgBGR:
{
if (!theCtx->IsGlGreaterEqual (1, 2) && !theCtx->extBgra)
{
return false;
}
aTextureFormat = GL_RGB8;
aPixelFormat = GL_BGR; // equals to GL_BGR_EXT
aDataType = GL_UNSIGNED_BYTE;
break;
}
case Image_PixMap::ImgGray:
{
aTextureFormat = GL_ALPHA8; // GL_R8
aPixelFormat = GL_ALPHA; // GL_RED
aDataType = GL_UNSIGNED_BYTE;
break;
}
default:
{
return false;
}
}
const GLsizei aMaxSize = theCtx->MaxTextureSize();
const GLsizei aWidth = (GLsizei )theImage.SizeX();
const GLsizei aHeight = (GLsizei )theImage.SizeY();
// Notice that formally general NPOT textures are required by OpenGL 2.0 specifications
// however some hardware (NV30 - GeForce FX, RadeOn 9xxx and Xxxx) supports GLSL but not NPOT!
// Trying to create NPOT rextures on such hardware will not fail
// but driver will fall back into software rendering,
const bool toForceP2 = !theCtx->IsGlGreaterEqual (3, 0) && !theCtx->arbNPTW;
const GLsizei aWidthOut = toForceP2 ? getPowerOfTwo (aWidth, aMaxSize) : Min (aWidth, aMaxSize);
const GLsizei aHeightOut = toForceP2 ? getPowerOfTwo (aHeight, aMaxSize) : Min (aHeight, aMaxSize);
GLint aTestWidth = 0;
GLint aTestHeight = 0;
glPixelStorei (GL_UNPACK_ALIGNMENT, 1); // ensure alignment will not screw up the party
switch (theType)
{
case Graphic3d_TOT_1D:
{
myTarget = GL_TEXTURE_1D;
Bind (theCtx);
glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
Image_PixMap aCopy;
GLvoid* aDataPtr = (GLvoid* )theImage.Data();
if (aWidth != aWidthOut)
{
if (!aCopy.InitTrash (theImage.Format(), Standard_Size(aWidthOut), 1)
|| gluScaleImage (aPixelFormat,
aWidth, 1, aDataType, theImage.Data(),
aWidthOut, 1, aDataType, aCopy.ChangeData()) != 0)
{
Unbind (theCtx);
return false;
}
aDataPtr = (GLvoid* )aCopy.Data();
}
// use proxy to check texture could be created or not
glTexImage1D (GL_PROXY_TEXTURE_1D, 0, aTextureFormat,
aWidthOut, 0,
aPixelFormat, aDataType, NULL);
glGetTexLevelParameteriv (GL_PROXY_TEXTURE_2D, 0, GL_TEXTURE_WIDTH, &aTestWidth);
if (aTestWidth == 0)
{
// no memory or broken input parameters
Unbind (theCtx);
return false;
}
glTexImage1D (GL_TEXTURE_1D, 0, aTextureFormat,
aWidthOut, 0,
aPixelFormat, aDataType, aDataPtr);
Unbind (theCtx);
return true;
}
case Graphic3d_TOT_2D:
{
myTarget = GL_TEXTURE_2D;
Bind (theCtx);
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
Image_PixMap aCopy;
GLvoid* aDataPtr = (GLvoid* )theImage.Data();
if (aWidth != aWidthOut || aHeight != aHeightOut)
{
// scale texture
if (!aCopy.InitTrash (theImage.Format(), Standard_Size(aWidthOut), Standard_Size(aHeightOut))
|| gluScaleImage (aPixelFormat,
aWidth, aHeight, aDataType, theImage.Data(),
aWidthOut, aHeightOut, aDataType, aCopy.ChangeData()) != 0)
{
Unbind (theCtx);
return false;
}
aDataPtr = (GLvoid* )aCopy.Data();
}
// use proxy to check texture could be created or not
glTexImage2D (GL_PROXY_TEXTURE_2D, 0, aTextureFormat,
aWidthOut, aHeightOut, 0,
aPixelFormat, aDataType, NULL);
glGetTexLevelParameteriv (GL_PROXY_TEXTURE_2D, 0, GL_TEXTURE_WIDTH, &aTestWidth);
glGetTexLevelParameteriv (GL_PROXY_TEXTURE_2D, 0, GL_TEXTURE_HEIGHT, &aTestHeight);
if (aTestWidth == 0 || aTestHeight == 0)
{
// no memory or broken input parameters
Unbind (theCtx);
return false;
}
glTexImage2D (GL_TEXTURE_2D, 0, aTextureFormat,
aWidthOut, aHeightOut, 0,
aPixelFormat, aDataType, aDataPtr);
Unbind (theCtx);
return true;
}
case Graphic3d_TOT_2D_MIPMAP:
{
myTarget = GL_TEXTURE_2D;
myHasMipmaps = Standard_True;
Bind (theCtx);
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR);
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
bool isCreated = gluBuild2DMipmaps (GL_TEXTURE_2D, aTextureFormat,
aWidth, aHeight,
aPixelFormat, aDataType, theImage.Data()) == 0;
Unbind (theCtx);
return isCreated;
}
default:
{
return false;
}
}
}

View File

@ -0,0 +1,107 @@
// Created by: Kirill GAVRILOV
// Copyright (c) 2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_Texture_H__
#define _OpenGl_Texture_H__
#include <OpenGl_GlCore13.hxx>
#include <OpenGl_Resource.hxx>
#include <Handle_OpenGl_Texture.hxx>
#include <Graphic3d_TypeOfTexture.hxx>
#include <Handle_Graphic3d_TextureParams.hxx>
class Handle(OpenGl_Context);
class OpenGl_Context;
class Image_PixMap;
//! Texture resource.
class OpenGl_Texture : public OpenGl_Resource
{
public:
//! Helpful constants
static const GLuint NO_TEXTURE = 0;
public:
//! Create uninitialized VBO.
Standard_EXPORT OpenGl_Texture (const Handle(Graphic3d_TextureParams)& theParams = NULL);
//! Destroy object.
Standard_EXPORT virtual ~OpenGl_Texture();
//! @return true if current object was initialized
inline bool IsValid() const
{
return myTextureId != NO_TEXTURE;
}
//! @return target to which the texture is bound (GL_TEXTURE_1D, GL_TEXTURE_2D)
inline GLenum GetTarget() const
{
return myTarget;
}
//! Creates Texture id if not yet generated.
//! Data should be initialized by another method.
Standard_EXPORT bool Create (const Handle(OpenGl_Context)& theCtx);
//! Destroy object - will release GPU memory if any.
Standard_EXPORT virtual void Release (const OpenGl_Context* theCtx);
//! Bind this Texture to specified unit.
Standard_EXPORT void Bind (const Handle(OpenGl_Context)& theCtx,
const GLenum theTextureUnit = GL_TEXTURE0) const;
//! Unbind texture from specified unit.
Standard_EXPORT void Unbind (const Handle(OpenGl_Context)& theCtx,
const GLenum theTextureUnit = GL_TEXTURE0) const;
//! Notice that texture will be unbound after this call.
Standard_EXPORT bool Init (const Handle(OpenGl_Context)& theCtx,
const Image_PixMap& theImage,
const Graphic3d_TypeOfTexture theType);
//! @return true if texture was generated within mipmaps
Standard_EXPORT const Standard_Boolean HasMipmaps() const;
//! @return assigned texture parameters (not necessary applied)
Standard_EXPORT const Handle(Graphic3d_TextureParams)& GetParams() const;
//! @param texture parameters
Standard_EXPORT void SetParams (const Handle(Graphic3d_TextureParams)& theParams);
protected:
GLuint myTextureId; //!< GL resource ID
GLenum myTarget; //!< GL_TEXTURE_1D/GL_TEXTURE_2D
GLsizei mySizeX; //!< texture width
GLsizei mySizeY; //!< texture height
GLint myTextFormat; //!< texture format - GL_RGB, GL_RGBA,...
Standard_Boolean myHasMipmaps; //!< flag indicates that texture was uploaded with mipmaps
Handle(Graphic3d_TextureParams) myParams; //!< texture parameters
public:
DEFINE_STANDARD_RTTI(OpenGl_Texture) // Type definition
};
#endif // _OpenGl_Texture_H__

View File

@ -1,847 +0,0 @@
// Copyright (c) 1999-2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
/*
* Fonction
* ~~~~~~~~
* Gestion des textures sous OpenGL
*
*
* Notes
* ~~~~~
* Les textures sont toujours initialisee avec des parametres par defaut
* texture 1D: WRAP_S = CLAMP
* MAG_FILTER = NEAREST
* generation de texture automatique en OBJECT_LINEAR
* rendu avec DECAL
*
* texture 2D: WRAP_S/T = REPEAT
* MAG/MIN_FILTER = LINEAR
* generation de texture automatique en OBJECT_LINEAR
* rendu avec MODULATE
*
* texture 2D MipMap: WRAP_S/T = REPEAT
* MAG_FILTER = LINEAR
* MIN_FILTER = LINEAR_MIPMAP_NEAREST
* generation de texture automatique en OBJECT_LINEAR
* rendu avec MODULATE
*
* Historique des modifications
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* 22-05-97: PCT ; Creation
* 18-06-97: FMN ; Ajout entete
* 20-06-97: PCT ; Correction bug parametres par defaut texture 1D
* 30-06-97: PCT ; Correction bug rechargement de la texture courante
* 04-07-97: PCT ; suppression de l'utilisation de libimage.a de SGI
* 01-08-97: PCT ; suppression InitializeTextureBox()
* 04-08-97: FMN,PCT ; Portage WNT
* 05-08-97: FMN ; ajout GetTextureData...
* 10-09-97: PCT ; ajout commentaires. GetTexture() ne doit pas
* etre utilisee dans Cas.Cade ( le chargement est
* fait par Graphic3d )
* 06-10-97: FMN ; Portage HP
* 14-10-97: FMN ; Ajout OpenGl_Extension
* 22-10-97: FMN ; Meilleure gestion de l'extension glXGetCurrentDisplayEXT
* 04-11-97: FMN ; Gestion des differentes versions GLX
* 19-11-97: FMN ; Ajout GetCurrentDisplay plus simple que glXGetCurrentDisplayEXT
* 04-12-97: FMN ; On suppose que l'on travaille en OpenGL1.1 (cf OpenGl_Extension)
* 17-12-97: FMN ; Probleme compilation SGI
* 17-12-97: FMN ; Probleme sur Optimisation sur MyBindTextureEXT()
* Le test sur la texture courante doit tenir compte du contexte.
* 22-07-98: FGU ; Ajout fonctions TransferTexture_To_Data() et TransferData_To_Texture()
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <OpenGl_GlCore11.hxx>
#include <OpenGl_Display.hxx>
#include <OpenGl_TextureBox.hxx>
#include <OpenGl_ResourceTexture.hxx>
#include <OpenGl_Context.hxx>
#include <GL/glu.h> // gluBuild2DMipmaps()
#include <NCollection_Vector.hxx>
typedef enum {TEXDATA_NONE, TEXDATA_1D, TEXDATA_2D, TEXDATA_2DMM} texDataStatus;
typedef enum {TEX_NONE, TEX_ALLOCATED} texStatus;
typedef GLfloat SizeType[4];
typedef int TextureDataID;
#define TEXTUREDATA_ERROR -1
struct texData
{
char imageFileName[128];
int imageWidth, imageHeight;
GLubyte *image;
texDataStatus status;
GLint type;
int share_count;
DEFINE_STANDARD_ALLOC
};
struct contextData
{
GLuint number;
GLDRAWABLE drawable;
GLCONTEXT context;
};
struct texDraw
{
TextureDataID data;
NCollection_Vector<contextData> contextdata;
texStatus status;
GLint Gen;
GLint Light;
GLint Wrap;
GLfloat Plane1[4];
GLfloat Plane2[4];
GLint Render;
GLfloat scalex, scaley;
GLfloat transx, transy;
GLfloat angle;
DEFINE_STANDARD_ALLOC
};
/*----------------------------------------------------------------------*/
/*
* Variables statiques
*/
static NCollection_Vector<texDraw> textab;
static NCollection_Vector<texData> texdata;
static TextureDataID current_texture_data = TEXTUREDATA_ERROR;
static TextureID current_texture = TEXTUREBOX_ERROR;
static GLfloat sgenparams[] = { 1.0 ,0.0 ,0.0 ,0.0};
static GLfloat tgenparams[] = { 0.0 ,1.0 ,0.0 ,0.0};
static GLenum status2type[] = { GL_NONE, GL_TEXTURE_1D, GL_TEXTURE_2D, GL_TEXTURE_2D };
/*----------------------------------------------------------------------*/
/*
* Fonctions privees
*/
/*----------------------------------------------------------------------*/
/*
* recherche l'existence de datas de texture par son nom
*/
static TextureDataID FindTextureData(char *FileName)
{
for (int i = 0; i < texdata.Length(); i++)
{
if ( texdata(i).status != TEXDATA_NONE && strcmp(FileName, texdata(i).imageFileName) == 0 )
{
return i;
}
}
return TEXTUREDATA_ERROR;
}
/*----------------------------------------------------------------------*/
/*
* recherche un emplacement de data texture libre
*/
static TextureDataID FindFreeTextureData(void)
{
for (int i = 0; i < texdata.Length(); i++)
{
if (texdata(i).status == TEXDATA_NONE)
{
return i;
}
}
texData aTexData;
texdata.Append(aTexData);
return texdata.Length() - 1;
}
/*----------------------------------------------------------------------*/
/*
* recherche un emplacement de texture libre
*/
static TextureID FindFreeTexture(void)
{
for (int i = 0; i < textab.Length(); i++)
{
if (textab(i).status == TEX_NONE)
{
return i;
}
}
texDraw aTexDraw;
textab.Append(aTexDraw);
return textab.Length() - 1;
}
/*----------------------------------------------------------------------*/
/*
* regarde si la texture a ete definie pour le contexte courant
*/
static int FindTextureContext(TextureID ID)
{
int i;
GLCONTEXT cur = GET_GL_CONTEXT();
for (i=0; i<textab(ID).contextdata.Length(); i++)
if (textab(ID).contextdata(i).context == cur)
return i;
return TEXTUREBOX_ERROR;
}
/*----------------------------------------------------------------------*/
/*
* chargement d'une texture suivant son type
*/
static void LoadTexture(TextureID ID)
{
TextureDataID data;
data = textab(ID).data;
switch (texdata(data).status)
{
case TEXDATA_1D:
glTexImage1D(GL_TEXTURE_1D, 0, 4,
texdata(data).imageWidth, 0,
GL_RGBA, GL_UNSIGNED_BYTE, texdata(data).image);
break;
case TEXDATA_2D:
glTexImage2D(GL_TEXTURE_2D, 0, 4,
texdata(data).imageWidth, texdata(data).imageHeight, 0,
GL_RGBA, GL_UNSIGNED_BYTE, texdata(data).image);
break;
case TEXDATA_2DMM:
gluBuild2DMipmaps(GL_TEXTURE_2D, 4,
texdata(data).imageWidth,
texdata(data).imageHeight,
GL_RGBA, GL_UNSIGNED_BYTE, texdata(data).image);
break;
default:
break;
}
}
/*----------------------------------------------------------------------*/
/*
* les parametres d'initialisation d'une texture
* NE PAS METTRE DANS UNE DISPLAY LIST POUR L'INSTANT ( pb avec les matrices )
*/
static void SetTextureParam(TextureID ID)
{
GLint cur_matrix;
TextureDataID data;
data = textab(ID).data;
glGetIntegerv(GL_MATRIX_MODE, &cur_matrix);
/*
* MISE EN PLACE DE LA MATRICE DE TEXTURE
*/
glMatrixMode(GL_TEXTURE);
glLoadIdentity();
/* if (textab(ID).Gen != GL_SPHERE_MAP)
{*/
glScalef(textab(ID).scalex, textab(ID).scaley, 1.0);
glTranslatef(-textab(ID).transx, -textab(ID).transy, 0.0);
glRotatef(-textab(ID).angle, 0.0, 0.0, 1.0);
/*}*/
/*
* GENERATION AUTOMATIQUE DE TEXTURE
*/
switch (textab(ID).Gen)
{
case GL_OBJECT_LINEAR:
glTexGeni(GL_S, GL_TEXTURE_GEN_MODE, GL_OBJECT_LINEAR);
glTexGenfv(GL_S, GL_OBJECT_PLANE, textab(ID).Plane1);
if (texdata(data).status != TEXDATA_1D)
{
glTexGeni(GL_T, GL_TEXTURE_GEN_MODE, GL_OBJECT_LINEAR);
glTexGenfv(GL_T, GL_OBJECT_PLANE, textab(ID).Plane2);
}
break;
case GL_SPHERE_MAP:
glTexGeni(GL_S, GL_TEXTURE_GEN_MODE, GL_SPHERE_MAP);
if (texdata(data).status != TEXDATA_1D)
glTexGeni(GL_T, GL_TEXTURE_GEN_MODE, GL_SPHERE_MAP);
break;
case GL_EYE_LINEAR:
glMatrixMode(GL_MODELVIEW);
glPushMatrix();
glLoadIdentity();
glTexGeni(GL_S, GL_TEXTURE_GEN_MODE, GL_EYE_LINEAR);
glTexGenfv(GL_S, GL_EYE_PLANE, textab(ID).Plane1);
if (texdata(data).status != TEXDATA_1D)
{
glTexGeni(GL_T, GL_TEXTURE_GEN_MODE, GL_EYE_LINEAR);
glTexGenfv(GL_T, GL_EYE_PLANE, textab(ID).Plane2);
}
glPopMatrix();
break;
}
/*
* RENDU DE LA TEXTURE AVEC LES LUMIERES
*/
glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, textab(ID).Light);
/*
* LISSAGE DE LA TEXTURE
*/
switch (texdata(data).status)
{
case TEXDATA_1D:
case TEXDATA_2D:
glTexParameteri(texdata(data).type, GL_TEXTURE_MAG_FILTER, textab(ID).Render);
glTexParameteri(texdata(data).type, GL_TEXTURE_MIN_FILTER, textab(ID).Render);
break;
case TEXDATA_2DMM:
if (textab(ID).Render == GL_NEAREST)
{
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST_MIPMAP_NEAREST);
}
else
{
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_NEAREST);
}
break;
default:
break;
}
/*
* WRAP DE LA TEXTURE
*/
switch (texdata(data).status)
{
case TEXDATA_1D:
glTexParameteri(GL_TEXTURE_1D, GL_TEXTURE_WRAP_S, textab(ID).Wrap);
break;
case TEXDATA_2D:
case TEXDATA_2DMM:
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, textab(ID).Wrap);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, textab(ID).Wrap);
break;
default:
break;
}
glMatrixMode(cur_matrix);
}
/*----------------------------------------------------------------------*/
/*
* simulation du glGenTexturesEXT pour un context
*/
static void MyGenTextureEXT (TextureID ID)
{
TextureDataID data = textab(ID).data;
contextData aContextData;
aContextData.context = GET_GL_CONTEXT();
aContextData.drawable = GET_GLDEV_CONTEXT();
glGenTextures (1, &aContextData.number);
textab(ID).contextdata.Append(aContextData);
glBindTexture (texdata(data).type, aContextData.number);
LoadTexture (ID);
}
/*----------------------------------------------------------------------*/
/*
* simulation du glBindTextureEXT
*/
static void MyBindTextureEXT (TextureID ID, int Context)
{
TextureDataID data = textab(ID).data;
if (texdata(data).status == TEXDATA_NONE)
return;
GLenum aParamName = texdata(data).status == TEXDATA_1D ?
GL_TEXTURE_BINDING_1D : GL_TEXTURE_BINDING_2D;
GLint aCurrTex = -1;
glGetIntegerv (aParamName, &aCurrTex);
if (textab(ID).contextdata(Context).number != aCurrTex)
{
glBindTexture (texdata(data).type, textab(ID).contextdata(Context).number);
}
}
/*----------------------------------------------------------------------*/
/*
* installation de la texture pour le dernier contexte
*/
static int InstallTextureInContext(TextureID ID)
{
#ifdef PRINT
printf("InstallTextureInContext::installation de la texture dans le context\n");
#endif
MyGenTextureEXT(ID);
SetTextureParam(ID);
#ifdef PRINT
printf("InstallTextureInContext::context ok\n");
#endif
return 0;
}
/*----------------------------------------------------------------------*/
static TextureID GetTextureData(char *FileName, texDataStatus status, const GLint width, const GLint height, const void *data)
{
TextureDataID i;
TextureID j;
/* essait de trouver la texture */
i = FindTextureData(FileName);
if (i == TEXTUREDATA_ERROR)
{
#ifdef PRINT
printf("GetTextureData::la texture %s n'existe pas => chargement\n", FileName);
#endif
/* creation d'une texture */
i = FindFreeTextureData();
if (i == TEXTUREDATA_ERROR) return TEXTUREBOX_ERROR;
texdata(i).share_count = 0;
strcpy(texdata(i).imageFileName, FileName);
texdata(i).image = new GLubyte[width*height*4];
memcpy(texdata(i).image, data, (width*height*4));
texdata(i).imageWidth = width;
texdata(i).imageHeight = height;
if (texdata(i).image == NULL) return TEXTUREBOX_ERROR;
texdata(i).status = status;
texdata(i).type = status2type[status];
}
j = FindFreeTexture();
if (j != TEXTUREBOX_ERROR)
{
#ifdef PRINT
printf("GetTextureData::installation texture pour obj %d\n", j);
#endif
textab(j).contextdata.Clear();
textab(j).data = i;
textab(j).status = TEX_ALLOCATED;
texdata(i).share_count++;
SetTextureDefaultParams(j);
#ifdef PRINT
printf("GetTextureData::texture %s(%d) texture %d count=%d\n", texdata(i).imageFileName, i, j, texdata(i).share_count);
#endif
}
else
if (texdata(i).share_count != 0)
delete [] texdata(i).image;
return j;
}
/*----------------------------------------------------------------------*/
/*
* Fonctions publiques
*/
/*----------------------------------------------------------------------*/
GLboolean IsTextureValid(TextureID ID)
{
if ( (ID < 0) || (ID >= textab.Length()) )
return GL_FALSE;
if (textab.Length() > 0)
{
return textab(ID).status == TEX_ALLOCATED;
}
else
{
return GL_FALSE;
}
}
/*----------------------------------------------------------------------*/
TextureID GetTextureData1D(char *FileName, const GLint width, const GLint height, const void *data)
{
#ifdef PRINT
printf("GetTextureData1D::loading 1d %s \n", FileName);
#endif
return GetTextureData(FileName, TEXDATA_1D, width, height, data);
}
/*----------------------------------------------------------------------*/
TextureID GetTextureData2D(char *FileName, const GLint width, const GLint height, const void *data)
{
#ifdef PRINT
printf("GetTextureData2D::loading 2d %s \n", FileName);
#endif
return GetTextureData(FileName, TEXDATA_2D, width, height, data);
}
/*----------------------------------------------------------------------*/
TextureID GetTextureData2DMipMap(char *FileName, const GLint width, const GLint height, const void *data)
{
#ifdef PRINT
printf("GetTextureData2DMipMap::loading 2dmm %s \n", FileName);
#endif
return GetTextureData(FileName, TEXDATA_2DMM, width, height, data);
}
/*----------------------------------------------------------------------*/
void SetCurrentTexture(TextureID ID)
{
int context;
if (!IsTextureValid(ID)) return;
context = FindTextureContext(ID);
/* la texture n'existe pas dans ce contexte */
if (context == TEXTUREBOX_ERROR)
{
#ifdef PRINT
printf("SetCurrentTexture::installation texture %d dans context\n", ID);
#endif
/* si on a une erreur pendant l'installation dans le context
* alors on installe la texture sans bind */
if (InstallTextureInContext(ID) == TEXTUREBOX_ERROR)
{
LoadTexture(ID);
SetTextureParam(ID);
}
}
/*oui, alors on bind directement */
else
{
#ifdef PRINT
printf("SetCurrentTexture: utilisation du bind %d\n", ID);
#endif
MyBindTextureEXT(ID, context);
SetTextureParam(ID);
}
current_texture = ID;
current_texture_data = textab(ID).data;
}
/*----------------------------------------------------------------------*/
void FreeTexture (const Handle(OpenGl_Context)& theContext,
TextureID ID)
{
if (!IsTextureValid (ID))
{
return;
}
TextureDataID data = textab(ID).data;
texdata(data).share_count--;
if (texdata(data).share_count == 0)
{
// release texture data
delete [] texdata(data).image;
// liberation de la texture dans tous les contextes
for (int i = 0; i < textab(ID).contextdata.Length(); ++i)
{
Handle(OpenGl_ResourceTexture) aResource = new OpenGl_ResourceTexture (textab(ID).contextdata(i).number);
if (!theContext.IsNull())
{
theContext->DelayedRelease (aResource);
}
}
texdata(data).status = TEXDATA_NONE;
textab(ID).contextdata.Clear();
}
textab(ID).status = TEX_NONE;
current_texture_data = TEXTUREDATA_ERROR;
}
/*----------------------------------------------------------------------*/
void EnableTexture(void)
{
if (!IsTextureValid(current_texture)) return;
switch (texdata(current_texture_data).status)
{
case TEXDATA_1D:
if (textab(current_texture).Gen != GL_NONE)
glEnable(GL_TEXTURE_GEN_S);
glEnable(GL_TEXTURE_1D);
break;
case TEXDATA_2D:
case TEXDATA_2DMM:
if (textab(current_texture).Gen != GL_NONE)
{
glEnable(GL_TEXTURE_GEN_S);
glEnable(GL_TEXTURE_GEN_T);
}
glEnable(GL_TEXTURE_2D);
break;
default:
break;
}
}
/*----------------------------------------------------------------------*/
void DisableTexture(void)
{
if ( !IsTextureEnabled() )
return;
if ( !IsTextureValid( current_texture ) )
return;
switch (texdata(current_texture_data).status)
{
case TEXDATA_1D:
if (textab(current_texture).Gen != GL_NONE)
glDisable(GL_TEXTURE_GEN_S);
glDisable(GL_TEXTURE_1D);
break;
case TEXDATA_2D:
case TEXDATA_2DMM:
if (textab(current_texture).Gen != GL_NONE)
{
glDisable(GL_TEXTURE_GEN_S);
glDisable(GL_TEXTURE_GEN_T);
}
glDisable(GL_TEXTURE_2D);
break;
default:
break;
}
}
/*----------------------------------------------------------------------*/
GLboolean IsTextureEnabled(void)
{
GLboolean isEnabled1D= GL_FALSE, isEnabled2D= GL_FALSE;
glGetBooleanv( GL_TEXTURE_1D, &isEnabled1D );
glGetBooleanv( GL_TEXTURE_2D, &isEnabled2D );
return isEnabled1D || isEnabled2D;
}
/*----------------------------------------------------------------------*/
void SetTextureModulate(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Light = GL_MODULATE;
}
/*----------------------------------------------------------------------*/
void SetTextureDecal(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Light = GL_DECAL;
}
/*----------------------------------------------------------------------*/
void SetTextureClamp(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Wrap = GL_CLAMP;
}
/*----------------------------------------------------------------------*/
void SetTextureRepeat(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Wrap = GL_REPEAT;
}
/*----------------------------------------------------------------------*/
/* gestion de la facon d'appliquer la texture */
void SetModeObject(TextureID ID, const GLfloat sparams[4], const GLfloat tparams[4])
{
if (!IsTextureValid(ID)) return;
textab(ID).Gen = GL_OBJECT_LINEAR;
if (sparams != NULL) memcpy(textab(ID).Plane1, sparams, sizeof(sgenparams));
else memcpy(textab(ID).Plane1, sgenparams, sizeof(sgenparams));
if (texdata(textab(ID).data).status != TEXDATA_1D) {
if (tparams != NULL) memcpy(textab(ID).Plane2, tparams, sizeof(tgenparams));
else memcpy(textab(ID).Plane2, tgenparams, sizeof(tgenparams));
}
}
/*----------------------------------------------------------------------*/
void SetModeSphere(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Gen = GL_SPHERE_MAP;
}
/*----------------------------------------------------------------------*/
void SetModeEye(TextureID ID, const GLfloat sparams[4], const GLfloat tparams[4])
{
if (!IsTextureValid(ID)) return;
textab(ID).Gen = GL_EYE_LINEAR;
if (sparams != NULL) memcpy(textab(ID).Plane1, sparams, sizeof(sgenparams));
else memcpy(textab(ID).Plane1, sgenparams, sizeof(sgenparams));
if (texdata(textab(ID).data).status != TEXDATA_1D) {
if (tparams != NULL) memcpy(textab(ID).Plane2, tparams, sizeof(tgenparams));
else memcpy(textab(ID).Plane2, tgenparams, sizeof(tgenparams));
}
}
/*----------------------------------------------------------------------*/
void SetModeManual(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Gen = GL_NONE;
}
/*----------------------------------------------------------------------*/
void SetRenderNearest(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Render = GL_NEAREST;
}
/*----------------------------------------------------------------------*/
void SetRenderLinear(TextureID ID)
{
if (!IsTextureValid(ID)) return;
textab(ID).Render = GL_LINEAR;
}
/*----------------------------------------------------------------------*/
void SetTexturePosition(TextureID ID,
GLfloat scalex, GLfloat scaley,
GLfloat transx, GLfloat transy,
GLfloat angle)
{
textab(ID).scalex = scalex;
textab(ID).scaley = scaley;
textab(ID).transx = transx;
textab(ID).transy = transy;
textab(ID).angle = angle;
}
/*----------------------------------------------------------------------*/
void SetTextureDefaultParams(TextureID ID)
{
if (!IsTextureValid(ID)) return;
#ifdef PRINT
printf("SetTextureDefaultParams::set parm par defaut textures\n");
#endif
textab(ID).scalex = 1.0;
textab(ID).scaley = 1.0;
textab(ID).transx = 0.0;
textab(ID).transy = 0.0;
textab(ID).angle = 0.0;
textab(ID).Gen = GL_OBJECT_LINEAR;
textab(ID).Light = texdata(textab(ID).data).status == TEXDATA_1D ? GL_DECAL : GL_MODULATE;
textab(ID).Wrap = texdata(textab(ID).data).status == TEXDATA_1D ? GL_CLAMP : GL_REPEAT;
memcpy(textab(ID).Plane1, sgenparams, sizeof(sgenparams));
memcpy(textab(ID).Plane2, tgenparams, sizeof(tgenparams));
textab(ID).Render = texdata(textab(ID).data).status == TEXDATA_1D ? GL_NEAREST : GL_LINEAR;
}
/*----------------------------------------------------------------------*/
/* Transfere de donnee des donnees internes a la structure TransferData */
void TransferTexture_To_Data(TextureID ID, TextureData *TransfDt)
{
/* affectations */
strcpy(TransfDt->path, texdata(textab(ID).data).imageFileName);
TransfDt->gen = textab(ID).Gen;
TransfDt->wrap = textab(ID).Wrap;
TransfDt->render = textab(ID).Light;
TransfDt->scalex = textab(ID).scalex;
TransfDt->scaley = textab(ID).scaley;
TransfDt->transx = textab(ID).transx;
TransfDt->transy = textab(ID).transy;
TransfDt->angle = textab(ID).angle;
memcpy(TransfDt->plane1, textab(ID).Plane1, sizeof(SizeType));
memcpy(TransfDt->plane2, textab(ID).Plane2, sizeof(SizeType));
}

View File

@ -1,142 +0,0 @@
// Copyright (c) 1999-2012 OPEN CASCADE SAS
//
// The content of this file is subject to the Open CASCADE Technology Public
// License Version 6.5 (the "License"). You may not use the content of this file
// except in compliance with the License. Please obtain a copy of the License
// at http://www.opencascade.org and read it completely before using this file.
//
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
//
// The Original Code and all software distributed under the License is
// distributed on an "AS IS" basis, without warranty of any kind, and the
// Initial Developer hereby disclaims all such warranties, including without
// limitation, any warranties of merchantability, fitness for a particular
// purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License.
/*
* Fonction
* ~~~~~~~~
* Gestion des textures sous OpenGL
*
*
* Notes
* ~~~~~
* Les textures sont toujours initialisee avec des parametres par defaut
* texture 1D: WRAP_S = CLAMP
* MAG_FILTER = NEAREST
* generation de texture automatique en OBJECT_LINEAR
* rendu avec DECAL
*
* texture 2D: WRAP_S/T = REPEAT
* MAG/MIN_FILTER = LINEAR
* generation de texture automatique en OBJECT_LINEAR
* rendu avec MODULATE
*
* texture 2D MipMap: WRAP_S/T = REPEAT
* MAG_FILTER = LINEAR
* MIN_FILTER = LINEAR_MIPMAP_NEAREST
* generation de texture automatique en OBJECT_LINEAR
* rendu avec MODULATE
*
*
* Attention:
* ~~~~~~~~~~~
* Ce package a ete teste sur SGI, OSF, SUN, HP et WNT.
*
*
* Historique des modifications
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* 22-05-97: PCT ; creation
* 01-08-97: PCT ; suppression InitializeTextureBox()
* 05-08-97: FMN ; ajout GetTextureData...
* 19-06-98: FMN ; Portage Optimizer (C++)
* 22-07-98: FGU ; ajout stucture TextureData
*/
/*----------------------------------------------------------------------*/
#ifndef _OPENGL_TEXTUREBOX_H_
#define _OPENGL_TEXTUREBOX_H_
#include <OpenGl_GlCore11.hxx>
#include <Standard_DefineAlloc.hxx>
typedef int TextureID;
#define TEXTUREBOX_ERROR ((TextureID)-1)
/*
* Structure
*/
struct _TextureData
{
/* Donnees propre au fichier */
char path[256];
/* Donnees propre a la texture */
GLint gen;
GLint wrap;
GLfloat plane1[4], plane2[4];
GLint render;
GLfloat scalex, scaley;
GLfloat transx, transy;
GLfloat angle;
DEFINE_STANDARD_ALLOC
};
typedef _TextureData TextureData;
/*
* Gestion des textures
*/
/* Get texture a partir des donnees (format RGBA) GLubyte data[width][height][4]
* Le nom est utiliser pour la gesiton en interne, il permet d'eviter de charger
* plusieurs textures avec le meme noms.
*/
TextureID GetTextureData1D(char *FileName, const GLint width, const GLint height, const void *data);
TextureID GetTextureData2D(char *FileName, const GLint width, const GLint height, const void *data);
TextureID GetTextureData2DMipMap(char *FileName, const GLint width, const GLint height, const void *data);
class Handle(OpenGl_Context);
void FreeTexture (const Handle(OpenGl_Context)& theContext,
TextureID ID);
void SetCurrentTexture(TextureID ID);
GLboolean IsTextureValid(TextureID ID);
void EnableTexture(void);
void DisableTexture(void);
GLboolean IsTextureEnabled(void);
/*
* Configuration d'une texture
*/
void SetTextureModulate(TextureID ID);
void SetTextureDecal(TextureID ID);
void SetTextureClamp(TextureID ID);
void SetTextureRepeat(TextureID ID);
void SetModeObject(TextureID ID, const GLfloat sparams[4], const GLfloat tparams[4]);
void SetModeSphere(TextureID ID);
void SetModeEye(TextureID ID, const GLfloat sparams[4], const GLfloat tparams[4]);
void SetModeManual(TextureID ID);
void SetRenderNearest(TextureID ID);
void SetRenderLinear(TextureID ID);
void SetTexturePosition(TextureID ID,
GLfloat scalex, GLfloat scaley,
GLfloat transx, GLfloat transy,
GLfloat angle);
void SetTextureDefaultParams(TextureID ID);
void TransferTexture_To_Data(TextureID, TextureData *);
/*----------------------------------------------------------------------*/
#endif /* _OPENGL_TEXTUREBOX_H_ */

View File

@ -24,8 +24,6 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <OpenGl_TextureBox.hxx>
#include <InterfaceGraphic_Graphic3d.hxx> /* pour CALL_DEF_STRUCTURE */ #include <InterfaceGraphic_Graphic3d.hxx> /* pour CALL_DEF_STRUCTURE */
#include <InterfaceGraphic_Aspect.hxx> /* pour CALL_DEF_VIEW */ #include <InterfaceGraphic_Aspect.hxx> /* pour CALL_DEF_VIEW */
#include <InterfaceGraphic_Visual3d.hxx> #include <InterfaceGraphic_Visual3d.hxx>
@ -99,7 +97,7 @@ void OpenGl_Trihedron::Redraw (const Handle(OpenGl_Workspace) &AWorkspace) const
const Standard_Real V = AWorkspace->ActiveView()->Width(); const Standard_Real V = AWorkspace->ActiveView()->Width();
/* la taille des axes est 1 proportion (fixee a l'init du triedre) */ /* la taille des axes est 1 proportion (fixee a l'init du triedre) */
/* de la dimension la plus petite de la window. */ /* de la dimension la plus petite de la window. */
const GLdouble L = ( U < V ? U : V ) * myScale; const GLdouble L = ( U < V ? U : V ) * myScale;
/* /*
@ -158,18 +156,18 @@ void OpenGl_Trihedron::Redraw (const Handle(OpenGl_Workspace) &AWorkspace) const
break; break;
} }
/* /*
* Creation du triedre * Creation du triedre
*/ */
const OpenGl_AspectLine *AspectLine = AWorkspace->AspectLine( Standard_True ); const OpenGl_AspectLine *AspectLine = AWorkspace->AspectLine( Standard_True );
/* Fotis Sioutis 2007-11-14 15:06 /* Fotis Sioutis 2007-11-14 15:06
I have also seen in previous posts that the view trihedron in V3d_WIREFRAME mode I have also seen in previous posts that the view trihedron in V3d_WIREFRAME mode
changes colors depending on the state of the view. This behaviour can be easily changes colors depending on the state of the view. This behaviour can be easily
corrected by altering call_triedron_redraw function in OpenGl_triedron.c of TKOpengl. corrected by altering call_triedron_redraw function in OpenGl_triedron.c of TKOpengl.
The only change needed is to erase glDisable(GL_LIGHTING) that is called before the The only change needed is to erase glDisable(GL_LIGHTING) that is called before the
Axis name drawing and move this function call just before the initial axis drawing. Axis name drawing and move this function call just before the initial axis drawing.
Below is the code portion with the modification.I don't know if this is considered to Below is the code portion with the modification.I don't know if this is considered to
be a bug but anyway i believe it might help some of you out there.*/ be a bug but anyway i believe it might help some of you out there.*/
glDisable(GL_LIGHTING); glDisable(GL_LIGHTING);
@ -259,10 +257,10 @@ void OpenGl_Trihedron::Redraw (const Handle(OpenGl_Workspace) &AWorkspace) const
TriedronCoord[1] = rayon * cos(ii * Angle1); TriedronCoord[1] = rayon * cos(ii * Angle1);
glVertex3dv( TriedronCoord ); glVertex3dv( TriedronCoord );
ii--; ii--;
} }
glEnd(); glEnd();
/* /*
* Noms des axes et de l'origine * Noms des axes et de l'origine
*/ */
const OpenGl_AspectText *AspectText = AWorkspace->AspectText( Standard_True ); const OpenGl_AspectText *AspectText = AWorkspace->AspectText( Standard_True );
@ -272,7 +270,7 @@ void OpenGl_Trihedron::Redraw (const Handle(OpenGl_Workspace) &AWorkspace) const
AWorkspace->RenderText (L"Y", 0, float(rayon), float(L + 3.0 * rayon), float(2.0 * rayon)); AWorkspace->RenderText (L"Y", 0, float(rayon), float(L + 3.0 * rayon), float(2.0 * rayon));
AWorkspace->RenderText (L"Z", 0, float(-2.0 * rayon), float(0.5 * rayon), float(L + 3.0 * rayon)); AWorkspace->RenderText (L"Z", 0, float(-2.0 * rayon), float(0.5 * rayon), float(L + 3.0 * rayon));
/* /*
* restauration du contexte des matrices * restauration du contexte des matrices
*/ */
glMatrixMode (GL_PROJECTION); glMatrixMode (GL_PROJECTION);
@ -304,7 +302,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
GLboolean isWithinView = GL_FALSE; GLboolean isWithinView = GL_FALSE;
/* la taille des axes est 1 proportion (fixee a l'init du triedre) */ /* la taille des axes est 1 proportion (fixee a l'init du triedre) */
/* de la dimension la plus petite de la window. */ /* de la dimension la plus petite de la window. */
GLdouble L = ( U < V ? U : V ) * myScale; GLdouble L = ( U < V ? U : V ) * myScale;
if (!isWithinView) if (!isWithinView)
@ -332,7 +330,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
*/ */
switch (myPos) switch (myPos)
{ {
case Aspect_TOTP_LEFT_LOWER : case Aspect_TOTP_LEFT_LOWER :
glTranslated( -0.5*U + L , -0.5*V + L , 0. ); glTranslated( -0.5*U + L , -0.5*V + L , 0. );
break; break;
@ -358,7 +356,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
const OpenGl_AspectLine *AspectLine = AWorkspace->AspectLine( Standard_True ); const OpenGl_AspectLine *AspectLine = AWorkspace->AspectLine( Standard_True );
const TEL_COLOUR &aLineColor = AspectLine->Color(); const TEL_COLOUR &aLineColor = AspectLine->Color();
/* /*
* Creation the trihedron * Creation the trihedron
*/ */
#define CYLINDER_LENGTH 0.75f #define CYLINDER_LENGTH 0.75f
@ -373,7 +371,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
/* GL_DEPTH_WRITEMASK is not a valid argument to glIsEnabled, the */ /* GL_DEPTH_WRITEMASK is not a valid argument to glIsEnabled, the */
/* original code is shown to be broken when run under an OpenGL debugger */ /* original code is shown to be broken when run under an OpenGL debugger */
/* like GLIntercept. This is the correct way to retrieve the mask value. */ /* like GLIntercept. This is the correct way to retrieve the mask value. */
glGetBooleanv(GL_DEPTH_WRITEMASK, &aIsDepthMaskEnabled); glGetBooleanv(GL_DEPTH_WRITEMASK, &aIsDepthMaskEnabled);
const GLdouble aCylinderLength = L * CYLINDER_LENGTH; const GLdouble aCylinderLength = L * CYLINDER_LENGTH;
const GLdouble aCylinderDiametr = L * myDiameter; const GLdouble aCylinderDiametr = L * myDiameter;
@ -411,21 +409,21 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
glEnable(GL_CULL_FACE); glEnable(GL_CULL_FACE);
/*Fotis Sioutis | 2008-01-21 10:55 /*Fotis Sioutis | 2008-01-21 10:55
In the function call_zbuffer_triedron_redraw of TKOpengl, In the function call_zbuffer_triedron_redraw of TKOpengl,
the z buffered trihedron changes colors in case there the z buffered trihedron changes colors in case there
is an object in the scene that has an explicit material is an object in the scene that has an explicit material
attached to it.In the trihedron display loop, attached to it.In the trihedron display loop,
GL_COLOR_MATERIAL is enabled, but only the GL_DIFFUSE GL_COLOR_MATERIAL is enabled, but only the GL_DIFFUSE
parameter is utilized in glColorMaterial(...). parameter is utilized in glColorMaterial(...).
This causes the last ambient,specular and emission values This causes the last ambient,specular and emission values
used, to stay at the stack and applied to the trihedron used, to stay at the stack and applied to the trihedron
(which causes the color change). (which causes the color change).
A fix is proposed , to change GL_DIFFUSE to A fix is proposed , to change GL_DIFFUSE to
GL_AMBIENT_AND_DIFFUSE in glColorMaterial call in GL_AMBIENT_AND_DIFFUSE in glColorMaterial call in
line 946.The above of course will leave unchanged line 946.The above of course will leave unchanged
the SPECULAR and EMISSION values. the SPECULAR and EMISSION values.
Another proposal which would fix 100% the problem Another proposal which would fix 100% the problem
is to use glMaterial instead of glColor on the trihedron is to use glMaterial instead of glColor on the trihedron
drawing loop. */ drawing loop. */
const GLfloat aNULLColor[] = { 0.f, 0.f, 0.f, 0.f }; /* FS 21/01/08 */ const GLfloat aNULLColor[] = { 0.f, 0.f, 0.f, 0.f }; /* FS 21/01/08 */
glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, aNULLColor); glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, aNULLColor);
@ -459,18 +457,18 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
/* PCD 17/06/07 */ /* PCD 17/06/07 */
GLint df; GLint df;
glGetIntegerv (GL_DEPTH_FUNC, &df); glGetIntegerv (GL_DEPTH_FUNC, &df);
int i; int i;
for (i = 0; i < 2; i++) /* PCD 11/02/08 Two pass method */ for (i = 0; i < 2; i++) /* PCD 11/02/08 Two pass method */
{ {
if (i == 0) /* First pass */ if (i == 0) /* First pass */
{ {
glDepthFunc(GL_ALWAYS); glDepthFunc(GL_ALWAYS);
} }
else else
{ {
glDepthFunc(GL_LEQUAL); glDepthFunc(GL_LEQUAL);
} }
glPushMatrix(); glPushMatrix();
@ -486,7 +484,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
glTranslated(0, 0, L * CYLINDER_LENGTH); glTranslated(0, 0, L * CYLINDER_LENGTH);
glCallList(startList + 3); glCallList(startList + 3);
glCallList(startList + 1); glCallList(startList + 1);
glPopMatrix(); glPopMatrix();
// X axis // X axis
glRotated(90.0, TriedronAxeY[0], TriedronAxeY[1], TriedronAxeY[2]); glRotated(90.0, TriedronAxeY[0], TriedronAxeY[1], TriedronAxeY[2]);
@ -495,7 +493,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
glTranslated(0, 0, L * CYLINDER_LENGTH); glTranslated(0, 0, L * CYLINDER_LENGTH);
glCallList(startList + 3); glCallList(startList + 3);
glCallList(startList + 1); glCallList(startList + 1);
glPopMatrix(); glPopMatrix();
// Y axis // Y axis
glRotated(-90.0, TriedronAxeX[0], TriedronAxeX[1], TriedronAxeX[2]); glRotated(-90.0, TriedronAxeX[0], TriedronAxeX[1], TriedronAxeX[2]);
@ -507,7 +505,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
glPopMatrix(); glPopMatrix();
} }
if (!aIsDepthEnabled) if (!aIsDepthEnabled)
glDisable(GL_DEPTH_TEST); glDisable(GL_DEPTH_TEST);
if (!aIsDepthMaskEnabled) if (!aIsDepthMaskEnabled)
@ -520,7 +518,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
glColor3fv (aLineColor.rgb); glColor3fv (aLineColor.rgb);
/* Always write the text */ /* Always write the text */
glDepthFunc(GL_ALWAYS); glDepthFunc(GL_ALWAYS);
glPopAttrib(); glPopAttrib();
@ -529,11 +527,11 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
const GLdouble rayon = L/30. ; /* rayon de la base du cone */ const GLdouble rayon = L/30. ; /* rayon de la base du cone */
//const double Angle = 2. * M_PI/ myNbFacettes; //const double Angle = 2. * M_PI/ myNbFacettes;
glDeleteLists(startList, 4); glDeleteLists(startList, 4);
glDisable(GL_LIGHTING); glDisable(GL_LIGHTING);
/* /*
* origine names * origine names
*/ */
const OpenGl_AspectText *AspectText = AWorkspace->AspectText( Standard_True ); const OpenGl_AspectText *AspectText = AWorkspace->AspectText( Standard_True );
@ -559,7 +557,7 @@ void OpenGl_Trihedron::RedrawZBuffer (const Handle(OpenGl_Workspace) &AWorkspace
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
/* /*
* Fonctions publiques * Fonctions publiques
*/ */
@ -614,44 +612,51 @@ OpenGl_Trihedron::~OpenGl_Trihedron ()
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
/* /*
* affichage d'un triedre non zoomable dans la wks awsid * affichage d'un triedre non zoomable dans la wks awsid
* *
* Triedre = Objet non Zoomable; * Triedre = Objet non Zoomable;
* on cree cette fonction pour pouvoir travailler par les structures * on cree cette fonction pour pouvoir travailler par les structures
* utilisees par les fonctions Tsm* et TEL_VIEW_REP * utilisees par les fonctions Tsm* et TEL_VIEW_REP
* *
*/ */
//call_triedron_redraw_from_wsid //call_triedron_redraw_from_wsid
void OpenGl_Trihedron::Render (const Handle(OpenGl_Workspace) &AWorkspace) const void OpenGl_Trihedron::Render (const Handle(OpenGl_Workspace)& theWorkspace) const
{ {
const OpenGl_AspectLine *oldAspectLine = AWorkspace->SetAspectLine(&myAspectLine); const OpenGl_AspectLine* aPrevAspectLine = theWorkspace->SetAspectLine (&myAspectLine);
const OpenGl_AspectText *oldAspectText = AWorkspace->SetAspectText(&myAspectText); const OpenGl_AspectText* aPrevAspectText = theWorkspace->SetAspectText (&myAspectText);
/* check if GL_LIGHTING should be disabled /* check if GL_LIGHTING should be disabled
no enabling 'cause it will be done (if necessary: kinda Polygon types ) no enabling 'cause it will be done (if necessary: kinda Polygon types )
during redrawing structures during redrawing structures
*/ */
if (!AWorkspace->UseGLLight()) if (!theWorkspace->UseGLLight())
glDisable( GL_LIGHTING ); {
glDisable (GL_LIGHTING);
}
/* sauvegarde du contexte (on reste dans le buffer courant) */ const Handle(OpenGl_Texture) aPrevTexture = theWorkspace->DisableTexture();
const GLboolean save_texture_state = IsTextureEnabled();
DisableTexture();
/* affichage du Triedre Non Zoomable */ /* affichage du Triedre Non Zoomable */
AWorkspace->ActiveView()->EndTransformPersistence(); theWorkspace->ActiveView()->EndTransformPersistence();
if (myIsWireframe) if (myIsWireframe)
Redraw (AWorkspace); {
Redraw (theWorkspace);
}
else else
RedrawZBuffer (AWorkspace); {
RedrawZBuffer (theWorkspace);
}
/* restauration du contexte */ // restore aspects
if (save_texture_state) EnableTexture(); if (!aPrevTexture.IsNull())
{
theWorkspace->EnableTexture (aPrevTexture);
}
AWorkspace->SetAspectText(oldAspectText); theWorkspace->SetAspectText (aPrevAspectText);
AWorkspace->SetAspectLine(oldAspectLine); theWorkspace->SetAspectLine (aPrevAspectLine);
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/

View File

@ -21,16 +21,18 @@
#include <OpenGl_GlCore11.hxx> #include <OpenGl_GlCore11.hxx>
#include <OpenGl_View.hxx> #include <OpenGl_View.hxx>
#include <OpenGl_Context.hxx>
#include <OpenGl_Workspace.hxx> #include <OpenGl_Workspace.hxx>
#include <OpenGl_Display.hxx> #include <OpenGl_Display.hxx>
#include <OpenGl_Display.hxx> #include <OpenGl_Texture.hxx>
#include <OpenGl_Trihedron.hxx> #include <OpenGl_Trihedron.hxx>
#include <OpenGl_GraduatedTrihedron.hxx> #include <OpenGl_GraduatedTrihedron.hxx>
#include <OpenGl_transform_persistence.hxx> #include <OpenGl_transform_persistence.hxx>
#include <Graphic3d_TextureEnv.hxx>
#include <GL/glu.h> // gluUnProject() #include <GL/glu.h> // gluUnProject()
IMPLEMENT_STANDARD_HANDLE(OpenGl_View,MMgt_TShared) IMPLEMENT_STANDARD_HANDLE(OpenGl_View,MMgt_TShared)
@ -77,8 +79,7 @@ static const TEL_TRANSFORM_PERSISTENCE myDefaultTransPers = { 0, 0.F, 0.F, 0.F }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
OpenGl_View::OpenGl_View (const CALL_DEF_VIEWCONTEXT &AContext) OpenGl_View::OpenGl_View (const CALL_DEF_VIEWCONTEXT &AContext)
: myTextureEnv(0), : mySurfaceDetail(Visual3d_TOD_NONE),
mySurfaceDetail(Visual3d_TOD_NONE),
myBackfacing(0), myBackfacing(0),
myBgTexture(myDefaultBgTexture), myBgTexture(myDefaultBgTexture),
myBgGradient(myDefaultBgGradient), myBgGradient(myDefaultBgGradient),
@ -122,11 +123,45 @@ OpenGl_View::OpenGl_View (const CALL_DEF_VIEWCONTEXT &AContext)
OpenGl_View::~OpenGl_View () OpenGl_View::~OpenGl_View ()
{ {
if (myAnimationListIndex) ReleaseGlResources (NULL); // ensure ReleaseGlResources() was called within valid context
glDeleteLists((GLuint)myAnimationListIndex,1); }
if ( myBgTexture.TexId != 0 ) void OpenGl_View::ReleaseGlResources (const Handle(OpenGl_Context)& theCtx)
glDeleteTextures( 1, (GLuint*)&(myBgTexture.TexId) ); {
if (!myTextureEnv.IsNull())
{
theCtx->DelayedRelease (myTextureEnv);
myTextureEnv.Nullify();
}
if (myBgTexture.TexId != 0)
{
glDeleteTextures (1, (GLuint*)&(myBgTexture.TexId));
myBgTexture.TexId = 0;
}
if (myAnimationListIndex)
{
glDeleteLists ((GLuint )myAnimationListIndex, 1);
myAnimationListIndex = 0;
}
}
void OpenGl_View::SetTextureEnv (const Handle(OpenGl_Context)& theCtx,
const Handle(Graphic3d_TextureEnv)& theTexture)
{
if (!myTextureEnv.IsNull())
{
theCtx->DelayedRelease (myTextureEnv);
myTextureEnv.Nullify();
}
if (theTexture.IsNull())
{
return;
}
myTextureEnv = new OpenGl_Texture (theTexture->GetParams());
Handle(Image_PixMap) anImage = theTexture->GetImage();
myTextureEnv->Init (theCtx, *anImage.operator->(), theTexture->Type());
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@ -214,7 +249,7 @@ void OpenGl_View::SetClippingPlanes (const CALL_DEF_VIEWCONTEXT &AContext)
{ {
// clear clipping planes information // clear clipping planes information
myClippingPlanes.Clear(); myClippingPlanes.Clear();
// update information // update information
int i = 0; int i = 0;
for (; i < AContext.NbActivePlane; i++) for (; i < AContext.NbActivePlane; i++)
{ {
@ -253,42 +288,42 @@ void OpenGl_View::SetVisualisation (const CALL_DEF_VIEWCONTEXT &AContext)
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
//call_togl_cliplimit //call_togl_cliplimit
void OpenGl_View::SetClipLimit (const CALL_DEF_VIEW &ACView) void OpenGl_View::SetClipLimit (const Graphic3d_CView& theCView)
{ {
myZClip.Back.Limit = myZClip.Back.Limit =
( ACView.Context.ZClipBackPlane - ACView.Mapping.BackPlaneDistance ) / (theCView.Context.ZClipBackPlane - theCView.Mapping.BackPlaneDistance) /
( ACView.Mapping.FrontPlaneDistance - ACView.Mapping.BackPlaneDistance ); (theCView.Mapping.FrontPlaneDistance - theCView.Mapping.BackPlaneDistance);
myZClip.Front.Limit = myZClip.Front.Limit =
( ACView.Context.ZClipFrontPlane - ACView.Mapping.BackPlaneDistance ) / (theCView.Context.ZClipFrontPlane - theCView.Mapping.BackPlaneDistance) /
( ACView.Mapping.FrontPlaneDistance - ACView.Mapping.BackPlaneDistance ); (theCView.Mapping.FrontPlaneDistance - theCView.Mapping.BackPlaneDistance);
if ( myZClip.Back.Limit < 0.F ) if (myZClip.Back.Limit < 0.0f)
myZClip.Back.Limit = 0.F; myZClip.Back.Limit = 0.0f;
if ( myZClip.Front.Limit > 1.F ) if (myZClip.Front.Limit > 1.0f)
myZClip.Front.Limit = 1.F; myZClip.Front.Limit = 1.0f;
if ( myZClip.Back.Limit > myZClip.Front.Limit ) if (myZClip.Back.Limit > myZClip.Front.Limit)
{ {
myZClip.Back.Limit = 0.F; myZClip.Back.Limit = 0.0f;
myZClip.Front.Limit = 1.F; myZClip.Front.Limit = 1.0f;
} }
myZClip.Back.IsOn = (ACView.Context.BackZClipping != 0); myZClip.Back.IsOn = (theCView.Context.BackZClipping != 0);
myZClip.Front.IsOn = (ACView.Context.FrontZClipping != 0); myZClip.Front.IsOn = (theCView.Context.FrontZClipping != 0);
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
//call_togl_viewmapping //call_togl_viewmapping
void OpenGl_View::SetMapping (const CALL_DEF_VIEW &ACView) void OpenGl_View::SetMapping (const Graphic3d_CView& theCView)
{ {
const float ratio = ACView.DefWindow.dy / ACView.DefWindow.dx; const float ratio = theCView.DefWindow.dy / theCView.DefWindow.dx;
const float r_ratio = ACView.DefWindow.dx / ACView.DefWindow.dy; const float r_ratio = theCView.DefWindow.dx / theCView.DefWindow.dy;
TEL_VIEW_MAPPING Map; TEL_VIEW_MAPPING Map;
Map.window.xmin = ACView.Mapping.WindowLimit.um; Map.window.xmin = theCView.Mapping.WindowLimit.um;
Map.window.ymin = ACView.Mapping.WindowLimit.vm; Map.window.ymin = theCView.Mapping.WindowLimit.vm;
Map.window.xmax = ACView.Mapping.WindowLimit.uM; Map.window.xmax = theCView.Mapping.WindowLimit.uM;
Map.window.ymax = ACView.Mapping.WindowLimit.vM; Map.window.ymax = theCView.Mapping.WindowLimit.vM;
Map.viewport.xmin = 0.F; Map.viewport.xmin = 0.F;
Map.viewport.xmax = ( 1.F < r_ratio ? 1.F : r_ratio ); Map.viewport.xmax = ( 1.F < r_ratio ? 1.F : r_ratio );
@ -297,8 +332,8 @@ void OpenGl_View::SetMapping (const CALL_DEF_VIEW &ACView)
Map.viewport.zmin = 0.F; Map.viewport.zmin = 0.F;
Map.viewport.zmax = 1.F; Map.viewport.zmax = 1.F;
/* projection type */ // projection type
switch( ACView.Mapping.Projection ) switch (theCView.Mapping.Projection)
{ {
case 0 : case 0 :
Map.proj = TelPerspective; Map.proj = TelPerspective;
@ -308,79 +343,81 @@ void OpenGl_View::SetMapping (const CALL_DEF_VIEW &ACView)
break; break;
} }
/* projection reference point */ // projection reference point
Map.prp[0] = ACView.Mapping.ProjectionReferencePoint.x; Map.prp[0] = theCView.Mapping.ProjectionReferencePoint.x;
Map.prp[1] = ACView.Mapping.ProjectionReferencePoint.y; Map.prp[1] = theCView.Mapping.ProjectionReferencePoint.y;
Map.prp[2] = ACView.Mapping.ProjectionReferencePoint.z; Map.prp[2] = theCView.Mapping.ProjectionReferencePoint.z;
if (!openglDisplay.IsNull() && !openglDisplay->Walkthrough()) if (!openglDisplay.IsNull() && !openglDisplay->Walkthrough())
Map.prp[2] += ACView.Mapping.FrontPlaneDistance; Map.prp[2] += theCView.Mapping.FrontPlaneDistance;
/* view plane distance */ // view plane distance
Map.vpd = ACView.Mapping.ViewPlaneDistance; Map.vpd = theCView.Mapping.ViewPlaneDistance;
/* back plane distance */ // back plane distance
Map.bpd = ACView.Mapping.BackPlaneDistance; Map.bpd = theCView.Mapping.BackPlaneDistance;
/* front plane distance */ // front plane distance
Map.fpd = ACView.Mapping.FrontPlaneDistance; Map.fpd = theCView.Mapping.FrontPlaneDistance;
Tint err_ind = 0; Tint err_ind = 0;
/* use user-defined matrix */ // use user-defined matrix
if ( ACView.Mapping.IsCustomMatrix ) if (theCView.Mapping.IsCustomMatrix)
{ {
int i, j; int i, j;
for( i = 0; i < 4; i++ ) for( i = 0; i < 4; i++ )
for( j = 0; j < 4; j++ ) for( j = 0; j < 4; j++ )
myMappingMatrix[i][j] = ACView.Mapping.ProjectionMatrix[i][j]; myMappingMatrix[i][j] = theCView.Mapping.ProjectionMatrix[i][j];
} }
else else
TelEvalViewMappingMatrix( &Map, &err_ind, myMappingMatrix ); TelEvalViewMappingMatrix( &Map, &err_ind, myMappingMatrix );
if ( !err_ind ) if (!err_ind)
myExtra.map = Map; myExtra.map = Map;
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
//call_togl_vieworientation //call_togl_vieworientation
void OpenGl_View::SetOrientation (const CALL_DEF_VIEW &ACView) void OpenGl_View::SetOrientation (const Graphic3d_CView& theCView)
{ {
Tfloat Vrp[3]; Tfloat Vrp[3];
Tfloat Vpn[3]; Tfloat Vpn[3];
Tfloat Vup[3]; Tfloat Vup[3];
Tfloat ScaleFactors[3]; Tfloat ScaleFactors[3];
Vrp[0] = ACView.Orientation.ViewReferencePoint.x; Vrp[0] = theCView.Orientation.ViewReferencePoint.x;
Vrp[1] = ACView.Orientation.ViewReferencePoint.y; Vrp[1] = theCView.Orientation.ViewReferencePoint.y;
Vrp[2] = ACView.Orientation.ViewReferencePoint.z; Vrp[2] = theCView.Orientation.ViewReferencePoint.z;
Vpn[0] = ACView.Orientation.ViewReferencePlane.x; Vpn[0] = theCView.Orientation.ViewReferencePlane.x;
Vpn[1] = ACView.Orientation.ViewReferencePlane.y; Vpn[1] = theCView.Orientation.ViewReferencePlane.y;
Vpn[2] = ACView.Orientation.ViewReferencePlane.z; Vpn[2] = theCView.Orientation.ViewReferencePlane.z;
Vup[0] = ACView.Orientation.ViewReferenceUp.x; Vup[0] = theCView.Orientation.ViewReferenceUp.x;
Vup[1] = ACView.Orientation.ViewReferenceUp.y; Vup[1] = theCView.Orientation.ViewReferenceUp.y;
Vup[2] = ACView.Orientation.ViewReferenceUp.z; Vup[2] = theCView.Orientation.ViewReferenceUp.z;
ScaleFactors[0] = ACView.Orientation.ViewScaleX; ScaleFactors[0] = theCView.Orientation.ViewScaleX;
ScaleFactors[1] = ACView.Orientation.ViewScaleY; ScaleFactors[1] = theCView.Orientation.ViewScaleY;
ScaleFactors[2] = ACView.Orientation.ViewScaleZ; ScaleFactors[2] = theCView.Orientation.ViewScaleZ;
Tint err_ind = 0; Tint err_ind = 0;
// use user-defined matrix // use user-defined matrix
if ( ACView.Orientation.IsCustomMatrix ) if (theCView.Orientation.IsCustomMatrix)
{ {
int i, j; int i, j;
for( i = 0; i < 4; i++ ) for( i = 0; i < 4; i++ )
for( j = 0; j < 4; j++ ) for( j = 0; j < 4; j++ )
myOrientationMatrix[i][j] = ACView.Orientation.ModelViewMatrix[i][j]; myOrientationMatrix[i][j] = theCView.Orientation.ModelViewMatrix[i][j];
} }
else else
TelEvalViewOrientationMatrix( Vrp, Vpn, Vup, ScaleFactors, &err_ind, myOrientationMatrix ); {
TelEvalViewOrientationMatrix (Vrp, Vpn, Vup, ScaleFactors, &err_ind, myOrientationMatrix);
}
if ( !err_ind ) if (!err_ind)
{ {
myExtra.vrp[0] = Vrp[0]; myExtra.vrp[0] = Vrp[0];
myExtra.vrp[1] = Vrp[1]; myExtra.vrp[1] = Vrp[1];
@ -402,9 +439,10 @@ void OpenGl_View::SetOrientation (const CALL_DEF_VIEW &ACView)
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
void OpenGl_View::SetFog (const CALL_DEF_VIEW &ACView, const Standard_Boolean AFlag) void OpenGl_View::SetFog (const Graphic3d_CView& theCView,
const Standard_Boolean theFlag)
{ {
if( !AFlag ) if (!theFlag)
{ {
myFog.IsOn = Standard_False; myFog.IsOn = Standard_False;
} }
@ -413,12 +451,12 @@ void OpenGl_View::SetFog (const CALL_DEF_VIEW &ACView, const Standard_Boolean AF
myFog.IsOn = Standard_True; myFog.IsOn = Standard_True;
myFog.Front = myFog.Front =
(ACView.Context.DepthFrontPlane - ACView.Mapping.BackPlaneDistance) / (theCView.Context.DepthFrontPlane - theCView.Mapping.BackPlaneDistance) /
(ACView.Mapping.FrontPlaneDistance - ACView.Mapping.BackPlaneDistance); (theCView.Mapping.FrontPlaneDistance - theCView.Mapping.BackPlaneDistance);
myFog.Back = myFog.Back =
(ACView.Context.DepthBackPlane - ACView.Mapping.BackPlaneDistance) / (theCView.Context.DepthBackPlane - theCView.Mapping.BackPlaneDistance) /
(ACView.Mapping.FrontPlaneDistance - ACView.Mapping.BackPlaneDistance); (theCView.Mapping.FrontPlaneDistance - theCView.Mapping.BackPlaneDistance);
if (myFog.Front < 0.F) if (myFog.Front < 0.F)
myFog.Front = 0.F; myFog.Front = 0.F;
@ -436,10 +474,10 @@ void OpenGl_View::SetFog (const CALL_DEF_VIEW &ACView, const Standard_Boolean AF
myFog.Back = 0.F; myFog.Back = 0.F;
} }
myFog.Color.rgb[0] = ACView.DefWindow.Background.r; myFog.Color.rgb[0] = theCView.DefWindow.Background.r;
myFog.Color.rgb[1] = ACView.DefWindow.Background.g; myFog.Color.rgb[1] = theCView.DefWindow.Background.g;
myFog.Color.rgb[2] = ACView.DefWindow.Background.b; myFog.Color.rgb[2] = theCView.DefWindow.Background.b;
myFog.Color.rgb[3] = 1.F; myFog.Color.rgb[3] = 1.0f;
} }
} }
@ -486,7 +524,7 @@ void OpenGl_View::EndTransformPersistence ()
glPopMatrix (); glPopMatrix ();
myIsTransPers = Standard_False; myIsTransPers = Standard_False;
} }
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@ -586,7 +624,7 @@ const TEL_TRANSFORM_PERSISTENCE * OpenGl_View::BeginTransformPersistence (const
glMatrixMode( GL_MODELVIEW ); glMatrixMode( GL_MODELVIEW );
glLoadIdentity(); glLoadIdentity();
glTranslated( ATransPers->pointX, ATransPers->pointY, ATransPers->pointZ ); glTranslated( ATransPers->pointX, ATransPers->pointY, ATransPers->pointZ );
} }
if( ATransPers->mode == TPF_TRIEDRON ) if( ATransPers->mode == TPF_TRIEDRON )

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_View_Header #ifndef _OpenGl_View_Header
#define _OpenGl_View_Header #define _OpenGl_View_Header
@ -44,10 +43,12 @@
#include <OpenGl_LayerList.hxx> #include <OpenGl_LayerList.hxx>
#include <OpenGl_Light.hxx> #include <OpenGl_Light.hxx>
#include <Handle_OpenGl_Context.hxx>
#include <Handle_OpenGl_Trihedron.hxx> #include <Handle_OpenGl_Trihedron.hxx>
#include <Handle_OpenGl_GraduatedTrihedron.hxx> #include <Handle_OpenGl_GraduatedTrihedron.hxx>
#include <Handle_OpenGl_Workspace.hxx> #include <Handle_OpenGl_Workspace.hxx>
#include <Handle_OpenGl_View.hxx> #include <Handle_OpenGl_View.hxx>
#include <Handle_OpenGl_Texture.hxx>
struct OPENGL_BG_TEXTURE struct OPENGL_BG_TEXTURE
{ {
@ -107,7 +108,10 @@ class OpenGl_View : public MMgt_TShared
OpenGl_View (const CALL_DEF_VIEWCONTEXT &AContext); OpenGl_View (const CALL_DEF_VIEWCONTEXT &AContext);
virtual ~OpenGl_View (); virtual ~OpenGl_View ();
void SetTextureEnv (const Standard_Integer AId) { myTextureEnv = AId; } void ReleaseGlResources (const Handle(OpenGl_Context)& theCtx);
void SetTextureEnv (const Handle(OpenGl_Context)& theCtx,
const Handle(Graphic3d_TextureEnv)& theTexture);
void SetSurfaceDetail (const Visual3d_TypeOfSurfaceDetail AMode) { mySurfaceDetail = AMode; } void SetSurfaceDetail (const Visual3d_TypeOfSurfaceDetail AMode) { mySurfaceDetail = AMode; }
void SetBackfacing (const Standard_Integer AMode); void SetBackfacing (const Standard_Integer AMode);
void SetLights (const CALL_DEF_VIEWCONTEXT &AContext); void SetLights (const CALL_DEF_VIEWCONTEXT &AContext);
@ -115,11 +119,11 @@ class OpenGl_View : public MMgt_TShared
void SetClippingPlanes (const CALL_DEF_VIEWCONTEXT &AContext); void SetClippingPlanes (const CALL_DEF_VIEWCONTEXT &AContext);
void SetVisualisation (const CALL_DEF_VIEWCONTEXT &AContext); void SetVisualisation (const CALL_DEF_VIEWCONTEXT &AContext);
void SetClipLimit (const CALL_DEF_VIEW &ACView); void SetClipLimit (const Graphic3d_CView& theCView);
void SetMapping (const CALL_DEF_VIEW &ACView); void SetMapping (const Graphic3d_CView& theCView);
void SetOrientation (const CALL_DEF_VIEW &ACView); void SetOrientation (const Graphic3d_CView& theCView);
void SetFog (const CALL_DEF_VIEW &ACView, const Standard_Boolean AFlag); void SetFog (const Graphic3d_CView& theCView, const Standard_Boolean theFlag);
void TriedronDisplay (const Aspect_TypeOfTriedronPosition APosition, const Quantity_NameOfColor AColor, const Standard_Real AScale, const Standard_Boolean AsWireframe); void TriedronDisplay (const Aspect_TypeOfTriedronPosition APosition, const Quantity_NameOfColor AColor, const Standard_Real AScale, const Standard_Boolean AsWireframe);
void TriedronErase (); void TriedronErase ();
@ -190,7 +194,7 @@ class OpenGl_View : public MMgt_TShared
void RenderStructs (const Handle(OpenGl_Workspace) &AWorkspace); void RenderStructs (const Handle(OpenGl_Workspace) &AWorkspace);
void RedrawLayer2d (const Handle(OpenGl_Workspace) &AWorkspace, const Graphic3d_CView& ACView, const Aspect_CLayer2d& ACLayer); void RedrawLayer2d (const Handle(OpenGl_Workspace) &AWorkspace, const Graphic3d_CView& ACView, const Aspect_CLayer2d& ACLayer);
Standard_Integer myTextureEnv; //WSTextureEnv Handle(OpenGl_Texture) myTextureEnv;
Visual3d_TypeOfSurfaceDetail mySurfaceDetail; //WSSurfaceDetail Visual3d_TypeOfSurfaceDetail mySurfaceDetail; //WSSurfaceDetail
Standard_Integer myBackfacing; //WSBackfacing Standard_Integer myBackfacing; //WSBackfacing

View File

@ -22,7 +22,6 @@
#include <OpenGl_GlCore11.hxx> #include <OpenGl_GlCore11.hxx>
#include <OpenGl_tgl_funcs.hxx> #include <OpenGl_tgl_funcs.hxx>
#include <OpenGl_TextureBox.hxx>
#include <Image_AlienPixMap.hxx> #include <Image_AlienPixMap.hxx>
#include <Visual3d_Layer.hxx> #include <Visual3d_Layer.hxx>
@ -1111,18 +1110,17 @@ D = -[Px,Py,Pz] dot |Nx|
{ {
case Visual3d_TOD_NONE: case Visual3d_TOD_NONE:
AWorkspace->NamedStatus |= OPENGL_NS_FORBIDSETTEX; AWorkspace->NamedStatus |= OPENGL_NS_FORBIDSETTEX;
DisableTexture(); AWorkspace->DisableTexture();
// Render the view // Render the view
RenderStructs(AWorkspace); RenderStructs(AWorkspace);
break; break;
case Visual3d_TOD_ENVIRONMENT: case Visual3d_TOD_ENVIRONMENT:
AWorkspace->NamedStatus |= OPENGL_NS_FORBIDSETTEX; AWorkspace->NamedStatus |= OPENGL_NS_FORBIDSETTEX;
SetCurrentTexture(myTextureEnv); AWorkspace->EnableTexture (myTextureEnv);
EnableTexture();
// Render the view // Render the view
RenderStructs(AWorkspace); RenderStructs(AWorkspace);
DisableTexture(); AWorkspace->DisableTexture();
break; break;
case Visual3d_TOD_ALL: case Visual3d_TOD_ALL:
@ -1130,14 +1128,13 @@ D = -[Px,Py,Pz] dot |Nx|
AWorkspace->NamedStatus &= ~OPENGL_NS_FORBIDSETTEX; AWorkspace->NamedStatus &= ~OPENGL_NS_FORBIDSETTEX;
// Render the view // Render the view
RenderStructs(AWorkspace); RenderStructs(AWorkspace);
DisableTexture(); AWorkspace->DisableTexture();
// Second pass // Second pass
if (AWorkspace->NamedStatus & OPENGL_NS_2NDPASSNEED) if (AWorkspace->NamedStatus & OPENGL_NS_2NDPASSNEED)
{ {
AWorkspace->NamedStatus |= OPENGL_NS_2NDPASSDO; AWorkspace->NamedStatus |= OPENGL_NS_2NDPASSDO;
SetCurrentTexture(myTextureEnv); AWorkspace->EnableTexture (myTextureEnv);
EnableTexture();
/* sauvegarde de quelques parametres OpenGL */ /* sauvegarde de quelques parametres OpenGL */
GLint blend_dst, blend_src; GLint blend_dst, blend_src;
@ -1161,7 +1158,7 @@ D = -[Px,Py,Pz] dot |Nx|
// Render the view // Render the view
RenderStructs(AWorkspace); RenderStructs(AWorkspace);
DisableTexture(); AWorkspace->DisableTexture();
/* restauration des parametres OpenGL */ /* restauration des parametres OpenGL */
glBlendFunc(blend_src, blend_dst); glBlendFunc(blend_src, blend_dst);

View File

@ -17,8 +17,7 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <OpenGl_GlCore12.hxx>
#include <OpenGl_GlCore11.hxx>
#include <InterfaceGraphic.hxx> #include <InterfaceGraphic.hxx>
@ -28,8 +27,11 @@
#include <OpenGl_AspectFace.hxx> #include <OpenGl_AspectFace.hxx>
#include <OpenGl_AspectMarker.hxx> #include <OpenGl_AspectMarker.hxx>
#include <OpenGl_AspectText.hxx> #include <OpenGl_AspectText.hxx>
#include <OpenGl_Context.hxx>
#include <OpenGl_TextureBox.hxx> #include <OpenGl_Texture.hxx>
#include <Graphic3d_TextureParams.hxx>
IMPLEMENT_STANDARD_HANDLE(OpenGl_Workspace,OpenGl_Window) IMPLEMENT_STANDARD_HANDLE(OpenGl_Workspace,OpenGl_Window)
IMPLEMENT_STANDARD_RTTIEXT(OpenGl_Workspace,OpenGl_Window) IMPLEMENT_STANDARD_RTTIEXT(OpenGl_Workspace,OpenGl_Window)
@ -55,6 +57,7 @@ namespace
{ 0.0F, 0.0F, 1.0F, 0.0F }, { 0.0F, 0.0F, 1.0F, 0.0F },
{ 0.0F, 0.0F, 0.0F, 1.0F }} { 0.0F, 0.0F, 0.0F, 1.0F }}
}; };
}; };
// ======================================================================= // =======================================================================
@ -99,7 +102,7 @@ OpenGl_Workspace::OpenGl_Workspace (const Handle(OpenGl_Display)& theDisplay,
// Eviter d'avoir les faces mal orientees en noir. // Eviter d'avoir les faces mal orientees en noir.
// Pourrait etre utiliser pour detecter les problemes d'orientation // Pourrait etre utiliser pour detecter les problemes d'orientation
glLightModeli ((GLenum )GL_LIGHT_MODEL_TWO_SIDE, GL_TRUE); glLightModeli ((GLenum )GL_LIGHT_MODEL_TWO_SIDE, GL_TRUE);
// Optimisation pour le Fog et l'antialiasing // Optimisation pour le Fog et l'antialiasing
glHint (GL_FOG_HINT, GL_FASTEST); glHint (GL_FOG_HINT, GL_FASTEST);
@ -157,7 +160,7 @@ void OpenGl_Workspace::UseTransparency (const Standard_Boolean theFlag)
//======================================================================= //=======================================================================
void OpenGl_Workspace::ResetAppliedAspect() void OpenGl_Workspace::ResetAppliedAspect()
{ {
NamedStatus = IsTextureEnabled() ? OPENGL_NS_TEXTURE : 0; NamedStatus = !myTextureBound.IsNull() ? OPENGL_NS_TEXTURE : 0;
HighlightColor = &myDefaultHighlightColor; HighlightColor = &myDefaultHighlightColor;
AspectLine_set = &myDefaultAspectLine; AspectLine_set = &myDefaultAspectLine;
AspectLine_applied = NULL; AspectLine_applied = NULL;
@ -176,3 +179,246 @@ void OpenGl_Workspace::ResetAppliedAspect()
AspectMarker(Standard_True); AspectMarker(Standard_True);
AspectText(Standard_True); AspectText(Standard_True);
} }
// =======================================================================
// function : DisableTexture
// purpose :
// =======================================================================
Handle(OpenGl_Texture) OpenGl_Workspace::DisableTexture()
{
if (myTextureBound.IsNull())
{
return myTextureBound;
}
// reset texture matrix because some code may expect it is identity
GLint aMatrixMode = GL_TEXTURE;
glGetIntegerv (GL_MATRIX_MODE, &aMatrixMode);
glMatrixMode (GL_TEXTURE);
glLoadIdentity();
glMatrixMode (aMatrixMode);
myTextureBound->Unbind (myGlContext);
switch (myTextureBound->GetTarget())
{
case GL_TEXTURE_1D:
{
if (myTextureBound->GetParams()->GenMode() != GL_NONE)
{
glDisable (GL_TEXTURE_GEN_S);
}
glDisable (GL_TEXTURE_1D);
break;
}
case GL_TEXTURE_2D:
{
if (myTextureBound->GetParams()->GenMode() != GL_NONE)
{
glDisable (GL_TEXTURE_GEN_S);
glDisable (GL_TEXTURE_GEN_T);
}
glDisable (GL_TEXTURE_2D);
break;
}
default: break;
}
Handle(OpenGl_Texture) aPrevTexture = myTextureBound;
myTextureBound.Nullify();
return aPrevTexture;
}
// =======================================================================
// function : setTextureParams
// purpose :
// =======================================================================
void OpenGl_Workspace::setTextureParams (Handle(OpenGl_Texture)& theTexture,
const Handle(Graphic3d_TextureParams)& theParams)
{
const Handle(Graphic3d_TextureParams)& aParams = theParams.IsNull() ? theTexture->GetParams() : theParams;
if (aParams.IsNull())
{
return;
}
GLint aMatrixMode = GL_TEXTURE;
glGetIntegerv (GL_MATRIX_MODE, &aMatrixMode);
// setup texture matrix
glMatrixMode (GL_TEXTURE);
glLoadIdentity();
const Graphic3d_Vec2& aScale = aParams->Scale();
const Graphic3d_Vec2& aTrans = aParams->Translation();
glScalef ( aScale.x(), aScale.y(), 1.0f);
glTranslatef (-aTrans.x(), -aTrans.y(), 0.0f);
glRotatef (-aParams->Rotation(), 0.0f, 0.0f, 1.0f);
// setup generation of texture coordinates
switch (aParams->GenMode())
{
case Graphic3d_TOTM_OBJECT:
{
glTexGeni (GL_S, GL_TEXTURE_GEN_MODE, GL_OBJECT_LINEAR);
glTexGenfv (GL_S, GL_OBJECT_PLANE, aParams->GenPlaneS().GetData());
if (theTexture->GetTarget() != GL_TEXTURE_1D)
{
glTexGeni (GL_T, GL_TEXTURE_GEN_MODE, GL_OBJECT_LINEAR);
glTexGenfv (GL_T, GL_OBJECT_PLANE, aParams->GenPlaneT().GetData());
}
break;
}
case Graphic3d_TOTM_SPHERE:
{
glTexGeni (GL_S, GL_TEXTURE_GEN_MODE, GL_SPHERE_MAP);
if (theTexture->GetTarget() != GL_TEXTURE_1D)
{
glTexGeni (GL_T, GL_TEXTURE_GEN_MODE, GL_SPHERE_MAP);
}
break;
}
case Graphic3d_TOTM_EYE:
{
glMatrixMode (GL_MODELVIEW);
glPushMatrix();
glLoadIdentity();
glTexGeni (GL_S, GL_TEXTURE_GEN_MODE, GL_EYE_LINEAR);
glTexGenfv (GL_S, GL_EYE_PLANE, aParams->GenPlaneS().GetData());
if (theTexture->GetTarget() != GL_TEXTURE_1D)
{
glTexGeni (GL_T, GL_TEXTURE_GEN_MODE, GL_EYE_LINEAR);
glTexGenfv (GL_T, GL_EYE_PLANE, aParams->GenPlaneT().GetData());
}
glPopMatrix();
break;
}
case Graphic3d_TOTM_MANUAL:
default: break;
}
// setup lighting
glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, aParams->IsModulate() ? GL_MODULATE : GL_DECAL);
// setup texture filtering and wrapping
//if (theTexture->GetParams() != theParams)
const GLenum aFilter = (aParams->Filter() == Graphic3d_TOTF_NEAREST) ? GL_NEAREST : GL_LINEAR;
const GLenum aWrapMode = aParams->IsRepeat() ? GL_REPEAT : GL_CLAMP;
switch (theTexture->GetTarget())
{
case GL_TEXTURE_1D:
{
glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, aFilter);
glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_MIN_FILTER, aFilter);
glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_WRAP_S, aWrapMode);
break;
}
case GL_TEXTURE_2D:
{
GLenum aFilterMin = aFilter;
if (theTexture->HasMipmaps())
{
aFilterMin = GL_NEAREST_MIPMAP_NEAREST;
if (aParams->Filter() == Graphic3d_TOTF_BILINEAR)
{
aFilterMin = GL_LINEAR_MIPMAP_NEAREST;
}
else if (aParams->Filter() == Graphic3d_TOTF_TRILINEAR)
{
aFilterMin = GL_LINEAR_MIPMAP_LINEAR;
}
if (myGlContext->extAnis)
{
// setup degree of anisotropy filter
const GLint aMaxDegree = myGlContext->MaxDegreeOfAnisotropy();
switch (aParams->AnisoFilter())
{
case Graphic3d_LOTA_QUALITY:
{
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAX_ANISOTROPY_EXT, aMaxDegree);
break;
}
case Graphic3d_LOTA_MIDDLE:
{
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAX_ANISOTROPY_EXT, (aMaxDegree <= 4) ? 2 : (aMaxDegree / 2));
break;
}
case Graphic3d_LOTA_FAST:
{
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAX_ANISOTROPY_EXT, 2);
break;
}
case Graphic3d_LOTA_OFF:
default:
{
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAX_ANISOTROPY_EXT, 1);
break;
}
}
}
}
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, aFilterMin);
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, aFilter);
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, aWrapMode);
glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, aWrapMode);
break;
}
default: break;
}
switch (theTexture->GetTarget())
{
case GL_TEXTURE_1D:
{
if (aParams->GenMode() != Graphic3d_TOTM_MANUAL)
{
glEnable (GL_TEXTURE_GEN_S);
}
glEnable (GL_TEXTURE_1D);
break;
}
case GL_TEXTURE_2D:
{
if (aParams->GenMode() != Graphic3d_TOTM_MANUAL)
{
glEnable (GL_TEXTURE_GEN_S);
glEnable (GL_TEXTURE_GEN_T);
}
glEnable (GL_TEXTURE_2D);
break;
}
default: break;
}
glMatrixMode (aMatrixMode); // turn back active matrix
theTexture->SetParams (aParams);
}
// =======================================================================
// function : EnableTexture
// purpose :
// =======================================================================
Handle(OpenGl_Texture) OpenGl_Workspace::EnableTexture (const Handle(OpenGl_Texture)& theTexture,
const Handle(Graphic3d_TextureParams)& theParams)
{
if (theTexture.IsNull() || !theTexture->IsValid())
{
return DisableTexture();
}
if (myTextureBound.IsNull() && myTextureBound == theTexture)
{
Handle(OpenGl_Texture) aPrevTexture = myTextureBound;
myTextureBound = theTexture;
return aPrevTexture;
}
Handle(OpenGl_Texture) aPrevTexture = DisableTexture();
myTextureBound = theTexture;
myTextureBound->Bind (myGlContext);
setTextureParams (myTextureBound, theParams);
return aPrevTexture;
}

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#ifndef _OpenGl_Workspace_Header #ifndef _OpenGl_Workspace_Header
#define _OpenGl_Workspace_Header #define _OpenGl_Workspace_Header
@ -26,29 +25,32 @@
#include <TColStd_Array2OfReal.hxx> #include <TColStd_Array2OfReal.hxx>
#include <Quantity_Color.hxx> #include <Quantity_Color.hxx>
#include <Graphic3d_TypeOfComposition.hxx>
#include <Graphic3d_CView.hxx> #include <Graphic3d_CView.hxx>
#include <Graphic3d_TypeOfComposition.hxx>
#include <Graphic3d_TypeOfTexture.hxx>
#include <Graphic3d_PtrFrameBuffer.hxx>
#include <Graphic3d_BufferType.hxx>
#include <Handle_Graphic3d_TextureParams.hxx>
#include <Aspect_CLayer2d.hxx> #include <Aspect_CLayer2d.hxx>
#include <Aspect_Handle.hxx> #include <Aspect_Handle.hxx>
#include <Aspect_PrintAlgo.hxx> #include <Aspect_PrintAlgo.hxx>
#include <Graphic3d_PtrFrameBuffer.hxx>
#include <Graphic3d_BufferType.hxx>
#include <InterfaceGraphic_Graphic3d.hxx> #include <InterfaceGraphic_Graphic3d.hxx>
#include <InterfaceGraphic_Visual3d.hxx> #include <InterfaceGraphic_Visual3d.hxx>
#include <OpenGl_tsm.hxx> #include <OpenGl_tsm.hxx>
#include <OpenGl_AspectFace.hxx>
#include <OpenGl_Display.hxx> #include <OpenGl_Display.hxx>
#include <OpenGl_Matrix.hxx> #include <OpenGl_Matrix.hxx>
#include <OpenGl_NamedStatus.hxx> #include <OpenGl_NamedStatus.hxx>
#include <OpenGl_TextParam.hxx> #include <OpenGl_TextParam.hxx>
#include <Handle_OpenGl_View.hxx> #include <Handle_OpenGl_View.hxx>
#include <Handle_OpenGl_Texture.hxx>
class OpenGl_AspectLine; class OpenGl_AspectLine;
class OpenGl_AspectFace;
class OpenGl_AspectMarker; class OpenGl_AspectMarker;
class OpenGl_AspectText; class OpenGl_AspectText;
class OpenGl_FrameBuffer; class OpenGl_FrameBuffer;
@ -88,8 +90,8 @@ public:
//! Special method to perform printing. //! Special method to perform printing.
//! System-specific and currently only Win platform implemented. //! System-specific and currently only Win platform implemented.
Standard_Boolean Print (const Graphic3d_CView& theCView, Standard_Boolean Print (const Graphic3d_CView& theCView,
const Aspect_CLayer2d& theCUnderLayer, const Aspect_CLayer2d& theCUnderLayer,
const Aspect_CLayer2d& theCOverLayer, const Aspect_CLayer2d& theCOverLayer,
const Aspect_Handle theHPrintDC, const Aspect_Handle theHPrintDC,
const Standard_Boolean theToShowBackground, const Standard_Boolean theToShowBackground,
@ -101,7 +103,7 @@ public:
// szvgl: defined in OpenGl_Workspace_1.cxx // szvgl: defined in OpenGl_Workspace_1.cxx
void BeginAnimation (const Standard_Boolean theUseDegeneration, void BeginAnimation (const Standard_Boolean theUseDegeneration,
const Standard_Boolean theUpdateAM); const Standard_Boolean theUpdateAM);
void EndAnimation(); void EndAnimation();
void EraseAnimation(); void EraseAnimation();
@ -165,6 +167,10 @@ public:
//! Clear the applied aspect state. //! Clear the applied aspect state.
void ResetAppliedAspect(); void ResetAppliedAspect();
Standard_EXPORT Handle(OpenGl_Texture) DisableTexture();
Standard_EXPORT Handle(OpenGl_Texture) EnableTexture (const Handle(OpenGl_Texture)& theTexture,
const Handle(Graphic3d_TextureParams)& theParams = NULL);
//// RELATED TO FONTS //// //// RELATED TO FONTS ////
int FindFont (const char* theFontName, int FindFont (const char* theFontName,
@ -198,28 +204,32 @@ protected:
virtual Standard_Boolean Activate(); virtual Standard_Boolean Activate();
// TEMPORARY!!! // TEMPORARY!!!
void Redraw1 (const Graphic3d_CView& theCView, void Redraw1 (const Graphic3d_CView& theCView,
const Aspect_CLayer2d& theCUnderLayer, const Aspect_CLayer2d& theCUnderLayer,
const Aspect_CLayer2d& theCOverLayer, const Aspect_CLayer2d& theCOverLayer,
const int theToSwap); const int theToSwap);
protected:
Handle(OpenGl_View) myView; // WSViews - now just one view is supported
Tint myTransientList; // WSTransient
Standard_Boolean myIsTransientOpen; // transientOpen
Tint myRetainMode; // WSRetainMode
Standard_Boolean myUseTransparency;
Standard_Boolean myUseZBuffer;
Standard_Boolean myUseDepthTest;
Standard_Boolean myUseGLLight;
Standard_Boolean myBackBufferRestored;
//// RELATED TO STATUS ////
void UpdateMaterial (const int flag); void UpdateMaterial (const int flag);
void setTextureParams (Handle(OpenGl_Texture)& theTexture,
const Handle(Graphic3d_TextureParams)& theParams);
protected: //! @name protected fields
Handle(OpenGl_View) myView; // WSViews - now just one view is supported
Tint myTransientList; // WSTransient
Standard_Boolean myIsTransientOpen; // transientOpen
Tint myRetainMode; // WSRetainMode
Standard_Boolean myUseTransparency;
Standard_Boolean myUseZBuffer;
Standard_Boolean myUseDepthTest;
Standard_Boolean myUseGLLight;
Standard_Boolean myBackBufferRestored;
protected: //! @name fields related to status
Handle(OpenGl_Texture) myTextureBound; //!< currently bound texture (managed by OpenGl_AspectFace and OpenGl_View environment texture)
const OpenGl_AspectLine *AspectLine_set, *AspectLine_applied; const OpenGl_AspectLine *AspectLine_set, *AspectLine_applied;
const OpenGl_AspectFace *AspectFace_set, *AspectFace_applied; const OpenGl_AspectFace *AspectFace_set, *AspectFace_applied;
const OpenGl_AspectMarker *AspectMarker_set, *AspectMarker_applied; const OpenGl_AspectMarker *AspectMarker_set, *AspectMarker_applied;
@ -232,11 +242,13 @@ protected:
const TEL_POFFSET_PARAM* PolygonOffset_applied; const TEL_POFFSET_PARAM* PolygonOffset_applied;
public: OpenGl_AspectFace myAspectFaceHl; // Hiddenline aspect
DEFINE_STANDARD_RTTI(OpenGl_Workspace) // Type definition public: //! @name type definition
DEFINE_STANDARD_RTTI(OpenGl_Workspace)
DEFINE_STANDARD_ALLOC DEFINE_STANDARD_ALLOC
}; };
#endif //_OpenGl_Workspace_Header #endif // _OpenGl_Workspace_Header

View File

@ -17,7 +17,6 @@
// purpose or non-infringement. Please see the License for the specific terms // purpose or non-infringement. Please see the License for the specific terms
// and conditions governing the rights and limitations under the License. // and conditions governing the rights and limitations under the License.
#include <math.h> #include <math.h>
#include <stdio.h> #include <stdio.h>
@ -26,6 +25,7 @@
#include <OpenGl_telem_util.hxx> #include <OpenGl_telem_util.hxx>
#include <OpenGl_AspectLine.hxx> #include <OpenGl_AspectLine.hxx>
#include <OpenGl_Structure.hxx> #include <OpenGl_Structure.hxx>
#include <OpenGl_Workspace.hxx>
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
# include <config.h> # include <config.h>
@ -44,7 +44,7 @@ static void call_util_transform_pt (float *x, float *y, float *z);
static void call_util_transpose_mat (float tmat[16], float mat[4][4]); static void call_util_transpose_mat (float tmat[16], float mat[4][4]);
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
/* /*
* Variables statiques * Variables statiques
*/ */
@ -162,7 +162,7 @@ void OpenGl_Workspace::RedrawImmediatMode ()
/* FMN necessaire pour l'affichage sur WNT */ /* FMN necessaire pour l'affichage sur WNT */
glFlush(); glFlush();
MakeBackBufCurrent(); MakeBackBufCurrent();
} }
} }
} }
@ -328,7 +328,7 @@ void OpenGl_Workspace::Move (const Standard_ShortReal X, const Standard_ShortRea
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
//call_togl_set_linecolor //call_togl_set_linecolor
void OpenGl_Workspace::SetLineColor (const Standard_ShortReal R, const Standard_ShortReal G, const Standard_ShortReal B) void OpenGl_Workspace::SetLineColor (const Standard_ShortReal R, const Standard_ShortReal G, const Standard_ShortReal B)
{ {
if (NamedStatus & (OPENGL_NS_ADD | OPENGL_NS_IMMEDIATE)) if (NamedStatus & (OPENGL_NS_ADD | OPENGL_NS_IMMEDIATE))
{ {

View File

@ -34,14 +34,13 @@
/* OCC22218 NOTE: project dependency on gl2ps is specified by macro */ /* OCC22218 NOTE: project dependency on gl2ps is specified by macro */
#ifdef HAVE_GL2PS #ifdef HAVE_GL2PS
#include <gl2ps.h> #include <gl2ps.h>
/* OCC22216 NOTE: linker dependency can be switched off by undefining macro. /* OCC22216 NOTE: linker dependency can be switched off by undefining macro.
Pragma comment for gl2ps.lib is defined only here. */ Pragma comment for gl2ps.lib is defined only here. */
#ifdef _MSC_VER #ifdef _MSC_VER
#pragma comment( lib, "gl2ps.lib" ) #pragma comment( lib, "gl2ps.lib" )
#endif #endif
#endif #endif
#include <OpenGl_TextureBox.hxx>
#include <Aspect_PolygonOffsetMode.hxx> #include <Aspect_PolygonOffsetMode.hxx>
#include <OpenGl_View.hxx> #include <OpenGl_View.hxx>
@ -51,7 +50,7 @@ static void TelUpdatePolygonOffsets( const TEL_POFFSET_PARAM *pdata )
{ {
if ( ( pdata->mode & Aspect_POM_Fill ) == Aspect_POM_Fill ) if ( ( pdata->mode & Aspect_POM_Fill ) == Aspect_POM_Fill )
glEnable ( GL_POLYGON_OFFSET_FILL ); glEnable ( GL_POLYGON_OFFSET_FILL );
else else
glDisable ( GL_POLYGON_OFFSET_FILL ); glDisable ( GL_POLYGON_OFFSET_FILL );
if ( ( pdata->mode & Aspect_POM_Line ) == Aspect_POM_Line ) if ( ( pdata->mode & Aspect_POM_Line ) == Aspect_POM_Line )
@ -72,22 +71,14 @@ static void TelUpdatePolygonOffsets( const TEL_POFFSET_PARAM *pdata )
void OpenGl_Workspace::UpdateMaterial( const int flag ) void OpenGl_Workspace::UpdateMaterial( const int flag )
{ {
// Case of Hiddenline // Case of Hiddenline
if (AspectFace_set->Context().InteriorStyle == Aspect_IS_HIDDENLINE) if (AspectFace_set->InteriorStyle == Aspect_IS_HIDDENLINE)
{ {
/* szvgl - IMPORTANT!!! */ myAspectFaceHl = *AspectFace_set; // copy all values including line edge aspect
static TEL_CONTEXT_FACE hl_context_face; myAspectFaceHl.IntFront.matcol = BackgroundColor();
static OpenGl_AspectFace hl_aspect_face; myAspectFaceHl.IntFront.color_mask = 0;
myAspectFaceHl.IntBack.color_mask = 0;
hl_context_face = AspectFace_set->Context(); AspectFace_set = &myAspectFaceHl;
hl_context_face.IntFront.matcol = BackgroundColor();
hl_context_face.IntFront.color_mask = 0;
hl_context_face.IntBack.color_mask = 0;
hl_aspect_face.SetContext(hl_context_face);
hl_aspect_face.SetAspectEdge(AspectFace_set->AspectEdge());
AspectFace_set = &hl_aspect_face;
return; return;
} }
@ -95,12 +86,12 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
GLenum face = 0; GLenum face = 0;
if ( flag == TEL_FRONT_MATERIAL ) if ( flag == TEL_FRONT_MATERIAL )
{ {
prop = &AspectFace_set->Context().IntFront; prop = &AspectFace_set->IntFront;
face = GL_FRONT_AND_BACK; face = GL_FRONT_AND_BACK;
} }
else else
{ {
prop = &AspectFace_set->Context().IntBack; prop = &AspectFace_set->IntBack;
face = GL_BACK; face = GL_BACK;
} }
@ -114,11 +105,11 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
if ( myUseTransparency && prop->trans != 1.0F ) if ( myUseTransparency && prop->trans != 1.0F )
{ {
// Render transparent // Render transparent
glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glEnable (GL_BLEND); glEnable (GL_BLEND);
glDepthMask (GL_FALSE); glDepthMask (GL_FALSE);
} }
else else
{ {
// Render opaque // Render opaque
if ( (NamedStatus & OPENGL_NS_ANTIALIASING) == 0 ) if ( (NamedStatus & OPENGL_NS_ANTIALIASING) == 0 )
@ -127,7 +118,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
glDisable (GL_BLEND); glDisable (GL_BLEND);
} }
glDepthMask (GL_TRUE); glDepthMask (GL_TRUE);
} }
} }
static float mAmb[4]; static float mAmb[4];
@ -140,7 +131,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
// Reset material // Reset material
if ( NamedStatus & OPENGL_NS_RESMAT ) if ( NamedStatus & OPENGL_NS_RESMAT )
{ {
// Ambient component // Ambient component
if( rm & OPENGL_AMBIENT_MASK ) if( rm & OPENGL_AMBIENT_MASK )
{ {
@ -177,7 +168,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
if (NamedStatus & OPENGL_NS_2NDPASSDO) if (NamedStatus & OPENGL_NS_2NDPASSDO)
{ {
mDiff[3] = prop->env_reflexion; mDiff[3] = prop->env_reflexion;
} }
else else
{ {
@ -194,7 +185,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
mSpec[0] = prop->spec * c[0]; mSpec[0] = prop->spec * c[0];
mSpec[1] = prop->spec * c[1]; mSpec[1] = prop->spec * c[1];
mSpec[2] = prop->spec * c[2]; mSpec[2] = prop->spec * c[2];
} }
else { else {
mSpec[0] = 0.F; mSpec[0] = 0.F;
mSpec[1] = 0.F; mSpec[1] = 0.F;
@ -204,7 +195,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
// Emissive component // Emissive component
if( rm & OPENGL_EMISSIVE_MASK ) if( rm & OPENGL_EMISSIVE_MASK )
{ {
const float *c = prop->isphysic? prop->emscol.rgb : prop->matcol.rgb; const float *c = prop->isphysic? prop->emscol.rgb : prop->matcol.rgb;
mEmsv[0] = prop->emsv * c[0]; mEmsv[0] = prop->emsv * c[0];
@ -228,10 +219,10 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
glMaterialf(face, GL_SHININESS, mShin); glMaterialf(face, GL_SHININESS, mShin);
NamedStatus &= ~OPENGL_NS_RESMAT; NamedStatus &= ~OPENGL_NS_RESMAT;
} }
// Set Material Optimize // Set Material Optimize
else else
{ {
// Ambient component // Ambient component
if( rm & OPENGL_AMBIENT_MASK ) if( rm & OPENGL_AMBIENT_MASK )
@ -280,7 +271,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
if (NamedStatus & OPENGL_NS_2NDPASSDO) if (NamedStatus & OPENGL_NS_2NDPASSDO)
{ {
mDiff[3] = prop->env_reflexion; mDiff[3] = prop->env_reflexion;
} }
else else
{ {
@ -298,7 +289,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
if (NamedStatus & OPENGL_NS_2NDPASSDO) if (NamedStatus & OPENGL_NS_2NDPASSDO)
{ {
newDiff3 = prop->env_reflexion; newDiff3 = prop->env_reflexion;
} }
else else
{ {
@ -323,7 +314,7 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
// Specular component // Specular component
if( rm & OPENGL_SPECULAR_MASK ) if( rm & OPENGL_SPECULAR_MASK )
{ {
const float *c = prop->isphysic? prop->speccol.rgb : defspeccol; const float *c = prop->isphysic? prop->speccol.rgb : defspeccol;
if (mSpec[0] != prop->spec * c[0] || if (mSpec[0] != prop->spec * c[0] ||
@ -368,8 +359,8 @@ void OpenGl_Workspace::UpdateMaterial( const int flag )
glMaterialfv(face, GL_EMISSION, mEmsv); glMaterialfv(face, GL_EMISSION, mEmsv);
} }
} }
else else
{ {
if ( mEmsv[0] != 0.F || mEmsv[1] != 0.F || mEmsv[2] != 0.F ) if ( mEmsv[0] != 0.F || mEmsv[1] != 0.F || mEmsv[2] != 0.F )
{ {
mEmsv[0] = 0.F; mEmsv[0] = 0.F;
@ -502,97 +493,115 @@ const OpenGl_AspectLine * OpenGl_Workspace::AspectLine(const Standard_Boolean Wi
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
const OpenGl_AspectFace * OpenGl_Workspace::AspectFace(const Standard_Boolean WithApply) const OpenGl_AspectFace* OpenGl_Workspace::AspectFace (const Standard_Boolean theToApply)
{ {
if ( WithApply && (AspectFace_set != AspectFace_applied) ) if (!theToApply || (AspectFace_set == AspectFace_applied))
{ {
const Aspect_InteriorStyle intstyle = AspectFace_set->Context().InteriorStyle; return AspectFace_set;
if ( !AspectFace_applied || AspectFace_applied->Context().InteriorStyle != intstyle ) }
const Aspect_InteriorStyle anIntstyle = AspectFace_set->InteriorStyle;
if (AspectFace_applied == NULL || AspectFace_applied->InteriorStyle != anIntstyle)
{
switch (anIntstyle)
{ {
switch( intstyle ) case Aspect_IS_EMPTY:
case Aspect_IS_HOLLOW:
{ {
case Aspect_IS_EMPTY: glPolygonMode (GL_FRONT_AND_BACK, GL_LINE);
case Aspect_IS_HOLLOW: break;
glPolygonMode(GL_FRONT_AND_BACK,GL_LINE); }
break; case Aspect_IS_HATCH:
{
case Aspect_IS_HATCH: glPolygonMode (GL_FRONT_AND_BACK, GL_FILL);
glPolygonMode(GL_FRONT_AND_BACK,GL_FILL); myDisplay->SetTypeOfHatch (AspectFace_applied != NULL ? AspectFace_applied->Hatch : TEL_HS_SOLID);
myDisplay->SetTypeOfHatch(AspectFace_applied? AspectFace_applied->Context().Hatch : TEL_HS_SOLID); break;
break; }
case Aspect_IS_SOLID:
case Aspect_IS_SOLID: case Aspect_IS_HIDDENLINE:
case Aspect_IS_HIDDENLINE: {
glPolygonMode(GL_FRONT_AND_BACK,GL_FILL); glPolygonMode (GL_FRONT_AND_BACK, GL_FILL);
glDisable(GL_POLYGON_STIPPLE); glDisable (GL_POLYGON_STIPPLE);
break; break;
}
case 5: //szvgl - no corresponding enumeration item Aspect_IS_POINT case 5: //szvgl - no corresponding enumeration item Aspect_IS_POINT
glPolygonMode(GL_FRONT_AND_BACK,GL_POINT); {
break; glPolygonMode(GL_FRONT_AND_BACK,GL_POINT);
break;
} }
} }
if( intstyle == Aspect_IS_HATCH ) }
if (anIntstyle == Aspect_IS_HATCH)
{
const Tint hatchstyle = AspectFace_set->Hatch;
if (AspectFace_applied == NULL || AspectFace_applied->Hatch != hatchstyle)
{ {
const Tint hatchstyle = AspectFace_set->Context().Hatch; myDisplay->SetTypeOfHatch(hatchstyle);
if( !AspectFace_applied || AspectFace_applied->Context().Hatch != hatchstyle )
{
myDisplay->SetTypeOfHatch(hatchstyle);
}
} }
if ( !ActiveView()->Backfacing() ) }
if (!ActiveView()->Backfacing())
{
const Tint aCullingMode = AspectFace_set->CullingMode;
if (AspectFace_applied == NULL || AspectFace_applied->CullingMode != aCullingMode)
{ {
const Tint mode = AspectFace_set->Context().CullingMode; switch ((TelCullMode )aCullingMode)
if( !AspectFace_applied || AspectFace_applied->Context().CullingMode != mode )
{ {
switch( (TelCullMode)mode ) case TelCullNone:
{ {
case TelCullNone: glDisable (GL_CULL_FACE);
glDisable(GL_CULL_FACE); break;
break; }
case TelCullFront:
case TelCullFront: {
glCullFace(GL_FRONT); glCullFace (GL_FRONT);
glEnable(GL_CULL_FACE); glEnable (GL_CULL_FACE);
break; break;
}
case TelCullBack: case TelCullBack:
glCullFace(GL_BACK); {
glEnable(GL_CULL_FACE); glCullFace (GL_BACK);
break; glEnable (GL_CULL_FACE);
break;
} }
} }
} }
}
// Aspect_POM_None means: do not change current settings // Aspect_POM_None means: do not change current settings
if ( ( AspectFace_set->Context().PolygonOffset.mode & Aspect_POM_None ) != Aspect_POM_None ) if ((AspectFace_set->PolygonOffset.mode & Aspect_POM_None) != Aspect_POM_None)
{
if (PolygonOffset_applied == NULL
|| PolygonOffset_applied->mode != AspectFace_set->PolygonOffset.mode
|| PolygonOffset_applied->factor != AspectFace_set->PolygonOffset.factor
|| PolygonOffset_applied->units != AspectFace_set->PolygonOffset.units)
{ {
if ( !PolygonOffset_applied || PolygonOffset_applied = &AspectFace_set->PolygonOffset;
PolygonOffset_applied->mode != AspectFace_set->Context().PolygonOffset.mode || TelUpdatePolygonOffsets (PolygonOffset_applied);
PolygonOffset_applied->factor != AspectFace_set->Context().PolygonOffset.factor ||
PolygonOffset_applied->units != AspectFace_set->Context().PolygonOffset.units )
{
PolygonOffset_applied = &AspectFace_set->Context().PolygonOffset;
TelUpdatePolygonOffsets( PolygonOffset_applied );
}
} }
}
UpdateMaterial( TEL_FRONT_MATERIAL ); UpdateMaterial (TEL_FRONT_MATERIAL);
if (AspectFace_set->Context().DistinguishingMode == TOn) if (AspectFace_set->DistinguishingMode == TOn)
UpdateMaterial( TEL_BACK_MATERIAL ); {
UpdateMaterial (TEL_BACK_MATERIAL);
}
if ((NamedStatus & OPENGL_NS_FORBIDSETTEX) == 0) if ((NamedStatus & OPENGL_NS_FORBIDSETTEX) == 0)
{
if (AspectFace_set->doTextureMap)
{
EnableTexture (AspectFace_set->TextureRes,
AspectFace_set->TextureParams);
}
else
{ {
DisableTexture(); DisableTexture();
if (AspectFace_set->Context().doTextureMap)
{
SetCurrentTexture(AspectFace_set->Context().TexId);
EnableTexture();
}
} }
AspectFace_applied = AspectFace_set;
} }
AspectFace_applied = AspectFace_set;
return AspectFace_set; return AspectFace_set;
} }

View File

@ -54,6 +54,7 @@
#include <AIS_ListIteratorOfListOfInteractive.hxx> #include <AIS_ListIteratorOfListOfInteractive.hxx>
#include <Aspect_InteriorStyle.hxx> #include <Aspect_InteriorStyle.hxx>
#include <Graphic3d_AspectFillArea3d.hxx> #include <Graphic3d_AspectFillArea3d.hxx>
#include <Graphic3d_TextureRoot.hxx>
#include <Image_AlienPixMap.hxx> #include <Image_AlienPixMap.hxx>
#include <Prs3d_ShadingAspect.hxx> #include <Prs3d_ShadingAspect.hxx>
@ -1786,61 +1787,6 @@ static int VDisplayAll( Draw_Interpretor& di, Standard_Integer argc, const char*
return 0; return 0;
} }
//#######################################################################################################
static TCollection_AsciiString GetEnvir (Draw_Interpretor& di) {
static Standard_Boolean IsDefined=Standard_False ;
static TCollection_AsciiString VarName;
if ( !IsDefined ) {
const char *envir, *casroot ;
envir = getenv("CSF_MDTVTexturesDirectory") ;
Standard_Boolean HasDefinition = Standard_False ;
if ( !envir ) {
casroot = getenv("CASROOT");
if ( casroot ) {
VarName = TCollection_AsciiString (casroot);
VarName += "/src/Textures" ;
HasDefinition = Standard_True ;
}
} else {
VarName = TCollection_AsciiString (envir);
HasDefinition = Standard_True ;
}
if ( HasDefinition ) {
OSD_Path aPath ( VarName );
OSD_Directory aDir(aPath);
if ( aDir.Exists () ) {
TCollection_AsciiString aTexture = VarName + "/2d_MatraDatavision.rgb" ;
OSD_File TextureFile ( aTexture );
if ( !TextureFile.Exists() ) {
di << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << "\n";
di << " not all files are found in : "<<VarName.ToCString() << "\n";
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
} else {
di << " CSF_MDTVTexturesDirectory or CASROOT not correctly setted " << "\n";
di << " Directory : "<< VarName.ToCString() << " not exist " << "\n";
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory or CASROOT not correctly setted " );
}
return VarName ;
} else {
di << " CSF_MDTVTexturesDirectory and CASROOT not setted " << "\n";
di << " one of these variable are mandatory to use this fonctionnality" << "\n";
Standard_Failure::Raise ( "CSF_MDTVTexturesDirectory and CASROOT not setted " );
}
IsDefined = Standard_True ;
}
return VarName ;
}
//#######################################################################################################
//####################################################################################################### //#######################################################################################################
//## VTexture //## VTexture
@ -1909,8 +1855,7 @@ Standard_Integer VTexture (Draw_Interpretor& di,Standard_Integer argc, const cha
{ {
if(strcasecmp(argv[2],"?")==0) if(strcasecmp(argv[2],"?")==0)
{ {
TCollection_AsciiString monPath = GetEnvir (di) ; TCollection_AsciiString monPath = Graphic3d_TextureRoot::TexturesFolder();
di<<"\n Files in current directory : \n"<<"\n"; di<<"\n Files in current directory : \n"<<"\n";
TCollection_AsciiString Cmnd ("glob -nocomplain *"); TCollection_AsciiString Cmnd ("glob -nocomplain *");
di.Eval(Cmnd.ToCString()); di.Eval(Cmnd.ToCString());

View File

@ -171,7 +171,6 @@ void VUserDrawObj::Render(const Handle(OpenGl_Workspace)& theWorkspace) const
// To test linking against OpenGl_Workspace and all aspect classes // To test linking against OpenGl_Workspace and all aspect classes
const OpenGl_AspectLine* aLA = theWorkspace->AspectLine(0); const OpenGl_AspectLine* aLA = theWorkspace->AspectLine(0);
const OpenGl_AspectFace* aFA = theWorkspace->AspectFace(0); const OpenGl_AspectFace* aFA = theWorkspace->AspectFace(0);
aFA->Context();
const OpenGl_AspectMarker* aMA = theWorkspace->AspectMarker(0); const OpenGl_AspectMarker* aMA = theWorkspace->AspectMarker(0);
aMA->Type(); aMA->Type();
const OpenGl_AspectText* aTA = theWorkspace->AspectText(0); const OpenGl_AspectText* aTA = theWorkspace->AspectText(0);

View File

@ -46,11 +46,6 @@
************************************************************************/ ************************************************************************/
#define IMP190100 //GG
// -> Enable to have overlapped BeginDraw() EndDraw().
// -> Don't redraw the scene at ClearDraw()
// but erase only the immediat draw stuff.
// for the class // for the class
#include <Visual3d_TransientManager.ixx> #include <Visual3d_TransientManager.ixx>
#include <Visual3d_ViewPtr.hxx> #include <Visual3d_ViewPtr.hxx>
@ -68,18 +63,14 @@
#define DEBUG_PRO4022 #define DEBUG_PRO4022
#define DEBUG_TEMPO_FOR_ROB #define DEBUG_TEMPO_FOR_ROB
enum TypeOfImmediat { enum TypeOfImmediat {
Immediat_None, Immediat_None,
Immediat_Transient, Immediat_Transient,
Immediat_Ajout Immediat_Ajout
}; };
//-Global data definitions //-Global data definitions
#ifdef IMP190100
static Standard_Integer theDrawingState = 0; static Standard_Integer theDrawingState = 0;
#else
static Standard_Boolean theDrawingState = Standard_False;
#endif
static Standard_Real theMinX,theMinY,theMinZ,theMaxX,theMaxY,theMaxZ; static Standard_Real theMinX,theMinY,theMinZ,theMaxX,theMaxY,theMaxZ;
static TypeOfImmediat theImmediatState = Immediat_None; static TypeOfImmediat theImmediatState = Immediat_None;
static Graphic3d_TypeOfPrimitive theTypeOfPrimitive = Graphic3d_TOP_UNDEFINED; static Graphic3d_TypeOfPrimitive theTypeOfPrimitive = Graphic3d_TOP_UNDEFINED;
@ -91,7 +82,7 @@ return theGraphicDriver;
#define theGraphicDriver _theGraphicDriver() #define theGraphicDriver _theGraphicDriver()
static Graphic3d_CView& _theCView() { static Graphic3d_CView& _theCView() {
static Graphic3d_CView theCView; static Graphic3d_CView theCView;
return theCView; return theCView;
} }
#define theCView _theCView() #define theCView _theCView()
@ -117,17 +108,13 @@ void Visual3d_TransientManager::Destroy () {
Standard_Boolean Visual3d_TransientManager::BeginDraw (const Handle(Visual3d_View)& AView, const Standard_Boolean DoubleBuffer, const Standard_Boolean RetainMode) { Standard_Boolean Visual3d_TransientManager::BeginDraw (const Handle(Visual3d_View)& AView, const Standard_Boolean DoubleBuffer, const Standard_Boolean RetainMode) {
#ifdef IMP190100
if (theDrawingState > 0) { if (theDrawingState > 0) {
CALL_DEF_VIEW* pview = (CALL_DEF_VIEW*) AView->CView(); Graphic3d_CView* pview = (Graphic3d_CView*) AView->CView();
if( theImmediatState == Immediat_Transient && if( theImmediatState == Immediat_Transient &&
pview->ViewId == theCView.ViewId ) { pview->ViewId == theCView.ViewId ) {
theDrawingState++; theDrawingState++;
return theDrawingState; return theDrawingState;
} else } else
#else
if (theDrawingState) {
#endif
Visual3d_TransientDefinitionError::Raise Visual3d_TransientDefinitionError::Raise
("Drawing in progress !"); ("Drawing in progress !");
} }
@ -135,7 +122,7 @@ Standard_Boolean Visual3d_TransientManager::BeginDraw (const Handle(Visual3d_Vie
Handle(Visual3d_Layer) OverLayer = AView->OverLayer (); Handle(Visual3d_Layer) OverLayer = AView->OverLayer ();
Handle(Visual3d_Layer) UnderLayer = AView->UnderLayer (); Handle(Visual3d_Layer) UnderLayer = AView->UnderLayer ();
OverCLayer.ptrLayer = UnderCLayer.ptrLayer = NULL; OverCLayer.ptrLayer = UnderCLayer.ptrLayer = NULL;
theCView = *(CALL_DEF_VIEW *)AView->CView (); theCView = *(Graphic3d_CView* )AView->CView ();
if (! UnderLayer.IsNull ()){ if (! UnderLayer.IsNull ()){
UnderCLayer = UnderLayer->CLayer(); UnderCLayer = UnderLayer->CLayer();
@ -153,11 +140,7 @@ Handle(Visual3d_Layer) UnderLayer = AView->UnderLayer ();
if (theGraphicDriver->BeginImmediatMode if (theGraphicDriver->BeginImmediatMode
(theCView, UnderCLayer, OverCLayer, DoubleBuffer, RetainMode)) { (theCView, UnderCLayer, OverCLayer, DoubleBuffer, RetainMode)) {
#ifdef IMP190100
theDrawingState++; theDrawingState++;
#else
theDrawingState = Standard_True;
#endif
theTypeOfPrimitive = Graphic3d_TOP_UNDEFINED; theTypeOfPrimitive = Graphic3d_TOP_UNDEFINED;
theImmediatState = Immediat_Transient; theImmediatState = Immediat_Transient;
// Reset MinMax // Reset MinMax
@ -174,19 +157,11 @@ Handle(Visual3d_Layer) UnderLayer = AView->UnderLayer ();
void Visual3d_TransientManager::EndDraw (const Standard_Boolean Synchronize) { void Visual3d_TransientManager::EndDraw (const Standard_Boolean Synchronize) {
#ifdef IMP190100
if( theDrawingState <= 0 ) if( theDrawingState <= 0 )
#else
if( !theDrawingState )
#endif
Visual3d_TransientDefinitionError::Raise ("Drawing not started !"); Visual3d_TransientDefinitionError::Raise ("Drawing not started !");
#ifdef IMP190100
theDrawingState--; theDrawingState--;
if( theDrawingState > 0 ) return; if( theDrawingState > 0 ) return;
#else
theDrawingState = Standard_False;
#endif
theImmediatState = Immediat_None; theImmediatState = Immediat_None;
// Flush all graphics // Flush all graphics
@ -196,17 +171,12 @@ void Visual3d_TransientManager::EndDraw (const Standard_Boolean Synchronize) {
void Visual3d_TransientManager::ClearDraw (const Handle(Visual3d_View)& AView, void Visual3d_TransientManager::ClearDraw (const Handle(Visual3d_View)& AView,
const Standard_Boolean aFlush) const Standard_Boolean aFlush)
{ {
#ifdef IMP190100
if (theDrawingState > 0) if (theDrawingState > 0)
#else
if (theDrawingState)
#endif
Visual3d_TransientDefinitionError::Raise Visual3d_TransientDefinitionError::Raise
("Drawing in progress !"); ("Drawing in progress !");
// Begin rendering // Begin rendering
theCView = *(CALL_DEF_VIEW *)AView->CView (); theCView = *(Graphic3d_CView* )AView->CView ();
if (!AView->UnderLayer().IsNull()) { if (!AView->UnderLayer().IsNull()) {
UnderCLayer = AView->UnderLayer()->CLayer(); UnderCLayer = AView->UnderLayer()->CLayer();
theCView.ptrUnderLayer = (CALL_DEF_LAYER *) &UnderCLayer; theCView.ptrUnderLayer = (CALL_DEF_LAYER *) &UnderCLayer;
@ -220,11 +190,6 @@ void Visual3d_TransientManager::ClearDraw (const Handle(Visual3d_View)& AView,
theGraphicDriver = *(Handle(Graphic3d_GraphicDriver) *) &agd; theGraphicDriver = *(Handle(Graphic3d_GraphicDriver) *) &agd;
theGraphicDriver->ClearImmediatMode (theCView, aFlush); theGraphicDriver->ClearImmediatMode (theCView, aFlush);
#ifndef IMP190100
// Reaffichage
AView->Redraw ();
#endif
} }
// //
@ -232,24 +197,19 @@ void Visual3d_TransientManager::ClearDraw (const Handle(Visual3d_View)& AView,
// //
Standard_Boolean Visual3d_TransientManager::BeginAddDraw (const Handle(Visual3d_View)& AView) { Standard_Boolean Visual3d_TransientManager::BeginAddDraw (const Handle(Visual3d_View)& AView) {
#ifdef IMP190100
if (theDrawingState > 0) { if (theDrawingState > 0) {
CALL_DEF_VIEW* pview = (CALL_DEF_VIEW*) AView->CView(); Graphic3d_CView* pview = (Graphic3d_CView* )AView->CView();
if( theImmediatState == Immediat_Ajout && if( theImmediatState == Immediat_Ajout &&
pview->ViewId == theCView.ViewId ) { pview->ViewId == theCView.ViewId ) {
theDrawingState++; theDrawingState++;
return theDrawingState; return theDrawingState;
} else } else
#else
if (theDrawingState) {
#endif
Visual3d_TransientDefinitionError::Raise Visual3d_TransientDefinitionError::Raise
("Drawing in progress !"); ("Drawing in progress !");
} }
// Begin rendering // Begin rendering
theCView = *(CALL_DEF_VIEW *)AView->CView (); theCView = *(Graphic3d_CView* )AView->CView ();
if (!AView->UnderLayer().IsNull()) { if (!AView->UnderLayer().IsNull()) {
UnderCLayer = AView->UnderLayer()->CLayer(); UnderCLayer = AView->UnderLayer()->CLayer();
theCView.ptrUnderLayer = (CALL_DEF_LAYER *) &UnderCLayer; theCView.ptrUnderLayer = (CALL_DEF_LAYER *) &UnderCLayer;
@ -263,11 +223,7 @@ Standard_Boolean Visual3d_TransientManager::BeginAddDraw (const Handle(Visual3d_
theGraphicDriver = *(Handle(Graphic3d_GraphicDriver) *) &agd; theGraphicDriver = *(Handle(Graphic3d_GraphicDriver) *) &agd;
if (theGraphicDriver->BeginAddMode (theCView)) { if (theGraphicDriver->BeginAddMode (theCView)) {
#ifdef IMP190100
theDrawingState++; theDrawingState++;
#else
theDrawingState = Standard_True;
#endif
theTypeOfPrimitive = Graphic3d_TOP_UNDEFINED; theTypeOfPrimitive = Graphic3d_TOP_UNDEFINED;
theImmediatState = Immediat_Ajout; theImmediatState = Immediat_Ajout;
// Reset MinMax // Reset MinMax
@ -284,19 +240,11 @@ Standard_Boolean Visual3d_TransientManager::BeginAddDraw (const Handle(Visual3d_
void Visual3d_TransientManager::EndAddDraw () { void Visual3d_TransientManager::EndAddDraw () {
#ifdef IMP190100
if( theDrawingState <= 0 ) if( theDrawingState <= 0 )
#else
if( !theDrawingState )
#endif
Visual3d_TransientDefinitionError::Raise ("Drawing not started !"); Visual3d_TransientDefinitionError::Raise ("Drawing not started !");
#ifdef IMP190100
theDrawingState--; theDrawingState--;
if( theDrawingState > 0 ) return; if( theDrawingState > 0 ) return;
#else
theDrawingState = Standard_False;
#endif
theImmediatState = Immediat_None; theImmediatState = Immediat_None;
// Flush all graphics // Flush all graphics
theGraphicDriver->EndAddMode(); theGraphicDriver->EndAddMode();
@ -540,8 +488,7 @@ Standard_ShortReal SRF = ShortRealFirst ();
theGraphicDriver->SetMinMax (x1, y1, z1, x2, y2, z2); theGraphicDriver->SetMinMax (x1, y1, z1, x2, y2, z2);
#endif /* DEBUG_PRO4022 */ #endif /* DEBUG_PRO4022 */
theGraphicDriver->DrawStructure theGraphicDriver->DrawStructure (*AStructure->CStructure());
(*(CALL_DEF_STRUCTURE *)AStructure->CStructure ());
} }
} }
@ -604,7 +551,7 @@ Quantity_Color AColor;
Aspect_TypeOfMarker AType; Aspect_TypeOfMarker AType;
CTX->Values (AColor,AType,AScale); CTX->Values (AColor,AType,AScale);
} }
void Visual3d_TransientManager::SetTransform (const TColStd_Array2OfReal& AMatrix, const Graphic3d_TypeOfComposition AType) { void Visual3d_TransientManager::SetTransform (const TColStd_Array2OfReal& AMatrix, const Graphic3d_TypeOfComposition AType) {
@ -625,7 +572,7 @@ Standard_Integer lr, ur, lc, uc;
("Visual3d_TransientManager::SetTransform, Bad Transformation matrix !"); ("Visual3d_TransientManager::SetTransform, Bad Transformation matrix !");
theGraphicDriver->Transform (AMatrix, AType); theGraphicDriver->Transform (AMatrix, AType);
} }
void Visual3d_TransientManager::MinMaxValues (Standard_Real& XMin, Standard_Real& YMin, Standard_Real& ZMin, Standard_Real& XMax, Standard_Real& YMax, Standard_Real& ZMax) { void Visual3d_TransientManager::MinMaxValues (Standard_Real& XMin, Standard_Real& YMin, Standard_Real& ZMin, Standard_Real& XMax, Standard_Real& YMax, Standard_Real& ZMax) {

View File

@ -85,8 +85,6 @@
#define GER61454 //GG 14-09-99 Activates model clipping planes #define GER61454 //GG 14-09-99 Activates model clipping planes
#define IMP140100 //GG14-01-00 Add ViewManager( ) method
#define G003 //EUG 30-09-00 Degeneration management #define G003 //EUG 30-09-00 Degeneration management
// Backfacing management // Backfacing management
@ -196,24 +194,18 @@ MyDisplayedStructure ()
{ {
Standard_Integer i, j; Standard_Integer i, j;
#ifdef IMP140100
MyPtrViewManager = AManager.operator->(); MyPtrViewManager = AManager.operator->();
#else
MyPtrViewManager = (void *) AManager.operator->();
#endif
memset (&MyCView, 0, sizeof(MyCView));
MyCView.ViewId = int (AManager->Identification (this)); MyCView.ViewId = int (AManager->Identification (this));
MyCView.Active = 0; MyCView.Active = 0;
MyCView.IsDeleted = 0; MyCView.IsDeleted = 0;
MyCView.WsId = -1; MyCView.WsId = -1;
MyCView.DefWindow.IsDefined = 0; MyCView.DefWindow.IsDefined = 0;
MyCView.Context.NbActiveLight = 0; MyCView.Context.NbActiveLight = 0;
MyCView.Context.NbActivePlane = 0; MyCView.Context.NbActivePlane = 0;
#ifdef GER61454 #ifdef GER61454
MyCView.Context.ActivePlane = NULL; MyCView.Context.ActivePlane = NULL;
#endif #endif
for (i=0; i<=3; i++) for (i=0; i<=3; i++)
@ -319,28 +311,22 @@ MyDisplayedStructure ()
{ {
Standard_Integer i, j; Standard_Integer i, j;
#ifdef IMP140100
MyPtrViewManager = AManager.operator->(); MyPtrViewManager = AManager.operator->();
#else
MyPtrViewManager = (void *) AManager.operator->();
#endif
MyViewOrientation = VO; MyViewOrientation = VO;
MyViewMapping = VM; MyViewMapping = VM;
MyContext = CTX; MyContext = CTX;
MyViewOrientationReset = VO; MyViewOrientationReset = VO;
MyViewMappingReset = VM; MyViewMappingReset = VM;
memset (&MyCView, 0, sizeof(MyCView));
MyCView.ViewId = int (AManager->Identification (this)); MyCView.ViewId = int (AManager->Identification (this));
MyCView.Active = 0; MyCView.Active = 0;
MyCView.IsDeleted = 0; MyCView.IsDeleted = 0;
MyCView.WsId = -1; MyCView.WsId = -1;
MyCView.DefWindow.IsDefined = 0; MyCView.DefWindow.IsDefined = 0;
MyCView.Context.NbActiveLight = 0; MyCView.Context.NbActiveLight = 0;
MyCView.Context.NbActivePlane = 0; MyCView.Context.NbActivePlane = 0;
#ifdef GER61454 #ifdef GER61454
MyCView.Context.ActivePlane = NULL; MyCView.Context.ActivePlane = NULL;
#endif #endif
@ -533,7 +519,7 @@ const Handle(WNT_Window) theWindow = *(Handle(WNT_Window) *) &AWindow;
// Update planses of model clipping // Update planses of model clipping
UpdatePlanes (); UpdatePlanes ();
// Update light sources // Update light sources
UpdateLights (); UpdateLights ();
/* /*
@ -907,7 +893,7 @@ CALL_DEF_PLANE *planes=NULL;
if (MyCView.Context.NbActivePlane > 0) { if (MyCView.Context.NbActivePlane > 0) {
// Dynamic Allocation // Dynamic Allocation
#ifdef GER61454 //Keep the plane address for the next Update ! #ifdef GER61454 //Keep the plane address for the next Update !
if( !MyCView.Context.ActivePlane ) if( !MyCView.Context.ActivePlane )
MyCView.Context.ActivePlane = new CALL_DEF_PLANE [j]; MyCView.Context.ActivePlane = new CALL_DEF_PLANE [j];
@ -1462,7 +1448,7 @@ void Visual3d_View::SetContext (const Visual3d_ContextView& CTX) {
Visual3d_TypeOfVisualization OldVisualMode; Visual3d_TypeOfVisualization OldVisualMode;
Visual3d_TypeOfVisualization NewVisualMode; Visual3d_TypeOfVisualization NewVisualMode;
// To manage display only in case of // To manage display only in case of
// change of visualisation mode. // change of visualisation mode.
OldVisualMode = MyContext.Visualization (); OldVisualMode = MyContext.Visualization ();
NewVisualMode = CTX.Visualization (); NewVisualMode = CTX.Visualization ();
@ -1470,7 +1456,7 @@ Visual3d_TypeOfVisualization NewVisualMode;
Visual3d_TypeOfModel OldModel; Visual3d_TypeOfModel OldModel;
Visual3d_TypeOfModel NewModel; Visual3d_TypeOfModel NewModel;
// To manage change of visualisation only in case // To manage change of visualisation only in case
// of change of mode of visualisation or of type of shading. // of change of mode of visualisation or of type of shading.
OldModel = MyContext.Model (); OldModel = MyContext.Model ();
NewModel = CTX.Model (); NewModel = CTX.Model ();
@ -1520,22 +1506,11 @@ Standard_Real NewZClippingBackPlane;
OldZClippingBackPlane = MyContext.ZClippingBackPlane (); OldZClippingBackPlane = MyContext.ZClippingBackPlane ();
NewZClippingBackPlane = CTX.ZClippingBackPlane (); NewZClippingBackPlane = CTX.ZClippingBackPlane ();
Standard_Integer OldTexEnvId; Handle(Graphic3d_TextureEnv) aTexEnvOld = MyContext.TextureEnv();
Standard_Integer NewTexEnvId; Handle(Graphic3d_TextureEnv) aTexEnvNew = CTX.TextureEnv();
Visual3d_TypeOfSurfaceDetail OldSurfaceDetail;
Visual3d_TypeOfSurfaceDetail NewSurfaceDetail;
Handle(Graphic3d_TextureEnv) TempTextureEnv1 = MyContext.TextureEnv(); Visual3d_TypeOfSurfaceDetail OldSurfaceDetail = MyContext.SurfaceDetail();
if (! TempTextureEnv1.IsNull()) OldTexEnvId = TempTextureEnv1->TextureId(); Visual3d_TypeOfSurfaceDetail NewSurfaceDetail = CTX.SurfaceDetail();
else OldTexEnvId = -1;
Handle(Graphic3d_TextureEnv) TempTextureEnv2 = CTX.TextureEnv();
if (! TempTextureEnv2.IsNull()) NewTexEnvId = TempTextureEnv2->TextureId();
else NewTexEnvId = -1;
OldSurfaceDetail = MyContext.SurfaceDetail();
NewSurfaceDetail = CTX.SurfaceDetail();
MyContext = CTX; MyContext = CTX;
@ -1580,14 +1555,15 @@ Standard_Boolean AWait = Standard_False; // => immediate update
} }
// management of textures // management of textures
if ( (OldTexEnvId != NewTexEnvId) || if ((aTexEnvOld != aTexEnvNew) || (OldSurfaceDetail != NewSurfaceDetail))
(OldSurfaceDetail != NewSurfaceDetail) ) {
MyGraphicDriver->Environment(MyCView); MyGraphicDriver->Environment(MyCView);
}
// Update of planes of model clipping // Update of planes of model clipping
UpdatePlanes (); UpdatePlanes ();
// Update of light sources // Update of light sources
UpdateLights (); UpdateLights ();
} }
@ -1610,7 +1586,7 @@ Graphic3d_SequenceOfStructure FooSequence;
while (S1Iterator.More ()) { while (S1Iterator.More ()) {
Answer = AcceptDisplay (S1Iterator.Key ()); Answer = AcceptDisplay (S1Iterator.Key ());
// If the structure can't be displayed in the // If the structure can't be displayed in the
// new context of the view, it is removed. // new context of the view, it is removed.
if ((Answer == Visual3d_TOA_NO) || if ((Answer == Visual3d_TOA_NO) ||
(Answer == Visual3d_TOA_COMPUTE)) (Answer == Visual3d_TOA_COMPUTE))
@ -1629,10 +1605,10 @@ Standard_Integer Length = FooSequence.Length ();
/* /*
* Change of context => * Change of context =>
* Display structures that can be displayed * Display structures that can be displayed
* with the new visualisation mode. * with the new visualisation mode.
* All structures with status Displayed are removed from the ViewManager * All structures with status Displayed are removed from the ViewManager
* and displayed in the view directly, if the structure is not already * and displayed in the view directly, if the structure is not already
* displayed and if the view accepts it in its context. * displayed and if the view accepts it in its context.
*/ */
@ -1645,7 +1621,7 @@ Standard_Integer Length = FooSequence.Length ();
Handle(Graphic3d_Structure) SG = it.Key(); Handle(Graphic3d_Structure) SG = it.Key();
if (! IsDisplayed (SG)) { if (! IsDisplayed (SG)) {
Answer = AcceptDisplay(SG); Answer = AcceptDisplay(SG);
// If the structure can be displayed in the // If the structure can be displayed in the
// new context of the view, it is displayed. // new context of the view, it is displayed.
if ((Answer == Visual3d_TOA_YES) || if ((Answer == Visual3d_TOA_YES) ||
(Answer == Visual3d_TOA_COMPUTE)) (Answer == Visual3d_TOA_COMPUTE))
@ -1708,8 +1684,8 @@ void Visual3d_View::Activate () {
* Activation of a new view => * Activation of a new view =>
* Display structures that can be displayed in this new view. * Display structures that can be displayed in this new view.
* All structures with status * All structures with status
* Displayed in ViewManager are returned and displayed in * Displayed in ViewManager are returned and displayed in
* the view directly, if the structure is not already * the view directly, if the structure is not already
* displayed and if the view accepts it in its context. * displayed and if the view accepts it in its context.
*/ */
@ -1777,8 +1753,8 @@ void Visual3d_View::Deactivate () {
* Deactivation of a view => * Deactivation of a view =>
* Removal of structures displayed in this view. * Removal of structures displayed in this view.
* All structures with status * All structures with status
* Displayed in ViewManager are returned and removed from * Displayed in ViewManager are returned and removed from
* the view directly, if the structure is not already * the view directly, if the structure is not already
* displayed and if the view accepts it in its context. * displayed and if the view accepts it in its context.
*/ */
@ -2118,7 +2094,7 @@ void Visual3d_View::Display (const Handle(Graphic3d_Structure)& AStructure, cons
if (! IsActive ()) return; if (! IsActive ()) return;
// If Display on a structure present in the list // If Display on a structure present in the list
// of calculated structures while it is not // of calculated structures while it is not
// or more, of calculated type => // or more, of calculated type =>
// - removes it as well as the associated old computed // - removes it as well as the associated old computed
// THis happens when hlhsr becomes again of type e // THis happens when hlhsr becomes again of type e
@ -2263,7 +2239,7 @@ Standard_Integer OldStructId =
// Cas COMPUTED invalid, WITHOUT a valid of replacement // Cas COMPUTED invalid, WITHOUT a valid of replacement
else { else {
// COMPUTED is removed if displayed // COMPUTED is removed if displayed
if (IsDisplayed (AStructure)) if (IsDisplayed (AStructure))
MyGraphicDriver->EraseStructure ( MyGraphicDriver->EraseStructure (
MyCView, MyCView,
@ -2374,7 +2350,7 @@ Standard_Boolean ComputeShading = ((ViewType == Visual3d_TOV_SHADING) &&
cout << flush; cout << flush;
#endif #endif
// It is displayed only if the calculated structure // It is displayed only if the calculated structure
// has a proper type corresponding to the one of the view. // has a proper type corresponding to the one of the view.
if (Answer != Visual3d_TOA_NO) { if (Answer != Visual3d_TOA_NO) {
if (! IsDisplayed (AStructure)) if (! IsDisplayed (AStructure))
@ -2403,7 +2379,7 @@ Standard_Integer StructId;
if (IsDeleted ()) return; if (IsDeleted ()) return;
// No test on window as the structure is displayed only if // No test on window as the structure is displayed only if
// the window exists, so only one test is enough. // the window exists, so only one test is enough.
if (IsDisplayed (AStructure)) { if (IsDisplayed (AStructure)) {
Visual3d_TypeOfAnswer Answer = AcceptDisplay (AStructure); Visual3d_TypeOfAnswer Answer = AcceptDisplay (AStructure);
@ -2602,7 +2578,7 @@ Graphic3d_MapIteratorOfMapOfStructure Iterator (MyDisplayedStructure);
Result = Result =
(((Iterator.Key ())->Visual ()) == Graphic3d_TOS_COMPUTED); (((Iterator.Key ())->Visual ()) == Graphic3d_TOS_COMPUTED);
// Iterator.Next () is located on the // Iterator.Next () is located on the
// next structure // next structure
Iterator.Next (); Iterator.Next ();
} }
@ -2687,7 +2663,7 @@ void Visual3d_View::MinMaxValues (const Graphic3d_MapOfStructure& ASet, Standard
if ( ZM != RealLast() && ZM > ZMax ) if ( ZM != RealLast() && ZM > ZMax )
ZMax = ZM ; ZMax = ZM ;
} }
// Only non-empty and non-infinite structures // Only non-empty and non-infinite structures
// are taken into account for calculation of MinMax // are taken into account for calculation of MinMax
if (! (Iterator.Key ())->IsInfinite () && if (! (Iterator.Key ())->IsInfinite () &&
! (Iterator.Key ())->IsEmpty ()) { ! (Iterator.Key ())->IsEmpty ()) {
@ -3053,9 +3029,7 @@ void Visual3d_View::UpdateView () {
MyCView.Context.Model = int (MyContext.Model ()); MyCView.Context.Model = int (MyContext.Model ());
MyCView.Context.Visualization = int (MyContext.Visualization ()); MyCView.Context.Visualization = int (MyContext.Visualization ());
Handle(Graphic3d_TextureEnv) TempTextureEnv = MyContext.TextureEnv(); MyCView.Context.TextureEnv = MyContext.TextureEnv();
if (! TempTextureEnv.IsNull()) MyCView.Context.TexEnvId = TempTextureEnv->TextureId();
else MyCView.Context.TexEnvId = -1;
MyCView.Context.SurfaceDetail = MyContext.SurfaceDetail(); MyCView.Context.SurfaceDetail = MyContext.SurfaceDetail();
} }
@ -3093,7 +3067,7 @@ Standard_Integer Length = MyCOMPUTEDSequence.Length ();
* previous orientation. * previous orientation.
* Recalculation of new structures. * Recalculation of new structures.
* Passage of the degenerated mode ON to OFF => * Passage of the degenerated mode ON to OFF =>
* Remove structures that were calculated before * Remove structures that were calculated before
* the degenerated mode passed to ON. * the degenerated mode passed to ON.
* Recalculate new structures. * Recalculate new structures.
*/ */
@ -3261,7 +3235,7 @@ Standard_Boolean ComputeShading = ((ViewType == Visual3d_TOV_SHADING) &&
<< "\n" << flush; << "\n" << flush;
#endif #endif
// hlhsr and the new associated compute are removed // hlhsr and the new associated compute are removed
MyTOCOMPUTESequence.Remove (Index); MyTOCOMPUTESequence.Remove (Index);
MyCOMPUTEDSequence.Remove (Index); MyCOMPUTEDSequence.Remove (Index);
@ -3343,7 +3317,7 @@ Standard_Integer StructId;
while (S1Iterator.More ()) { while (S1Iterator.More ()) {
Answer = AcceptDisplay (S1Iterator.Key ()); Answer = AcceptDisplay (S1Iterator.Key ());
// If the structure was calculated, the previous one is // If the structure was calculated, the previous one is
// removed and the new one is displayed // removed and the new one is displayed
// (This is the role of passage into degenerated mode) // (This is the role of passage into degenerated mode)
@ -3414,10 +3388,10 @@ Standard_Integer StructId;
while (S1Iterator.More ()) { while (S1Iterator.More ()) {
Answer = AcceptDisplay (S1Iterator.Key ()); Answer = AcceptDisplay (S1Iterator.Key ());
// If the structure was calculated, the previous one is // If the structure was calculated, the previous one is
// removed and the new one is displayed // removed and the new one is displayed
// (This is the role of passage into degenerated mode) // (This is the role of passage into degenerated mode)
if (Answer == Visual3d_TOA_COMPUTE) { if (Answer == Visual3d_TOA_COMPUTE) {
Standard_Integer Index = IsComputed (S1Iterator.Key ()); Standard_Integer Index = IsComputed (S1Iterator.Key ());
if (Index != 0) { if (Index != 0) {
@ -3452,7 +3426,7 @@ Standard_Integer Index = IsComputed (S1Iterator.Key ());
} }
} }
else { else {
// Else is impossible // Else is impossible
// Degenerated mode was activated before display of the // Degenerated mode was activated before display of the
// structure. So the structure was displayed in the // structure. So the structure was displayed in the
// degenerated mode, but the calculated structure didn't exist. // degenerated mode, but the calculated structure didn't exist.
@ -3589,7 +3563,7 @@ Graphic3d_MapIteratorOfMapOfStructure S1Iterator (MyDisplayedStructure);
else { else {
Standard_Integer Index = IsComputed (S1Iterator.Key ()); Standard_Integer Index = IsComputed (S1Iterator.Key ());
// As the mode is not degenerated the displayed structure // As the mode is not degenerated the displayed structure
// is plotted as if it was not calculated, otherwise the // is plotted as if it was not calculated, otherwise the
// associated calculated structure is plotted. // associated calculated structure is plotted.
if (Index == 0) if (Index == 0)
(S1Iterator.Key ())->Plot (APlotter); (S1Iterator.Key ())->Plot (APlotter);
@ -3608,7 +3582,7 @@ Standard_Integer Visual3d_View::HaveTheSameOwner (const Handle(Graphic3d_Structu
Standard_Integer Result = 0; Standard_Integer Result = 0;
Standard_Integer Length = MyTOCOMPUTESequence.Length (); Standard_Integer Length = MyTOCOMPUTESequence.Length ();
// Find in the sequence of already calculated structures // Find in the sequence of already calculated structures
// 1/ Structure with the same Owner as <AStructure> // 1/ Structure with the same Owner as <AStructure>
// 2/ Which is not <AStructure> // 2/ Which is not <AStructure>
// 3/ COMPUTED which of is valid // 3/ COMPUTED which of is valid
@ -3749,15 +3723,15 @@ Standard_Boolean Visual3d_View::GetGraduatedTrihedron
/* Names of axes */ /* Names of axes */
xname = MyGTrihedron.xname; xname = MyGTrihedron.xname;
yname = MyGTrihedron.yname; yname = MyGTrihedron.yname;
zname = MyGTrihedron.zname; zname = MyGTrihedron.zname;
/* Draw names */ /* Draw names */
xdrawname = MyGTrihedron.xdrawname; xdrawname = MyGTrihedron.xdrawname;
ydrawname = MyGTrihedron.ydrawname; ydrawname = MyGTrihedron.ydrawname;
zdrawname = MyGTrihedron.zdrawname; zdrawname = MyGTrihedron.zdrawname;
/* Draw values */ /* Draw values */
xdrawvalues = MyGTrihedron.xdrawvalues; xdrawvalues = MyGTrihedron.xdrawvalues;
ydrawvalues = MyGTrihedron.ydrawvalues; ydrawvalues = MyGTrihedron.ydrawvalues;
zdrawvalues = MyGTrihedron.zdrawvalues; zdrawvalues = MyGTrihedron.zdrawvalues;
/* Draw grid */ /* Draw grid */
drawgrid = MyGTrihedron.drawgrid; drawgrid = MyGTrihedron.drawgrid;
@ -3965,12 +3939,10 @@ Standard_Integer Visual3d_View::PlaneLimit() const {
return maxplane; return maxplane;
} }
#ifdef IMP140100 Handle(Visual3d_ViewManager) Visual3d_View::ViewManager() const
Handle(Visual3d_ViewManager) Visual3d_View::ViewManager() const { {
return MyPtrViewManager;
return MyPtrViewManager;
} }
#endif
#ifdef G003 #ifdef G003
void Visual3d_View :: SetComputedMode ( const Standard_Boolean aMode ) { void Visual3d_View :: SetComputedMode ( const Standard_Boolean aMode ) {
@ -4339,7 +4311,7 @@ void Visual3d_View::AddZLayer (const Standard_Integer theLayerId)
//======================================================================= //=======================================================================
//function : RemoveZLayer //function : RemoveZLayer
//purpose : //purpose :
//======================================================================= //=======================================================================
void Visual3d_View::RemoveZLayer (const Standard_Integer theLayerId) void Visual3d_View::RemoveZLayer (const Standard_Integer theLayerId)
@ -4349,7 +4321,7 @@ void Visual3d_View::RemoveZLayer (const Standard_Integer theLayerId)
//======================================================================= //=======================================================================
//function : ChangeZLayer //function : ChangeZLayer
//purpose : //purpose :
//======================================================================= //=======================================================================
void Visual3d_View::ChangeZLayer (const Handle(Graphic3d_Structure)& theStructure, void Visual3d_View::ChangeZLayer (const Handle(Graphic3d_Structure)& theStructure,

View File

@ -35,7 +35,7 @@
24-10-97 : CAL ; Retrait de DownCast. 24-10-97 : CAL ; Retrait de DownCast.
20-11-97 : CAL ; Disparition de la dependance avec math 20-11-97 : CAL ; Disparition de la dependance avec math
01-12-97 : CAL ; Retrait du test IsActive sur l'Update et le Redraw 01-12-97 : CAL ; Retrait du test IsActive sur l'Update et le Redraw
31-12-97 : CAL ; Disparition de MathGra 31-12-97 : CAL ; Disparition de MathGra
16-01-98 : CAL ; Ajout du SetTransform sur une TOS_COMPUTED 16-01-98 : CAL ; Ajout du SetTransform sur une TOS_COMPUTED
11-03-98 : CAL ; Visual3d_ViewManager::Remove () 11-03-98 : CAL ; Visual3d_ViewManager::Remove ()
20-05-98 : CAL ; Perfs. Connection entre structures COMPUTED. 20-05-98 : CAL ; Perfs. Connection entre structures COMPUTED.
@ -161,7 +161,7 @@ void Visual3d_ViewManager::ChangeDisplayPriority (const Handle(Graphic3d_Structu
// Change structure priority in all defined views // Change structure priority in all defined views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->ChangeDisplayPriority (MyIterator.Value ())->ChangeDisplayPriority
(AStructure, OldPriority, NewPriority); (AStructure, OldPriority, NewPriority);
@ -172,14 +172,14 @@ void Visual3d_ViewManager::ChangeDisplayPriority (const Handle(Graphic3d_Structu
} }
void Visual3d_ViewManager::ReCompute (const Handle(Graphic3d_Structure)& AStructure) { void Visual3d_ViewManager::ReCompute (const Handle(Graphic3d_Structure)& AStructure) {
//Standard_Integer LengthD = MyDisplayedStructure.Extent() (); //Standard_Integer LengthD = MyDisplayedStructure.Extent() ();
// Even if physically the structure cannot // Even if physically the structure cannot
// be displayed (pb of visualisation type) // be displayed (pb of visualisation type)
// it has status Displayed. // it has status Displayed.
if (!MyDisplayedStructure.Contains(AStructure)) if (!MyDisplayedStructure.Contains(AStructure))
return; return;
@ -187,19 +187,19 @@ void Visual3d_ViewManager::ReCompute (const Handle(Graphic3d_Structure)& AStruct
// Recompute structure in all activated views // Recompute structure in all activated views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->ReCompute (AStructure); (MyIterator.Value ())->ReCompute (AStructure);
// MyIterator.Next () is located on the next view // MyIterator.Next () is located on the next view
MyIterator.Next (); MyIterator.Next ();
} }
} }
void Visual3d_ViewManager::ReCompute (const Handle(Graphic3d_Structure)& AStructure, void Visual3d_ViewManager::ReCompute (const Handle(Graphic3d_Structure)& AStructure,
const Handle(Graphic3d_DataStructureManager)& AProjector) const Handle(Graphic3d_DataStructureManager)& AProjector)
{ {
if (! AProjector->IsKind (STANDARD_TYPE (Visual3d_View))) return; if (! AProjector->IsKind (STANDARD_TYPE (Visual3d_View))) return;
@ -215,12 +215,12 @@ void Visual3d_ViewManager::ReCompute (const Handle(Graphic3d_Structure)& AStruct
// it has status Displayed. // it has status Displayed.
if (!MyDisplayedStructure.Contains(AStructure)) if (!MyDisplayedStructure.Contains(AStructure))
return; return;
// //
// Recompute structure in all activated views // Recompute structure in all activated views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
if ((MyIterator.Value ())->Identification () == ViewId) if ((MyIterator.Value ())->Identification () == ViewId)
theView->ReCompute (AStructure); theView->ReCompute (AStructure);
@ -234,7 +234,7 @@ void Visual3d_ViewManager::ReCompute (const Handle(Graphic3d_Structure)& AStruct
void Visual3d_ViewManager::Clear (const Handle(Graphic3d_Structure)& AStructure, const Standard_Boolean WithDestruction) { void Visual3d_ViewManager::Clear (const Handle(Graphic3d_Structure)& AStructure, const Standard_Boolean WithDestruction) {
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Clear (AStructure, WithDestruction); (MyIterator.Value ())->Clear (AStructure, WithDestruction);
@ -247,7 +247,7 @@ void Visual3d_ViewManager::Clear (const Handle(Graphic3d_Structure)& AStructure,
void Visual3d_ViewManager::Connect (const Handle(Graphic3d_Structure)& AMother, const Handle(Graphic3d_Structure)& ADaughter) { void Visual3d_ViewManager::Connect (const Handle(Graphic3d_Structure)& AMother, const Handle(Graphic3d_Structure)& ADaughter) {
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Connect (AMother, ADaughter); (MyIterator.Value ())->Connect (AMother, ADaughter);
@ -260,7 +260,7 @@ void Visual3d_ViewManager::Connect (const Handle(Graphic3d_Structure)& AMother,
void Visual3d_ViewManager::Disconnect (const Handle(Graphic3d_Structure)& AMother, const Handle(Graphic3d_Structure)& ADaughter) { void Visual3d_ViewManager::Disconnect (const Handle(Graphic3d_Structure)& AMother, const Handle(Graphic3d_Structure)& ADaughter) {
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Disconnect (AMother, ADaughter); (MyIterator.Value ())->Disconnect (AMother, ADaughter);
@ -270,7 +270,7 @@ void Visual3d_ViewManager::Disconnect (const Handle(Graphic3d_Structure)& AMothe
} }
void Visual3d_ViewManager::Display (const Handle(Graphic3d_Structure)& AStructure) { void Visual3d_ViewManager::Display (const Handle(Graphic3d_Structure)& AStructure) {
// Even if physically the structure cannot // Even if physically the structure cannot
@ -283,7 +283,7 @@ void Visual3d_ViewManager::Display (const Handle(Graphic3d_Structure)& AStructur
// Display structure in all activated views // Display structure in all activated views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Display (AStructure); (MyIterator.Value ())->Display (AStructure);
@ -308,7 +308,7 @@ void Visual3d_ViewManager::Erase (const Handle(Graphic3d_Structure)& AStructure)
// Erase structure in all defined views // Erase structure in all defined views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Erase (AStructure); (MyIterator.Value ())->Erase (AStructure);
@ -325,7 +325,7 @@ void Visual3d_ViewManager::Erase (const Handle(Graphic3d_Structure)& AStructure)
void Visual3d_ViewManager::Erase () { void Visual3d_ViewManager::Erase () {
Graphic3d_MapIteratorOfMapOfStructure it( MyDisplayedStructure); Graphic3d_MapIteratorOfMapOfStructure it( MyDisplayedStructure);
for (; it.More(); it.Next()) { for (; it.More(); it.Next()) {
Handle(Graphic3d_Structure) SG = it.Key(); Handle(Graphic3d_Structure) SG = it.Key();
SG->Erase(); SG->Erase();
@ -341,7 +341,7 @@ void Visual3d_ViewManager::Highlight (const Handle(Graphic3d_Structure)& AStruct
// Highlight in all activated views // Highlight in all activated views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Highlight (AStructure, AMethod); (MyIterator.Value ())->Highlight (AStructure, AMethod);
@ -354,7 +354,7 @@ void Visual3d_ViewManager::Highlight (const Handle(Graphic3d_Structure)& AStruct
void Visual3d_ViewManager::SetTransform (const Handle(Graphic3d_Structure)& AStructure, const TColStd_Array2OfReal& ATrsf) { void Visual3d_ViewManager::SetTransform (const Handle(Graphic3d_Structure)& AStructure, const TColStd_Array2OfReal& ATrsf) {
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->SetTransform (AStructure, ATrsf); (MyIterator.Value ())->SetTransform (AStructure, ATrsf);
@ -367,7 +367,7 @@ void Visual3d_ViewManager::SetTransform (const Handle(Graphic3d_Structure)& AStr
void Visual3d_ViewManager::UnHighlight () { void Visual3d_ViewManager::UnHighlight () {
Graphic3d_MapIteratorOfMapOfStructure it(MyHighlightedStructure); Graphic3d_MapIteratorOfMapOfStructure it(MyHighlightedStructure);
for (; it.More(); it.Next()) { for (; it.More(); it.Next()) {
Handle(Graphic3d_Structure) SG = it.Key(); Handle(Graphic3d_Structure) SG = it.Key();
SG->UnHighlight (); SG->UnHighlight ();
@ -385,7 +385,7 @@ void Visual3d_ViewManager::UnHighlight (const Handle(Graphic3d_Structure)& AStru
// UnHighlight in all activated views // UnHighlight in all activated views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->UnHighlight (AStructure); (MyIterator.Value ())->UnHighlight (AStructure);
@ -407,7 +407,7 @@ Standard_Integer Dx, Dy;
Standard_Integer j = MyDefinedView.Extent (); Standard_Integer j = MyDefinedView.Extent ();
if (j == 0) return; if (j == 0) return;
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
if (! MyUnderLayer.IsNull () || ! MyOverLayer.IsNull ()) { if (! MyUnderLayer.IsNull () || ! MyOverLayer.IsNull ()) {
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Window ()->Size (Dx, Dy); (MyIterator.Value ())->Window ()->Size (Dx, Dy);
@ -422,7 +422,7 @@ Standard_Integer Dx, Dy;
if (! MyOverLayer.IsNull ()) if (! MyOverLayer.IsNull ())
MyOverLayer->SetViewport (MaxDx, MaxDy); MyOverLayer->SetViewport (MaxDx, MaxDy);
} }
if (! MyUnderLayer.IsNull () || ! MyOverLayer.IsNull ()) if (! MyUnderLayer.IsNull () || ! MyOverLayer.IsNull ())
MyIterator.Initialize (MyDefinedView); MyIterator.Initialize (MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
@ -442,7 +442,7 @@ void Visual3d_ViewManager::Update () const {
Standard_Integer j = MyDefinedView.Extent (); Standard_Integer j = MyDefinedView.Extent ();
if (j == 0) return; if (j == 0) return;
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
(MyIterator.Value ())->Update (MyUnderLayer, MyOverLayer); (MyIterator.Value ())->Update (MyUnderLayer, MyOverLayer);
@ -537,7 +537,7 @@ Standard_Real Dx, Dy, Ratio;
AVertex.Coord (AX, AY, AZ); AVertex.Coord (AX, AY, AZ);
Result = MyGraphicDriver->ProjectRaster (TheCView, Result = MyGraphicDriver->ProjectRaster (TheCView,
Standard_ShortReal (AX), Standard_ShortReal (AY), Standard_ShortReal (AZ), Standard_ShortReal (AX), Standard_ShortReal (AY), Standard_ShortReal (AZ),
AU, AV); AU, AV);
@ -985,7 +985,7 @@ const Handle(WNT_Window) theWindow = *(Handle(WNT_Window) *) &AspectWindow;
// Comparaison on window IDs // Comparaison on window IDs
if (TheWindowIdOfView == TheSpecifiedWindowId) { if (TheWindowIdOfView == TheSpecifiedWindowId) {
Exist = Standard_True; Exist = Standard_True;
TheCView = *(CALL_DEF_VIEW *)(MyIterator.Value ())->CView (); TheCView = *(Graphic3d_CView* )(MyIterator.Value())->CView();
} }
} /* if ((MyIterator.Value ())->IsDefined ()) */ } /* if ((MyIterator.Value ())->IsDefined ()) */
@ -1003,7 +1003,7 @@ void Visual3d_ViewManager::Activate () {
// Activates all deactivated views // Activates all deactivated views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
if (! (MyIterator.Value ())->IsActive ()) if (! (MyIterator.Value ())->IsActive ())
(MyIterator.Value ())->Activate (); (MyIterator.Value ())->Activate ();
@ -1020,7 +1020,7 @@ void Visual3d_ViewManager::Deactivate () {
// Deactivates all activated views // Deactivates all activated views
// //
Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView);
while (MyIterator.More ()) { while (MyIterator.More ()) {
if ((MyIterator.Value ())->IsActive ()) if ((MyIterator.Value ())->IsActive ())
(MyIterator.Value ())->Deactivate (); (MyIterator.Value ())->Deactivate ();
@ -1047,7 +1047,7 @@ Handle(Graphic3d_Structure) Visual3d_ViewManager::Identification (const Standard
} }
Standard_Integer Visual3d_ViewManager::Identification () const { Standard_Integer Visual3d_ViewManager::Identification () const {
return (Graphic3d_StructureManager::Identification ()); return (Graphic3d_StructureManager::Identification ());
} }
@ -1092,7 +1092,7 @@ void Visual3d_ViewManager::SetZBufferAuto (const Standard_Boolean AFlag) {
if (! MyZBufferAuto && ! AFlag) return; if (! MyZBufferAuto && ! AFlag) return;
// if pass from False to True : // if pass from False to True :
// no problem, at the next view update, it // no problem, at the next view update, it
// will properly ask questions to answer (SetVisualisation) // will properly ask questions to answer (SetVisualisation)
// if pass from True to False : // if pass from True to False :
// it is necessary to modify ZBufferActivity at each view so that // it is necessary to modify ZBufferActivity at each view so that
@ -1158,7 +1158,7 @@ const Handle(Visual3d_Layer)& Visual3d_ViewManager::OverLayer () const {
//======================================================================= //=======================================================================
//function : ChangeZLayer //function : ChangeZLayer
//purpose : //purpose :
//======================================================================= //=======================================================================
void Visual3d_ViewManager::ChangeZLayer (const Handle(Graphic3d_Structure)& theStructure, void Visual3d_ViewManager::ChangeZLayer (const Handle(Graphic3d_Structure)& theStructure,
@ -1166,7 +1166,7 @@ void Visual3d_ViewManager::ChangeZLayer (const Handle(Graphic3d_Structure)& theS
{ {
if (!myLayerIds.Contains (theLayerId)) if (!myLayerIds.Contains (theLayerId))
return; return;
// change display layer for structure in all views // change display layer for structure in all views
if (MyDisplayedStructure.Contains (theStructure)) if (MyDisplayedStructure.Contains (theStructure))
{ {
@ -1174,7 +1174,7 @@ void Visual3d_ViewManager::ChangeZLayer (const Handle(Graphic3d_Structure)& theS
for ( ; aViewIt.More (); aViewIt.Next ()) for ( ; aViewIt.More (); aViewIt.Next ())
(aViewIt.Value ())->ChangeZLayer (theStructure, theLayerId); (aViewIt.Value ())->ChangeZLayer (theStructure, theLayerId);
} }
// tell graphic driver to update the structure's display layer // tell graphic driver to update the structure's display layer
MyGraphicDriver->ChangeZLayer ( MyGraphicDriver->ChangeZLayer (
(*(Graphic3d_CStructure*)theStructure->CStructure ()), theLayerId); (*(Graphic3d_CStructure*)theStructure->CStructure ()), theLayerId);
@ -1223,7 +1223,7 @@ Standard_Boolean Visual3d_ViewManager::AddZLayer (Standard_Integer& theLayerId)
//======================================================================= //=======================================================================
//function : RemoveZLayer //function : RemoveZLayer
//purpose : //purpose :
//======================================================================= //=======================================================================
Standard_Boolean Visual3d_ViewManager::RemoveZLayer (const Standard_Integer theLayerId) Standard_Boolean Visual3d_ViewManager::RemoveZLayer (const Standard_Integer theLayerId)
@ -1282,7 +1282,7 @@ void Visual3d_ViewManager::InstallZLayers(const Handle(Visual3d_View)& theView)
{ {
if (!MyDefinedView.Contains (theView)) if (!MyDefinedView.Contains (theView))
return; return;
// erase and insert layers iteratively to provide the same layer order as // erase and insert layers iteratively to provide the same layer order as
// in the view manager's sequence. This approach bases on the layer insertion // in the view manager's sequence. This approach bases on the layer insertion
// order: the new layers are always appended to the end of the list // order: the new layers are always appended to the end of the list