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

0031705: Visualization - move out construction of predefined markers from OpenGl_AspectsSprite to Graphic3d_MarkerImage

Built-in markers definition has been moved from OpenGl_AspectsSprite to Graphic3d_MarkerImage and generalized.
RGBA8 pixel format is now preferred over BGRA8.
Fallback OpenGL 1.1 rendering code now supports drawing of colored markers using glDrawPixels().

Added function Image_PixMap::FlipY() flipping image rows.
This commit is contained in:
mkrylova 2020-11-20 15:10:23 +03:00 committed by bugmaster
parent a8d3a0b102
commit 59500bb229
10 changed files with 1761 additions and 1745 deletions

View File

@ -96,6 +96,7 @@ Graphic3d_MapOfStructure.hxx
Graphic3d_MapOfZLayerSettings.hxx
Graphic3d_MarkerImage.cxx
Graphic3d_MarkerImage.hxx
Graphic3d_MarkerImage.pxx
Graphic3d_Mat4.hxx
Graphic3d_Mat4d.hxx
Graphic3d_MaterialAspect.cxx

View File

@ -19,20 +19,146 @@
#include <Standard_Atomic.hxx>
#include <TColStd_HArray1OfByte.hxx>
#include "Graphic3d_MarkerImage.pxx"
IMPLEMENT_STANDARD_RTTIEXT(Graphic3d_MarkerImage,Standard_Transient)
namespace
{
static volatile Standard_Integer THE_MARKER_IMAGE_COUNTER = 0;
}
//! Returns a parameters for the marker of the specified type and scale.
static void getMarkerBitMapParam (const Aspect_TypeOfMarker theMarkerType,
const Standard_ShortReal theScale,
Standard_Integer& theWidth,
Standard_Integer& theHeight,
Standard_Integer& theOffset,
Standard_Integer& theNumOfBytes)
{
const Standard_Integer aType = Standard_Integer(theMarkerType > Aspect_TOM_O
? Aspect_TOM_O
: theMarkerType);
const Standard_Real anIndex = (Standard_Real)(TEL_NO_OF_SIZES - 1) * (theScale - (Standard_Real)TEL_PM_START_SIZE)
/ (Standard_Real)(TEL_PM_END_SIZE - TEL_PM_START_SIZE);
Standard_Integer anId = (Standard_Integer)(anIndex + 0.5);
if (anId < 0)
{
anId = 0;
}
else if (anId >= TEL_NO_OF_SIZES)
{
anId = TEL_NO_OF_SIZES - 1;
}
theWidth = (Standard_Integer)arrPMFontInfo[aType][anId].width;
theHeight = (Standard_Integer)arrPMFontInfo[aType][anId].height;
theOffset = arrPMFontInfo[aType][anId].offset;
const Standard_Integer aNumOfBytesInRow = theWidth / 8 + (theWidth % 8 ? 1 : 0);
theNumOfBytes = theHeight * aNumOfBytesInRow;
}
//! Merge two image pixmap into one. Used for creating image for following markers:
//! Aspect_TOM_O_POINT, Aspect_TOM_O_PLUS, Aspect_TOM_O_STAR, Aspect_TOM_O_X, Aspect_TOM_RING1, Aspect_TOM_RING2, Aspect_TOM_RING3
static Handle(Image_PixMap) mergeImages (const Handle(Image_PixMap)& theImage1,
const Handle(Image_PixMap)& theImage2)
{
if (theImage1.IsNull() && theImage2.IsNull())
{
return Handle(Image_PixMap)();
}
Handle(Image_PixMap) aResultImage = new Image_PixMap();
Standard_Integer aWidth1 = 0, aHeight1 = 0;
if (!theImage1.IsNull())
{
aWidth1 = (Standard_Integer )theImage1->Width();
aHeight1 = (Standard_Integer )theImage1->Height();
}
Standard_Integer aWidth2 = 0, aHeight2 = 0;
if (!theImage2.IsNull())
{
aWidth2 = (Standard_Integer )theImage2->Width();
aHeight2 = (Standard_Integer )theImage2->Height();
}
const Standard_Integer aMaxWidth = Max (aWidth1, aWidth2);
const Standard_Integer aMaxHeight = Max (aHeight1, aHeight2);
const Standard_Integer aSize = Max (aMaxWidth, aMaxHeight);
aResultImage->InitZero (Image_Format_Alpha, aSize, aSize);
if (!theImage1.IsNull())
{
const Standard_Integer aXOffset1 = Abs (aWidth1 - aMaxWidth) / 2;
const Standard_Integer anYOffset1 = Abs (aHeight1 - aMaxHeight) / 2;
for (Standard_Integer anY = 0; anY < aHeight1; anY++)
{
Standard_Byte* anImageLine = theImage1->ChangeRow (anY);
Standard_Byte* aResultImageLine = aResultImage->ChangeRow (anYOffset1 + anY);
for (Standard_Integer aX = 0; aX < aWidth1; aX++)
{
aResultImageLine[aXOffset1 + aX] |= anImageLine[aX];
}
}
}
if (!theImage2.IsNull())
{
const Standard_Integer aXOffset2 = Abs (aWidth2 - aMaxWidth) / 2;
const Standard_Integer anYOffset2 = Abs (aHeight2 - aMaxHeight) / 2;
for (Standard_Integer anY = 0; anY < aHeight2; anY++)
{
Standard_Byte* anImageLine = theImage2->ChangeRow (anY);
Standard_Byte* aResultImageLine = aResultImage->ChangeRow (anYOffset2 + anY);
for (Standard_Integer aX = 0; aX < aWidth2; aX++)
{
aResultImageLine[aXOffset2 + aX] |= anImageLine[aX];
}
}
}
return aResultImage;
}
//! Draw inner point as filled rectangle
static Handle(TColStd_HArray1OfByte) fillPointBitmap (const Standard_Integer theSize)
{
const Standard_Integer aNbBytes = (theSize / 8 + (theSize % 8 ? 1 : 0)) * theSize;
Handle(TColStd_HArray1OfByte) aBitMap = new TColStd_HArray1OfByte (0, aNbBytes - 1);
for (Standard_Integer anIter = 0; anIter < aBitMap->Length(); ++anIter)
{
aBitMap->SetValue (anIter, 255);
}
return aBitMap;
}
//! Returns a marker image for the marker of the specified type and scale.
static Handle(Graphic3d_MarkerImage) getTextureImage (const Aspect_TypeOfMarker theMarkerType,
const Standard_ShortReal theScale)
{
Standard_Integer aWidth = 0, aHeight = 0, anOffset = 0, aNbBytes = 0;
getMarkerBitMapParam (theMarkerType, theScale, aWidth, aHeight, anOffset, aNbBytes);
Handle(TColStd_HArray1OfByte) aBitMap = new TColStd_HArray1OfByte (0, aNbBytes - 1);
for (Standard_Integer anIter = 0; anIter < aNbBytes; ++anIter)
{
aBitMap->ChangeValue (anIter) = Graphic3d_MarkerImage_myMarkerRaster[anOffset + anIter];
}
Handle(Graphic3d_MarkerImage) aTexture = new Graphic3d_MarkerImage (aBitMap, aWidth, aHeight);
return aTexture;
}
}
// =======================================================================
// function : Graphic3d_MarkerImage
// purpose :
// =======================================================================
Graphic3d_MarkerImage::Graphic3d_MarkerImage (const Handle(Image_PixMap)& theImage)
Graphic3d_MarkerImage::Graphic3d_MarkerImage (const Handle(Image_PixMap)& theImage,
const Handle(Image_PixMap)& theImageAlpha)
: myImage (theImage),
myImageAlpha (theImageAlpha),
myMargin (1),
myWidth ((Standard_Integer )theImage->Width()),
myHeight ((Standard_Integer )theImage->Height())
@ -42,6 +168,20 @@ Graphic3d_MarkerImage::Graphic3d_MarkerImage (const Handle(Image_PixMap)& theIma
myImageAlphaId = TCollection_AsciiString ("Graphic3d_MarkerImageAlpha_")
+ TCollection_AsciiString (THE_MARKER_IMAGE_COUNTER);
if (!theImageAlpha.IsNull())
{
if (theImageAlpha->Format() != Image_Format_Alpha
&& theImageAlpha->Format() != Image_Format_Gray)
{
throw Standard_ProgramError ("Graphic3d_MarkerImage, wrong color format of alpha image");
}
if (theImageAlpha->SizeX() != theImage->SizeX()
|| theImageAlpha->SizeY() != theImage->SizeY())
{
throw Standard_ProgramError ("Graphic3d_MarkerImage, wrong dimensions of alpha image");
}
}
}
// =======================================================================
@ -49,8 +189,8 @@ Graphic3d_MarkerImage::Graphic3d_MarkerImage (const Handle(Image_PixMap)& theIma
// purpose :
// =======================================================================
Graphic3d_MarkerImage::Graphic3d_MarkerImage (const Handle(TColStd_HArray1OfByte)& theBitMap,
const Standard_Integer& theWidth,
const Standard_Integer& theHeight)
const Standard_Integer theWidth,
const Standard_Integer theHeight)
: myBitMap (theBitMap),
myMargin (1),
myWidth (theWidth),
@ -63,31 +203,39 @@ Graphic3d_MarkerImage::Graphic3d_MarkerImage (const Handle(TColStd_HArray1OfByte
+ TCollection_AsciiString (THE_MARKER_IMAGE_COUNTER);
}
// =======================================================================
// function : IsColoredImage
// purpose :
// =======================================================================
bool Graphic3d_MarkerImage::IsColoredImage() const
{
return !myImage.IsNull()
&& myImage->Format() != Image_Format_Alpha
&& myImage->Format() != Image_Format_Gray;
}
// =======================================================================
// function : GetBitMapArray
// purpose :
// =======================================================================
Handle(TColStd_HArray1OfByte) Graphic3d_MarkerImage::GetBitMapArray (const Standard_Real& theAlphaValue) const
Handle(TColStd_HArray1OfByte) Graphic3d_MarkerImage::GetBitMapArray (const Standard_Real theAlphaValue,
const Standard_Boolean theIsTopDown) const
{
if (!myBitMap.IsNull())
if (!myBitMap.IsNull()
|| myImage.IsNull())
{
return myBitMap;
}
Handle(TColStd_HArray1OfByte) aBitMap;
if (myImage.IsNull())
{
return aBitMap;
}
const Standard_Integer aNumOfBytesInRow = (Standard_Integer )(myImage->Width() / 8) + (myImage->Width() % 8 ? 1 : 0);
const Standard_Integer aNumOfBytes = (Standard_Integer )(aNumOfBytesInRow * myImage->Height());
const Standard_Integer aHeight = (Standard_Integer )myImage->Height();
const Standard_Integer aWidth = (Standard_Integer )myImage->Width();
aBitMap = new TColStd_HArray1OfByte (0, aNumOfBytes - 1);
Handle(TColStd_HArray1OfByte) aBitMap = new TColStd_HArray1OfByte (0, aNumOfBytes - 1);
aBitMap->Init (0);
for (Standard_Integer aRow = 0; aRow < aHeight; aRow++)
{
const Standard_Integer aResRow = !theIsTopDown ? (aHeight - aRow - 1) : aRow;
for (Standard_Integer aColumn = 0; aColumn < aWidth; aColumn++)
{
const Quantity_ColorRGBA aColor = myImage->PixelColor (aColumn, aRow);
@ -101,7 +249,7 @@ Handle(TColStd_HArray1OfByte) Graphic3d_MarkerImage::GetBitMapArray (const Stand
aBitOn = aColor.Alpha() > theAlphaValue;
}
Standard_Integer anIndex = aNumOfBytesInRow * aRow + aColumn / 8;
Standard_Integer anIndex = aNumOfBytesInRow * aResRow + aColumn / 8;
aBitMap->SetValue (anIndex, (Standard_Byte)(aBitMap->Value (anIndex) +
(aBitOn ? (0x80 >> (aColumn % 8)) : 0)));
}
@ -116,12 +264,8 @@ Handle(TColStd_HArray1OfByte) Graphic3d_MarkerImage::GetBitMapArray (const Stand
// =======================================================================
const Handle(Image_PixMap)& Graphic3d_MarkerImage::GetImage()
{
if (!myImage.IsNull())
{
return myImage;
}
if (myBitMap.IsNull())
if (!myImage.IsNull()
|| myBitMap.IsNull())
{
return myImage;
}
@ -216,3 +360,122 @@ void Graphic3d_MarkerImage::GetTextureSize (Standard_Integer& theWidth,
theWidth = myWidth;
theHeight = myHeight;
}
// =======================================================================
// function : GetMarkerImage
// purpose :
// =======================================================================
Handle(Graphic3d_MarkerImage) Graphic3d_MarkerImage::StandardMarker (const Aspect_TypeOfMarker theMarkerType,
const Standard_ShortReal theScale,
const Graphic3d_Vec4& theColor)
{
switch (theMarkerType)
{
case Aspect_TOM_O_POINT:
case Aspect_TOM_O_PLUS:
case Aspect_TOM_O_STAR:
case Aspect_TOM_O_X:
{
// For this type of markers we merge two base bitmaps into one
// For example Aspect_TOM_O_PLUS = Aspect_TOM_O + Aspect_TOM_PLUS
Handle(Graphic3d_MarkerImage) aMarkerImage1 = getTextureImage (Aspect_TOM_O, theScale);
Handle(Graphic3d_MarkerImage) aMarkerImage2;
if (theMarkerType == Aspect_TOM_O_POINT)
{
// draw inner point as filled rectangle
const Standard_Integer aSize = theScale > 7 ? 7 : (Standard_Integer)(theScale + 0.5F);
Handle(TColStd_HArray1OfByte) aBitMap = fillPointBitmap (aSize);
aMarkerImage2 = new Graphic3d_MarkerImage (aBitMap, aSize, aSize);
}
else
{
aMarkerImage2 = getTextureImage (Aspect_TypeOfMarker(theMarkerType - Aspect_TOM_O_POINT), theScale);
}
Handle(Image_PixMap) anImage = mergeImages (aMarkerImage1->GetImage(), aMarkerImage2->GetImage());
Handle(Graphic3d_MarkerImage) aNewMarkerImage = new Graphic3d_MarkerImage (anImage);
return aNewMarkerImage;
}
case Aspect_TOM_RING1:
case Aspect_TOM_RING2:
case Aspect_TOM_RING3:
{
const Standard_ShortReal aDelta = 0.1f;
Standard_ShortReal aScale = theScale;
Standard_ShortReal aLimit = 0.0f;
if (theMarkerType == Aspect_TOM_RING1)
{
aLimit = aScale * 0.2f;
}
else if (theMarkerType == Aspect_TOM_RING2)
{
aLimit = aScale * 0.5f;
}
else if (theMarkerType == Aspect_TOM_RING3)
{
aLimit = aScale * 0.8f;
}
Handle(Image_PixMap) anImage;
for (; aScale > aLimit && aScale >= 1.0f; aScale -= aDelta)
{
anImage = mergeImages (anImage, getTextureImage (Aspect_TOM_O, aScale)->GetImage());
}
Handle(Graphic3d_MarkerImage) aNewMarkerImage = new Graphic3d_MarkerImage (anImage);
return aNewMarkerImage;
}
case Aspect_TOM_BALL:
{
Standard_Integer aWidth = 0, aHeight = 0, anOffset = 0, aNbBytes = 0;
Standard_ShortReal aScale = theScale;
getMarkerBitMapParam (Aspect_TOM_O, aScale, aWidth, aHeight, anOffset, aNbBytes);
NCollection_Vec4<Standard_Real> aColor (theColor);
const Standard_Integer aSize = Max (aWidth + 2, aHeight + 2); // includes extra margin
Handle(Image_PixMap) anImage = new Image_PixMap();
Handle(Image_PixMap) anImageA = new Image_PixMap();
anImage ->InitZero (Image_Format_RGBA, aSize, aSize);
anImageA->InitZero (Image_Format_Alpha, aSize, aSize);
// we draw a set of circles
Image_ColorRGBA aColor32;
aColor32.a() = 255;
Standard_Real aHLS[3];
const Standard_ShortReal aDelta = 0.1f;
while (aScale >= 1.0f)
{
Quantity_Color::RgbHls (aColor.r(), aColor.g(), aColor.b(), aHLS[0], aHLS[1], aHLS[2]);
aHLS[2] *= 0.95; // 5% saturation change
Quantity_Color::HlsRgb (aHLS[0], aHLS[1], aHLS[2], aColor.r(), aColor.g(), aColor.b());
aColor32.r() = Standard_Byte (255.0 * aColor.r());
aColor32.g() = Standard_Byte (255.0 * aColor.g());
aColor32.b() = Standard_Byte (255.0 * aColor.b());
const Handle(Graphic3d_MarkerImage) aMarker = getTextureImage (Aspect_TOM_O, aScale);
const Handle(Image_PixMap)& aCircle = aMarker->GetImage();
const Standard_Size aDiffX = (anImage->SizeX() - aCircle->SizeX()) / 2;
const Standard_Size aDiffY = (anImage->SizeY() - aCircle->SizeY()) / 2;
for (Standard_Size aRow = 0; aRow < aCircle->SizeY(); ++aRow)
{
const Standard_Byte* aRowData = aCircle->Row(aRow);
for (Standard_Size aCol = 0; aCol < aCircle->SizeX(); ++aCol)
{
if (aRowData[aCol] != 0)
{
anImage->ChangeValue<Image_ColorRGBA>(aDiffX + aRow, aDiffY + aCol) = aColor32;
anImageA->ChangeValue<Standard_Byte> (aDiffX + aRow, aDiffY + aCol) = 255;
}
}
}
aScale -= aDelta;
}
Handle(Graphic3d_MarkerImage) aNewMarkerImage = new Graphic3d_MarkerImage (anImage, anImageA);
return aNewMarkerImage;
}
default:
{
return getTextureImage (theMarkerType, theScale);
}
}
}

View File

@ -16,6 +16,8 @@
#ifndef _Graphic3d_MarkerImage_H__
#define _Graphic3d_MarkerImage_H__
#include <Aspect_TypeOfMarker.hxx>
#include <Graphic3d_Vec4.hxx>
#include <TColStd_HArray1OfByte.hxx>
#include <TCollection_AsciiString.hxx>
@ -25,44 +27,63 @@ class Image_PixMap;
//! It can convert bitmap texture stored in TColStd_HArray1OfByte to Image_PixMap and vice versa.
class Graphic3d_MarkerImage : public Standard_Transient
{
DEFINE_STANDARD_RTTIEXT(Graphic3d_MarkerImage, Standard_Transient)
public:
//! @param theImage - source image
Standard_EXPORT Graphic3d_MarkerImage (const Handle(Image_PixMap)& theImage);
//! Returns a marker image for the marker of the specified type, scale and color.
Standard_EXPORT static Handle(Graphic3d_MarkerImage) StandardMarker (const Aspect_TypeOfMarker theMarkerType,
const Standard_ShortReal theScale,
const Graphic3d_Vec4& theColor);
public:
//! Constructor from existing pixmap.
//! @param theImage [in] source image
//! @param theImageAlpha [in] colorless image
Standard_EXPORT Graphic3d_MarkerImage (const Handle(Image_PixMap)& theImage,
const Handle(Image_PixMap)& theImageAlpha = Handle(Image_PixMap)());
//! Creates marker image from array of bytes
//! (method for compatibility with old markers definition).
//! @param theBitMap - source bitmap stored as array of bytes
//! @param theWidth - number of bits in a row
//! @param theHeight - number of bits in a column
//! @param theBitMap [in] source bitmap stored as array of bytes
//! @param theWidth [in] number of bits in a row
//! @param theHeight [in] number of bits in a column
Standard_EXPORT Graphic3d_MarkerImage (const Handle(TColStd_HArray1OfByte)& theBitMap,
const Standard_Integer& theWidth,
const Standard_Integer& theHeight);
const Standard_Integer theWidth,
const Standard_Integer theHeight);
//! Return marker image.
//! If an instance of the class has been initialized with a bitmap, it will be converted to image.
Standard_EXPORT const Handle(Image_PixMap)& GetImage();
//! Return image alpha as grayscale image.
//! Note that if an instance of the class has been initialized with a bitmap
//! or with grayscale image this method will return exactly the same image as GetImage()
Standard_EXPORT const Handle(Image_PixMap)& GetImageAlpha();
//! Return an unique ID.
//! This ID will be used to manage resource in graphic driver.
Standard_EXPORT const TCollection_AsciiString& GetImageId() const;
//! Return an unique ID.
//! This ID will be used to manage resource in graphic driver.
Standard_EXPORT const TCollection_AsciiString& GetImageAlphaId() const;
//! Return texture size
Standard_EXPORT void GetTextureSize (Standard_Integer& theWidth,
Standard_Integer& theHeight) const;
//! Return TRUE if marker image has colors (e.g. RGBA and not grayscale).
Standard_EXPORT bool IsColoredImage() const;
//! Return marker image as array of bytes.
//! If an instance of the class has been initialized with image, it will be converted to bitmap based on the parameter theAlphaValue.
//! @param theAlphaValue pixels in the image that have alpha value greater than
//! or equal to this parameter will be stored in bitmap as "1",
//! others will be stored as "0"
//! @return marker image as array of bytes. If an instance of the class has been
//! initialized with image, it will be converted to bitmap based on the parameter theAlphaValue.
Standard_EXPORT Handle(TColStd_HArray1OfByte) GetBitMapArray (const Standard_Real& theAlphaValue = 0.5) const;
//! @return marker image. If an instance of the class has been initialized with a bitmap, it will be
//! converted to image.
Standard_EXPORT const Handle(Image_PixMap)& GetImage();
//! @return image alpha as grayscale image. Note that if an instance of the class has been initialized
//! with a bitmap or with grayscale image this method will return exactly the same image as GetImage()
Standard_EXPORT const Handle(Image_PixMap)& GetImageAlpha();
//! @return an unique ID. This ID will be used to manage resource in graphic driver.
Standard_EXPORT const TCollection_AsciiString& GetImageId() const;
//! @return an unique ID. This ID will be used to manage resource in graphic driver.
Standard_EXPORT const TCollection_AsciiString& GetImageAlphaId() const;
//! @return texture size
Standard_EXPORT void GetTextureSize (Standard_Integer& theWidth,
Standard_Integer& theHeight) const;
//! @param theIsTopDown [in] flag indicating expected rows order in returned bitmap, which is bottom-up by default
Standard_EXPORT Handle(TColStd_HArray1OfByte) GetBitMapArray (const Standard_Real theAlphaValue = 0.5,
const Standard_Boolean theIsTopDown = false) const;
private:
@ -75,10 +96,6 @@ private:
Standard_Integer myWidth; //!< marker width
Standard_Integer myHeight; //!< marker height
public:
DEFINE_STANDARD_RTTIEXT(Graphic3d_MarkerImage,Standard_Transient) // Type definition
};
DEFINE_STANDARD_HANDLE (Graphic3d_MarkerImage, Standard_Transient)

File diff suppressed because it is too large Load Diff

View File

@ -662,3 +662,36 @@ void Image_PixMap::ToBlackWhite (Image_PixMap& theImage)
}
}
}
// =======================================================================
// function : InitCopy
// purpose :
// =======================================================================
bool Image_PixMap::FlipY (Image_PixMap& theImage)
{
if (theImage.IsEmpty()
|| theImage.SizeX() == 0
|| theImage.SizeY() == 0)
{
return false;
}
NCollection_Buffer aTmp (NCollection_BaseAllocator::CommonBaseAllocator());
const size_t aRowSize = theImage.SizeRowBytes();
if (!aTmp.Allocate (aRowSize))
{
return false;
}
// for odd height middle row should be left as is
Standard_Size aNbRowsHalf = theImage.SizeY() / 2;
for (Standard_Size aRowT = 0, aRowB = theImage.SizeY() - 1; aRowT < aNbRowsHalf; ++aRowT, --aRowB)
{
Standard_Byte* aTop = theImage.ChangeRow (aRowT);
Standard_Byte* aBot = theImage.ChangeRow (aRowB);
memcpy (aTmp.ChangeData(), aTop, aRowSize);
memcpy (aTop, aBot, aRowSize);
memcpy (aBot, aTmp.Data(), aRowSize);
}
return true;
}

View File

@ -48,6 +48,9 @@ public:
//! Convert image to Black/White.
Standard_EXPORT static void ToBlackWhite (Image_PixMap& theImage);
//! Reverse line order as it draws it from bottom to top.
Standard_EXPORT static bool FlipY (Image_PixMap& theImage);
//! Return default image data allocator.
Standard_EXPORT static const Handle(NCollection_BaseAllocator)& DefaultAllocator();

File diff suppressed because it is too large Load Diff

View File

@ -39,6 +39,13 @@ public:
//! Returns TRUE for point sprite texture.
virtual bool IsPointSprite() const Standard_OVERRIDE { return true; }
//! @return true if current object was initialized
virtual bool IsValid() const Standard_OVERRIDE
{
return myBitmapList != 0
|| myTextureId != NO_TEXTURE;
}
//! @return true if this is display list bitmap
inline Standard_Boolean IsDisplayList() const
{

View File

@ -597,73 +597,57 @@ void OpenGl_PrimitiveArray::drawMarkers (const Handle(OpenGl_Workspace)& theWork
&& aCtx->ActiveProgram()->HasTessellationStage()
? GL_PATCHES
: myDrawMode;
if (anAspectMarker->Aspect()->MarkerType() == Aspect_TOM_POINT)
{
aCtx->SetPointSize (anAspectMarker->MarkerSize());
aCtx->core11fwd->glDrawArrays (aDrawMode, 0, !myVboAttribs.IsNull() ? myVboAttribs->GetElemsNb() : myAttribs->NbElements);
aCtx->SetPointSize (1.0f);
return;
}
#if !defined(GL_ES_VERSION_2_0)
if (aCtx->core11 != NULL)
{
aCtx->core11fwd->glEnable (GL_ALPHA_TEST);
aCtx->core11fwd->glAlphaFunc (GL_GEQUAL, 0.1f);
}
#endif
aCtx->core11fwd->glEnable (GL_BLEND);
aCtx->core11fwd->glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
if (anAspectMarker->HasPointSprite (aCtx))
{
// Textured markers will be drawn with the point sprites
aCtx->SetPointSize (anAspectMarker->MarkerSize());
aCtx->SetPointSpriteOrigin();
#if !defined(GL_ES_VERSION_2_0)
if (aCtx->core11 != NULL)
{
aCtx->core11fwd->glEnable (GL_ALPHA_TEST);
aCtx->core11fwd->glAlphaFunc (GL_GEQUAL, 0.1f);
}
#endif
aCtx->core11fwd->glEnable (GL_BLEND);
aCtx->core11fwd->glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
aCtx->core11fwd->glDrawArrays (aDrawMode, 0, !myVboAttribs.IsNull() ? myVboAttribs->GetElemsNb() : myAttribs->NbElements);
aCtx->core11fwd->glDisable (GL_BLEND);
#if !defined(GL_ES_VERSION_2_0)
if (aCtx->core11 != NULL)
{
if (aCtx->ShaderManager()->MaterialState().AlphaCutoff() >= ShortRealLast())
{
aCtx->core11fwd->glDisable (GL_ALPHA_TEST);
}
else
{
aCtx->core11fwd->glAlphaFunc (GL_GEQUAL, aCtx->ShaderManager()->MaterialState().AlphaCutoff());
}
}
#endif
aCtx->SetPointSize (1.0f);
return;
}
else if (anAspectMarker->Aspect()->MarkerType() == Aspect_TOM_POINT)
{
aCtx->SetPointSize (anAspectMarker->MarkerSize());
aCtx->core11fwd->glDrawArrays (aDrawMode, 0, !myVboAttribs.IsNull() ? myVboAttribs->GetElemsNb() : myAttribs->NbElements);
aCtx->SetPointSize (1.0f);
}
#if !defined(GL_ES_VERSION_2_0)
// Textured markers will be drawn with the glBitmap
else if (anAspectMarker->Aspect()->MarkerType() != Aspect_TOM_POINT)
else if (const Handle(OpenGl_PointSprite)& aSprite = anAspectMarker->SpriteRes (aCtx, theWorkspace->ToHighlight()))
{
const Handle(OpenGl_PointSprite)& aSpriteNorm = anAspectMarker->SpriteRes (aCtx, false);
if (aSpriteNorm.IsNull())
for (Standard_Integer anIter = 0; anIter < myAttribs->NbElements; anIter++)
{
return;
aCtx->core11->glRasterPos3fv (myAttribs->Value<Graphic3d_Vec3> (anIter).GetData());
aSprite->DrawBitmap (theWorkspace->GetGlContext());
}
}
#endif
/**if (!isHilight && (myPArray->vcolours != NULL))
aCtx->core11fwd->glDisable (GL_BLEND);
#if !defined(GL_ES_VERSION_2_0)
if (aCtx->core11 != NULL)
{
if (aCtx->ShaderManager()->MaterialState().AlphaCutoff() >= ShortRealLast())
{
for (Standard_Integer anIter = 0; anIter < myAttribs->NbElements; anIter++)
{
glColor4ubv (myPArray->vcolours[anIter].GetData());
glRasterPos3fv (myAttribs->Value<Graphic3d_Vec3> (anIter).GetData());
aSpriteNorm->DrawBitmap (theWorkspace->GetGlContext());
}
aCtx->core11fwd->glDisable (GL_ALPHA_TEST);
}
else*/
else
{
for (Standard_Integer anIter = 0; anIter < myAttribs->NbElements; anIter++)
{
aCtx->core11->glRasterPos3fv (myAttribs->Value<Graphic3d_Vec3> (anIter).GetData());
aSpriteNorm->DrawBitmap (theWorkspace->GetGlContext());
}
aCtx->core11fwd->glAlphaFunc (GL_GEQUAL, aCtx->ShaderManager()->MaterialState().AlphaCutoff());
}
}
#endif

View File

@ -49,7 +49,7 @@ public:
Standard_EXPORT virtual ~OpenGl_Texture();
//! @return true if current object was initialized
bool IsValid() const { return myTextureId != NO_TEXTURE; }
virtual bool IsValid() const { return myTextureId != NO_TEXTURE; }
//! @return target to which the texture is bound (GL_TEXTURE_1D, GL_TEXTURE_2D)
GLenum GetTarget() const { return myTarget; }