mirror of
https://github.com/SFML/SFML.git
synced 2025-01-19 15:55:13 +08:00
Removed all the remaining const_cast, and replaced them with mutable members (this is needed for optimized lazy calculations)
git-svn-id: https://sfml.svn.sourceforge.net/svnroot/sfml/branches/sfml2@1353 4e206d99-4929-0410-ac5d-dfc041789085
This commit is contained in:
parent
9f1354b2a9
commit
40f13c7302
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -346,16 +346,16 @@ private :
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
// Member data
|
// Member data
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Vector2f myPosition; ///< Position of the object on screen
|
Vector2f myPosition; ///< Position of the object on screen
|
||||||
Vector2f myScale; ///< Scale of the object
|
Vector2f myScale; ///< Scale of the object
|
||||||
Vector2f myOrigin; ///< Origin of translation / rotation / scaling of the object
|
Vector2f myOrigin; ///< Origin of translation / rotation / scaling of the object
|
||||||
float myRotation; ///< Orientation of the object, in degrees
|
float myRotation; ///< Orientation of the object, in degrees
|
||||||
Color myColor; ///< Overlay color of the object
|
Color myColor; ///< Overlay color of the object
|
||||||
Blend::Mode myBlendMode; ///< Blending mode
|
Blend::Mode myBlendMode; ///< Blending mode
|
||||||
mutable bool myNeedUpdate; ///< Do we need to recompute the transform matrix ?
|
mutable Matrix3 myMatrix; ///< Precomputed transform matrix gathering the translation / rotation / scale / center
|
||||||
mutable bool myInvNeedUpdate; ///< Do we need to recompute the inverse transform matrix ?
|
mutable Matrix3 myInvMatrix; ///< Precomputed inverse transform matrix gathering the translation / rotation / scale / center
|
||||||
mutable Matrix3 myMatrix; ///< Precomputed transform matrix gathering the translation / rotation / scale / center
|
mutable bool myMatrixUpdated; ///< Do we need to recompute the transform matrix ?
|
||||||
mutable Matrix3 myInvMatrix; ///< Precomputed inverse transform matrix gathering the translation / rotation / scale / center
|
mutable bool myInvMatrixUpdated; ///< Do we need to recompute the inverse transform matrix ?
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sf
|
} // namespace sf
|
||||||
|
@ -306,14 +306,14 @@ private :
|
|||||||
/// array of pixels
|
/// array of pixels
|
||||||
///
|
///
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void EnsureTextureUpdate();
|
void EnsureTextureUpdate() const;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// Make sure the array of pixels is updated with the
|
/// Make sure the array of pixels is updated with the
|
||||||
/// texture in video memory
|
/// texture in video memory
|
||||||
///
|
///
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void EnsureArrayUpdate();
|
void EnsureArrayUpdate() const;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// Reset the image attributes
|
/// Reset the image attributes
|
||||||
@ -327,19 +327,24 @@ private :
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void DestroyTexture();
|
void DestroyTexture();
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
// Types
|
||||||
|
////////////////////////////////////////////////////////////
|
||||||
|
typedef std::vector<Color> ColorArray; ///< Array of colors
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
// Member data
|
// Member data
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
unsigned int myWidth; ///< Image width
|
unsigned int myWidth; ///< Image width
|
||||||
unsigned int myHeight; ///< Image Height
|
unsigned int myHeight; ///< Image Height
|
||||||
unsigned int myTextureWidth; ///< Actual texture width (can be greater than image width because of padding)
|
unsigned int myTextureWidth; ///< Actual texture width (can be greater than image width because of padding)
|
||||||
unsigned int myTextureHeight; ///< Actual texture height (can be greater than image height because of padding)
|
unsigned int myTextureHeight; ///< Actual texture height (can be greater than image height because of padding)
|
||||||
unsigned int myTexture; ///< Internal texture identifier
|
unsigned int myTexture; ///< Internal texture identifier
|
||||||
bool myIsSmooth; ///< Status of the smooth filter
|
bool myIsSmooth; ///< Status of the smooth filter
|
||||||
std::vector<Color> myPixels; ///< Pixels of the image
|
mutable ColorArray myPixels; ///< Pixels of the image
|
||||||
bool myNeedTextureUpdate; ///< Status of synchronization between pixels in central memory and the internal texture un video memory
|
mutable bool myTextureUpdated; ///< Status of synchronization between pixels in central memory and the internal texture un video memory
|
||||||
bool myNeedArrayUpdate; ///< Status of synchronization between pixels in central memory and the internal texture un video memory
|
mutable bool myArrayUpdated; ///< Status of synchronization between pixels in central memory and the internal texture un video memory
|
||||||
bool myPixelsFlipped; ///< To work around the inconsistency in Y orientation
|
mutable bool myPixelsFlipped; ///< To work around the inconsistency in Y orientation
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sf
|
} // namespace sf
|
||||||
|
@ -172,17 +172,17 @@ private :
|
|||||||
/// Recompute the bounding rectangle of the text
|
/// Recompute the bounding rectangle of the text
|
||||||
///
|
///
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void RecomputeRect();
|
void UpdateRect() const;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
// Member data
|
// Member data
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
String myString; ///< String to display
|
String myString; ///< String to display
|
||||||
ResourcePtr<Font> myFont; ///< Font used to display the string
|
ResourcePtr<Font> myFont; ///< Font used to display the string
|
||||||
unsigned int myCharacterSize; ///< Base size of characters, in pixels
|
unsigned int myCharacterSize; ///< Base size of characters, in pixels
|
||||||
unsigned long myStyle; ///< Text style (see Style enum)
|
unsigned long myStyle; ///< Text style (see Style enum)
|
||||||
FloatRect myBaseRect; ///< Bounding rectangle of the text in object coordinates
|
mutable FloatRect myBaseRect; ///< Bounding rectangle of the text in object coordinates
|
||||||
bool myNeedRectUpdate; ///< Does the bounding rect need an update ?
|
mutable bool myRectUpdated; ///< Is the bounding rectangle up-to-date ?
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sf
|
} // namespace sf
|
||||||
|
@ -276,14 +276,14 @@ private :
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
// Member data
|
// Member data
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Vector2f myCenter; ///< Center of the view, in scene coordinates
|
Vector2f myCenter; ///< Center of the view, in scene coordinates
|
||||||
Vector2f mySize; ///< Size of the view, in scene coordinates
|
Vector2f mySize; ///< Size of the view, in scene coordinates
|
||||||
float myRotation; ///< Angle of rotation of the view rectangle, in degrees
|
float myRotation; ///< Angle of rotation of the view rectangle, in degrees
|
||||||
FloatRect myViewport; ///< Viewport rectangle, expressed as a factor of the render-target's size
|
FloatRect myViewport; ///< Viewport rectangle, expressed as a factor of the render-target's size
|
||||||
mutable Matrix3 myMatrix; ///< Precomputed projection matrix corresponding to the view
|
mutable Matrix3 myMatrix; ///< Precomputed projection matrix corresponding to the view
|
||||||
mutable Matrix3 myInverseMatrix; ///< Precomputed inverse projection matrix corresponding to the view
|
mutable Matrix3 myInverseMatrix; ///< Precomputed inverse projection matrix corresponding to the view
|
||||||
mutable bool myNeedUpdate; ///< Internal state telling if the matrix needs to be updated
|
mutable bool myMatrixUpdated; ///< Internal state telling if the matrix needs to be updated
|
||||||
mutable bool myNeedInvUpdate; ///< Internal state telling if the matrix needs to be updated
|
mutable bool myInvMatrixUpdated; ///< Internal state telling if the matrix needs to be updated
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sf
|
} // namespace sf
|
||||||
|
@ -37,14 +37,14 @@ namespace sf
|
|||||||
/// Default constructor
|
/// Default constructor
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Drawable::Drawable(const Vector2f& position, const Vector2f& scale, float rotation, const Color& color) :
|
Drawable::Drawable(const Vector2f& position, const Vector2f& scale, float rotation, const Color& color) :
|
||||||
myPosition (position),
|
myPosition (position),
|
||||||
myScale (scale),
|
myScale (scale),
|
||||||
myOrigin (0, 0),
|
myOrigin (0, 0),
|
||||||
myRotation (rotation),
|
myRotation (rotation),
|
||||||
myColor (color),
|
myColor (color),
|
||||||
myBlendMode (Blend::Alpha),
|
myBlendMode (Blend::Alpha),
|
||||||
myNeedUpdate (true),
|
myMatrixUpdated (false),
|
||||||
myInvNeedUpdate(true)
|
myInvMatrixUpdated(false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,9 +83,10 @@ void Drawable::SetPosition(const Vector2f& position)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Drawable::SetX(float x)
|
void Drawable::SetX(float x)
|
||||||
{
|
{
|
||||||
myPosition.x = x;
|
myPosition.x = x;
|
||||||
myNeedUpdate = true;
|
|
||||||
myInvNeedUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -94,9 +95,10 @@ void Drawable::SetX(float x)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Drawable::SetY(float y)
|
void Drawable::SetY(float y)
|
||||||
{
|
{
|
||||||
myPosition.y = y;
|
myPosition.y = y;
|
||||||
myNeedUpdate = true;
|
|
||||||
myInvNeedUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -127,9 +129,10 @@ void Drawable::SetScaleX(float factor)
|
|||||||
{
|
{
|
||||||
if (factor > 0)
|
if (factor > 0)
|
||||||
{
|
{
|
||||||
myScale.x = factor;
|
myScale.x = factor;
|
||||||
myNeedUpdate = true;
|
|
||||||
myInvNeedUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,9 +144,10 @@ void Drawable::SetScaleY(float factor)
|
|||||||
{
|
{
|
||||||
if (factor > 0)
|
if (factor > 0)
|
||||||
{
|
{
|
||||||
myScale.y = factor;
|
myScale.y = factor;
|
||||||
myNeedUpdate = true;
|
|
||||||
myInvNeedUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,10 +159,11 @@ void Drawable::SetScaleY(float factor)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Drawable::SetOrigin(float x, float y)
|
void Drawable::SetOrigin(float x, float y)
|
||||||
{
|
{
|
||||||
myOrigin.x = x;
|
myOrigin.x = x;
|
||||||
myOrigin.y = y;
|
myOrigin.y = y;
|
||||||
myNeedUpdate = true;
|
|
||||||
myInvNeedUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -181,8 +186,9 @@ void Drawable::SetRotation(float angle)
|
|||||||
myRotation = static_cast<float>(fmod(angle, 360));
|
myRotation = static_cast<float>(fmod(angle, 360));
|
||||||
if (myRotation < 0)
|
if (myRotation < 0)
|
||||||
myRotation += 360.f;
|
myRotation += 360.f;
|
||||||
myNeedUpdate = true;
|
|
||||||
myInvNeedUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -331,10 +337,10 @@ sf::Vector2f Drawable::TransformToGlobal(const sf::Vector2f& point) const
|
|||||||
const Matrix3& Drawable::GetMatrix() const
|
const Matrix3& Drawable::GetMatrix() const
|
||||||
{
|
{
|
||||||
// First recompute it if needed
|
// First recompute it if needed
|
||||||
if (myNeedUpdate)
|
if (!myMatrixUpdated)
|
||||||
{
|
{
|
||||||
myMatrix.SetFromTransformations(myOrigin, myPosition, myRotation, myScale);
|
myMatrix.SetFromTransformations(myOrigin, myPosition, myRotation, myScale);
|
||||||
myNeedUpdate = false;
|
myMatrixUpdated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return myMatrix;
|
return myMatrix;
|
||||||
@ -347,10 +353,10 @@ const Matrix3& Drawable::GetMatrix() const
|
|||||||
const Matrix3& Drawable::GetInverseMatrix() const
|
const Matrix3& Drawable::GetInverseMatrix() const
|
||||||
{
|
{
|
||||||
// First recompute it if needed
|
// First recompute it if needed
|
||||||
if (myInvNeedUpdate)
|
if (!myInvMatrixUpdated)
|
||||||
{
|
{
|
||||||
myInvMatrix = GetMatrix().GetInverse();
|
myInvMatrix = GetMatrix().GetInverse();
|
||||||
myInvNeedUpdate = false;
|
myInvMatrixUpdated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return myInvMatrix;
|
return myInvMatrix;
|
||||||
|
@ -48,8 +48,8 @@ myTextureWidth (0),
|
|||||||
myTextureHeight (0),
|
myTextureHeight (0),
|
||||||
myTexture (0),
|
myTexture (0),
|
||||||
myIsSmooth (true),
|
myIsSmooth (true),
|
||||||
myNeedTextureUpdate(false),
|
myTextureUpdated (true),
|
||||||
myNeedArrayUpdate (false),
|
myArrayUpdated (true),
|
||||||
myPixelsFlipped (false)
|
myPixelsFlipped (false)
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -63,19 +63,19 @@ Image::Image(const Image& copy) :
|
|||||||
Resource<Image>(copy)
|
Resource<Image>(copy)
|
||||||
{
|
{
|
||||||
// First make sure that the source image is up-to-date
|
// First make sure that the source image is up-to-date
|
||||||
const_cast<Image&>(copy).EnsureArrayUpdate();
|
copy.EnsureArrayUpdate();
|
||||||
|
|
||||||
// Copy all its members
|
// Copy all its members
|
||||||
myWidth = copy.myWidth;
|
myWidth = copy.myWidth;
|
||||||
myHeight = copy.myHeight;
|
myHeight = copy.myHeight;
|
||||||
myTextureWidth = copy.myTextureWidth;
|
myTextureWidth = copy.myTextureWidth;
|
||||||
myTextureHeight = copy.myTextureHeight;
|
myTextureHeight = copy.myTextureHeight;
|
||||||
myTexture = 0;
|
myTexture = 0;
|
||||||
myIsSmooth = copy.myIsSmooth;
|
myIsSmooth = copy.myIsSmooth;
|
||||||
myPixels = copy.myPixels;
|
myPixels = copy.myPixels;
|
||||||
myNeedTextureUpdate = false;
|
myTextureUpdated = true;
|
||||||
myNeedArrayUpdate = false;
|
myArrayUpdated = true;
|
||||||
myPixelsFlipped = copy.myPixelsFlipped;
|
myPixelsFlipped = copy.myPixelsFlipped;
|
||||||
|
|
||||||
// Create the texture
|
// Create the texture
|
||||||
CreateTexture();
|
CreateTexture();
|
||||||
@ -184,7 +184,7 @@ bool Image::LoadFromPixels(unsigned int width, unsigned int height, const Uint8*
|
|||||||
bool Image::SaveToFile(const std::string& filename) const
|
bool Image::SaveToFile(const std::string& filename) const
|
||||||
{
|
{
|
||||||
// Check if the array of pixels needs to be updated
|
// Check if the array of pixels needs to be updated
|
||||||
const_cast<Image*>(this)->EnsureArrayUpdate();
|
EnsureArrayUpdate();
|
||||||
|
|
||||||
// Let the image loader save our pixel array into the image
|
// Let the image loader save our pixel array into the image
|
||||||
return priv::ImageLoader::GetInstance().SaveImageToFile(filename, myPixels, myWidth, myHeight);
|
return priv::ImageLoader::GetInstance().SaveImageToFile(filename, myPixels, myWidth, myHeight);
|
||||||
@ -233,7 +233,7 @@ void Image::CreateMaskFromColor(const Color& transparentColor, Uint8 alpha)
|
|||||||
std::replace(myPixels.begin(), myPixels.end(), transparentColor, newColor);
|
std::replace(myPixels.begin(), myPixels.end(), transparentColor, newColor);
|
||||||
|
|
||||||
// The texture will need to be updated
|
// The texture will need to be updated
|
||||||
myNeedTextureUpdate = true;
|
myTextureUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -250,7 +250,7 @@ void Image::Copy(const Image& source, unsigned int destX, unsigned int destY, co
|
|||||||
|
|
||||||
// Make sure both images have up-to-date arrays
|
// Make sure both images have up-to-date arrays
|
||||||
EnsureArrayUpdate();
|
EnsureArrayUpdate();
|
||||||
const_cast<Image&>(source).EnsureArrayUpdate();
|
source.EnsureArrayUpdate();
|
||||||
|
|
||||||
// Adjust the source rectangle
|
// Adjust the source rectangle
|
||||||
IntRect srcRect = sourceRect;
|
IntRect srcRect = sourceRect;
|
||||||
@ -323,7 +323,7 @@ void Image::Copy(const Image& source, unsigned int destX, unsigned int destY, co
|
|||||||
}
|
}
|
||||||
|
|
||||||
// The texture will need an update
|
// The texture will need an update
|
||||||
myNeedTextureUpdate = true;
|
myTextureUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -368,9 +368,9 @@ bool Image::CopyScreen(RenderWindow& window, const IntRect& sourceRect)
|
|||||||
|
|
||||||
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
||||||
|
|
||||||
myNeedTextureUpdate = false;
|
myTextureUpdated = true;
|
||||||
myNeedArrayUpdate = true;
|
myArrayUpdated = false;
|
||||||
myPixelsFlipped = true;
|
myPixelsFlipped = true;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -401,7 +401,7 @@ void Image::SetPixel(unsigned int x, unsigned int y, const Color& color)
|
|||||||
myPixels[x + y * myWidth] = color;
|
myPixels[x + y * myWidth] = color;
|
||||||
|
|
||||||
// The texture will need to be updated
|
// The texture will need to be updated
|
||||||
myNeedTextureUpdate = true;
|
myTextureUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -411,7 +411,7 @@ void Image::SetPixel(unsigned int x, unsigned int y, const Color& color)
|
|||||||
const Color& Image::GetPixel(unsigned int x, unsigned int y) const
|
const Color& Image::GetPixel(unsigned int x, unsigned int y) const
|
||||||
{
|
{
|
||||||
// First check if the array of pixels needs to be updated
|
// First check if the array of pixels needs to be updated
|
||||||
const_cast<Image*>(this)->EnsureArrayUpdate();
|
EnsureArrayUpdate();
|
||||||
|
|
||||||
// Check if pixel is whithin the image bounds
|
// Check if pixel is whithin the image bounds
|
||||||
if ((x >= myWidth) || (y >= myHeight))
|
if ((x >= myWidth) || (y >= myHeight))
|
||||||
@ -433,7 +433,7 @@ const Color& Image::GetPixel(unsigned int x, unsigned int y) const
|
|||||||
const Uint8* Image::GetPixelsPtr() const
|
const Uint8* Image::GetPixelsPtr() const
|
||||||
{
|
{
|
||||||
// First check if the array of pixels needs to be updated
|
// First check if the array of pixels needs to be updated
|
||||||
const_cast<Image*>(this)->EnsureArrayUpdate();
|
EnsureArrayUpdate();
|
||||||
|
|
||||||
if (!myPixels.empty())
|
if (!myPixels.empty())
|
||||||
{
|
{
|
||||||
@ -461,8 +461,8 @@ void Image::UpdatePixels(const Uint8* pixels)
|
|||||||
|
|
||||||
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
||||||
|
|
||||||
myNeedArrayUpdate = true;
|
myArrayUpdated = false;
|
||||||
myNeedTextureUpdate = false;
|
myTextureUpdated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -484,7 +484,7 @@ void Image::UpdatePixels(const Uint8* pixels, const IntRect& rectangle)
|
|||||||
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
||||||
|
|
||||||
// The pixel cache is no longer up-to-date
|
// The pixel cache is no longer up-to-date
|
||||||
myNeedArrayUpdate = true;
|
myArrayUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -494,7 +494,7 @@ void Image::UpdatePixels(const Uint8* pixels, const IntRect& rectangle)
|
|||||||
void Image::Bind() const
|
void Image::Bind() const
|
||||||
{
|
{
|
||||||
// First check if the texture needs to be updated
|
// First check if the texture needs to be updated
|
||||||
const_cast<Image*>(this)->EnsureTextureUpdate();
|
EnsureTextureUpdate();
|
||||||
|
|
||||||
// Bind it
|
// Bind it
|
||||||
if (myTexture)
|
if (myTexture)
|
||||||
@ -562,22 +562,29 @@ bool Image::IsSmooth() const
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
FloatRect Image::GetTexCoords(const IntRect& rect) const
|
FloatRect Image::GetTexCoords(const IntRect& rect) const
|
||||||
{
|
{
|
||||||
float width = static_cast<float>(myTextureWidth);
|
if ((myTextureWidth != 0) && (myTextureHeight != 0))
|
||||||
float height = static_cast<float>(myTextureHeight);
|
|
||||||
|
|
||||||
if (myPixelsFlipped)
|
|
||||||
{
|
{
|
||||||
return FloatRect(rect.Left / width,
|
float width = static_cast<float>(myTextureWidth);
|
||||||
rect.Bottom / height,
|
float height = static_cast<float>(myTextureHeight);
|
||||||
rect.Right / width,
|
|
||||||
rect.Top / height);
|
if (myPixelsFlipped)
|
||||||
|
{
|
||||||
|
return FloatRect(rect.Left / width,
|
||||||
|
rect.Bottom / height,
|
||||||
|
rect.Right / width,
|
||||||
|
rect.Top / height);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return FloatRect(rect.Left / width,
|
||||||
|
rect.Top / height,
|
||||||
|
rect.Right / width,
|
||||||
|
rect.Bottom / height);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return FloatRect(rect.Left / width,
|
return FloatRect(0, 0, 0, 0);
|
||||||
rect.Top / height,
|
|
||||||
rect.Right / width,
|
|
||||||
rect.Bottom / height);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -626,15 +633,15 @@ Image& Image::operator =(const Image& other)
|
|||||||
{
|
{
|
||||||
Image temp(other);
|
Image temp(other);
|
||||||
|
|
||||||
std::swap(myWidth, temp.myWidth);
|
std::swap(myWidth, temp.myWidth);
|
||||||
std::swap(myHeight, temp.myHeight);
|
std::swap(myHeight, temp.myHeight);
|
||||||
std::swap(myTextureWidth, temp.myTextureWidth);
|
std::swap(myTextureWidth, temp.myTextureWidth);
|
||||||
std::swap(myTextureHeight, temp.myTextureHeight);
|
std::swap(myTextureHeight, temp.myTextureHeight);
|
||||||
std::swap(myTexture, temp.myTexture);
|
std::swap(myTexture, temp.myTexture);
|
||||||
std::swap(myIsSmooth, temp.myIsSmooth);
|
std::swap(myIsSmooth, temp.myIsSmooth);
|
||||||
std::swap(myNeedArrayUpdate, temp.myNeedArrayUpdate);
|
std::swap(myArrayUpdated, temp.myArrayUpdated);
|
||||||
std::swap(myNeedTextureUpdate, temp.myNeedTextureUpdate);
|
std::swap(myTextureUpdated, temp.myTextureUpdated);
|
||||||
std::swap(myPixelsFlipped, temp.myPixelsFlipped);
|
std::swap(myPixelsFlipped, temp.myPixelsFlipped);
|
||||||
myPixels.swap(temp.myPixels);
|
myPixels.swap(temp.myPixels);
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
@ -692,7 +699,7 @@ bool Image::CreateTexture()
|
|||||||
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
||||||
}
|
}
|
||||||
|
|
||||||
myNeedTextureUpdate = true;
|
myTextureUpdated = false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -702,9 +709,9 @@ bool Image::CreateTexture()
|
|||||||
/// Make sure the texture in video memory is updated with the
|
/// Make sure the texture in video memory is updated with the
|
||||||
/// array of pixels
|
/// array of pixels
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Image::EnsureTextureUpdate()
|
void Image::EnsureTextureUpdate() const
|
||||||
{
|
{
|
||||||
if (myNeedTextureUpdate)
|
if (!myTextureUpdated)
|
||||||
{
|
{
|
||||||
if (myTexture && !myPixels.empty())
|
if (myTexture && !myPixels.empty())
|
||||||
{
|
{
|
||||||
@ -719,7 +726,7 @@ void Image::EnsureTextureUpdate()
|
|||||||
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
||||||
}
|
}
|
||||||
|
|
||||||
myNeedTextureUpdate = false;
|
myTextureUpdated = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -728,9 +735,9 @@ void Image::EnsureTextureUpdate()
|
|||||||
/// Make sure the array of pixels is updated with the
|
/// Make sure the array of pixels is updated with the
|
||||||
/// texture in video memory
|
/// texture in video memory
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Image::EnsureArrayUpdate()
|
void Image::EnsureArrayUpdate() const
|
||||||
{
|
{
|
||||||
if (myNeedArrayUpdate)
|
if (!myArrayUpdated)
|
||||||
{
|
{
|
||||||
// First make sure the texture is up-to-date
|
// First make sure the texture is up-to-date
|
||||||
// (may not be the case if an external update has been scheduled)
|
// (may not be the case if an external update has been scheduled)
|
||||||
@ -756,7 +763,7 @@ void Image::EnsureArrayUpdate()
|
|||||||
// Texture and array don't have the same size, we have to use a slower algorithm
|
// Texture and array don't have the same size, we have to use a slower algorithm
|
||||||
|
|
||||||
// All the pixels will first be copied to a temporary array
|
// All the pixels will first be copied to a temporary array
|
||||||
std::vector<Color> allPixels(myTextureWidth * myTextureHeight);
|
ColorArray allPixels(myTextureWidth * myTextureHeight);
|
||||||
GLCheck(glBindTexture(GL_TEXTURE_2D, myTexture));
|
GLCheck(glBindTexture(GL_TEXTURE_2D, myTexture));
|
||||||
GLCheck(glGetTexImage(GL_TEXTURE_2D, 0, GL_RGBA, GL_UNSIGNED_BYTE, &allPixels[0]));
|
GLCheck(glGetTexImage(GL_TEXTURE_2D, 0, GL_RGBA, GL_UNSIGNED_BYTE, &allPixels[0]));
|
||||||
|
|
||||||
@ -783,7 +790,7 @@ void Image::EnsureArrayUpdate()
|
|||||||
// Restore the previous texture
|
// Restore the previous texture
|
||||||
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
GLCheck(glBindTexture(GL_TEXTURE_2D, previous));
|
||||||
|
|
||||||
myNeedArrayUpdate = false;
|
myArrayUpdated = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -795,15 +802,15 @@ void Image::Reset()
|
|||||||
{
|
{
|
||||||
DestroyTexture();
|
DestroyTexture();
|
||||||
|
|
||||||
myWidth = 0;
|
myWidth = 0;
|
||||||
myHeight = 0;
|
myHeight = 0;
|
||||||
myTextureWidth = 0;
|
myTextureWidth = 0;
|
||||||
myTextureHeight = 0;
|
myTextureHeight = 0;
|
||||||
myTexture = 0;
|
myTexture = 0;
|
||||||
myIsSmooth = true;
|
myIsSmooth = true;
|
||||||
myNeedTextureUpdate = false;
|
myTextureUpdated = true;
|
||||||
myNeedArrayUpdate = false;
|
myArrayUpdated = true;
|
||||||
myPixelsFlipped = false;
|
myPixelsFlipped = false;
|
||||||
myPixels.clear();
|
myPixels.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -818,9 +825,9 @@ void Image::DestroyTexture()
|
|||||||
{
|
{
|
||||||
GLuint Texture = static_cast<GLuint>(myTexture);
|
GLuint Texture = static_cast<GLuint>(myTexture);
|
||||||
GLCheck(glDeleteTextures(1, &Texture));
|
GLCheck(glDeleteTextures(1, &Texture));
|
||||||
myTexture = 0;
|
myTexture = 0;
|
||||||
myNeedTextureUpdate = false;
|
myTextureUpdated = true;
|
||||||
myNeedArrayUpdate = false;
|
myArrayUpdated = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,8 +140,8 @@ void RenderImage::Display()
|
|||||||
{
|
{
|
||||||
bool pixelsFlipped = myRenderImage->UpdateTexture(myImage.myTexture);
|
bool pixelsFlipped = myRenderImage->UpdateTexture(myImage.myTexture);
|
||||||
myImage.myPixelsFlipped = pixelsFlipped;
|
myImage.myPixelsFlipped = pixelsFlipped;
|
||||||
myImage.myNeedArrayUpdate = true;
|
myImage.myArrayUpdated = false;
|
||||||
myImage.myNeedTextureUpdate = false;
|
myImage.myTextureUpdated = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -190,7 +190,7 @@ void Sprite::Render(RenderTarget&, RenderQueue& queue) const
|
|||||||
|
|
||||||
// Check if the image is valid, and calculate the texture coordinates
|
// Check if the image is valid, and calculate the texture coordinates
|
||||||
FloatRect coords;
|
FloatRect coords;
|
||||||
if (myImage && (myImage->GetWidth() > 0) && (myImage->GetHeight() > 0))
|
if (myImage)
|
||||||
{
|
{
|
||||||
coords = myImage->GetTexCoords(mySubRect);
|
coords = myImage->GetTexCoords(mySubRect);
|
||||||
if (myIsFlippedX) std::swap(coords.Left, coords.Right);
|
if (myIsFlippedX) std::swap(coords.Left, coords.Right);
|
||||||
|
@ -36,10 +36,10 @@ namespace sf
|
|||||||
/// Default constructor
|
/// Default constructor
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Text::Text() :
|
Text::Text() :
|
||||||
myFont (&Font::GetDefaultFont()),
|
myFont (&Font::GetDefaultFont()),
|
||||||
myCharacterSize (30),
|
myCharacterSize(30),
|
||||||
myStyle (Regular),
|
myStyle (Regular),
|
||||||
myNeedRectUpdate(true)
|
myRectUpdated (true)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -49,10 +49,10 @@ myNeedRectUpdate(true)
|
|||||||
/// Construct the string from any kind of text
|
/// Construct the string from any kind of text
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
Text::Text(const String& string, const Font& font, unsigned int characterSize) :
|
Text::Text(const String& string, const Font& font, unsigned int characterSize) :
|
||||||
myFont (&font),
|
myFont (&font),
|
||||||
myCharacterSize (characterSize),
|
myCharacterSize(characterSize),
|
||||||
myStyle (Regular),
|
myStyle (Regular),
|
||||||
myNeedRectUpdate(true)
|
myRectUpdated (true)
|
||||||
{
|
{
|
||||||
SetString(string);
|
SetString(string);
|
||||||
}
|
}
|
||||||
@ -63,8 +63,8 @@ myNeedRectUpdate(true)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Text::SetString(const String& string)
|
void Text::SetString(const String& string)
|
||||||
{
|
{
|
||||||
myNeedRectUpdate = true;
|
|
||||||
myString = string;
|
myString = string;
|
||||||
|
myRectUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -75,8 +75,8 @@ void Text::SetFont(const Font& font)
|
|||||||
{
|
{
|
||||||
if (myFont != &font)
|
if (myFont != &font)
|
||||||
{
|
{
|
||||||
myNeedRectUpdate = true;
|
|
||||||
myFont = &font;
|
myFont = &font;
|
||||||
|
myRectUpdated = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -88,8 +88,8 @@ void Text::SetCharacterSize(unsigned int size)
|
|||||||
{
|
{
|
||||||
if (myCharacterSize != size)
|
if (myCharacterSize != size)
|
||||||
{
|
{
|
||||||
myNeedRectUpdate = true;
|
|
||||||
myCharacterSize = size;
|
myCharacterSize = size;
|
||||||
|
myRectUpdated = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -102,8 +102,8 @@ void Text::SetStyle(unsigned long style)
|
|||||||
{
|
{
|
||||||
if (myStyle != style)
|
if (myStyle != style)
|
||||||
{
|
{
|
||||||
myNeedRectUpdate = true;
|
|
||||||
myStyle = style;
|
myStyle = style;
|
||||||
|
myRectUpdated = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -197,8 +197,7 @@ Vector2f Text::GetCharacterPos(std::size_t index) const
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
FloatRect Text::GetRect() const
|
FloatRect Text::GetRect() const
|
||||||
{
|
{
|
||||||
if (myNeedRectUpdate)
|
UpdateRect();
|
||||||
const_cast<Text*>(this)->RecomputeRect();
|
|
||||||
|
|
||||||
FloatRect rect;
|
FloatRect rect;
|
||||||
rect.Left = (myBaseRect.Left - GetOrigin().x) * GetScale().x + GetPosition().x;
|
rect.Left = (myBaseRect.Left - GetOrigin().x) * GetScale().x + GetPosition().x;
|
||||||
@ -312,10 +311,13 @@ void Text::Render(RenderTarget&, RenderQueue& queue) const
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
/// Recompute the bounding rectangle of the text
|
/// Recompute the bounding rectangle of the text
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void Text::RecomputeRect()
|
void Text::UpdateRect() const
|
||||||
{
|
{
|
||||||
|
if (myRectUpdated)
|
||||||
|
return;
|
||||||
|
|
||||||
// Reset the previous states
|
// Reset the previous states
|
||||||
myNeedRectUpdate = false;
|
myRectUpdated = true;
|
||||||
myBaseRect = FloatRect(0, 0, 0, 0);
|
myBaseRect = FloatRect(0, 0, 0, 0);
|
||||||
|
|
||||||
// No text or not font: empty box
|
// No text or not font: empty box
|
||||||
|
@ -32,12 +32,12 @@ namespace sf
|
|||||||
{
|
{
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
View::View() :
|
View::View() :
|
||||||
myCenter (),
|
myCenter (),
|
||||||
mySize (),
|
mySize (),
|
||||||
myRotation (0),
|
myRotation (0),
|
||||||
myViewport (0, 0, 1, 1),
|
myViewport (0, 0, 1, 1),
|
||||||
myNeedUpdate (true),
|
myMatrixUpdated (false),
|
||||||
myNeedInvUpdate(true)
|
myInvMatrixUpdated(false)
|
||||||
{
|
{
|
||||||
Reset(FloatRect(0, 0, 1000, 1000));
|
Reset(FloatRect(0, 0, 1000, 1000));
|
||||||
}
|
}
|
||||||
@ -45,12 +45,12 @@ myNeedInvUpdate(true)
|
|||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
View::View(const FloatRect& rectangle) :
|
View::View(const FloatRect& rectangle) :
|
||||||
myCenter (),
|
myCenter (),
|
||||||
mySize (),
|
mySize (),
|
||||||
myRotation (0),
|
myRotation (0),
|
||||||
myViewport (0, 0, 1, 1),
|
myViewport (0, 0, 1, 1),
|
||||||
myNeedUpdate (true),
|
myMatrixUpdated (false),
|
||||||
myNeedInvUpdate(true)
|
myInvMatrixUpdated(false)
|
||||||
{
|
{
|
||||||
Reset(rectangle);
|
Reset(rectangle);
|
||||||
}
|
}
|
||||||
@ -58,12 +58,12 @@ myNeedInvUpdate(true)
|
|||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
View::View(const Vector2f& center, const Vector2f& size) :
|
View::View(const Vector2f& center, const Vector2f& size) :
|
||||||
myCenter (center),
|
myCenter (center),
|
||||||
mySize (size),
|
mySize (size),
|
||||||
myRotation (0),
|
myRotation (0),
|
||||||
myViewport (0, 0, 1, 1),
|
myViewport (0, 0, 1, 1),
|
||||||
myNeedUpdate (true),
|
myMatrixUpdated (false),
|
||||||
myNeedInvUpdate(true)
|
myInvMatrixUpdated(false)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -71,10 +71,11 @@ myNeedInvUpdate(true)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void View::SetCenter(float x, float y)
|
void View::SetCenter(float x, float y)
|
||||||
{
|
{
|
||||||
myCenter.x = x;
|
myCenter.x = x;
|
||||||
myCenter.y = y;
|
myCenter.y = y;
|
||||||
myNeedUpdate = true;
|
|
||||||
myNeedInvUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -88,10 +89,11 @@ void View::SetCenter(const Vector2f& center)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void View::SetSize(float width, float height)
|
void View::SetSize(float width, float height)
|
||||||
{
|
{
|
||||||
mySize.x = width;
|
mySize.x = width;
|
||||||
mySize.y = height;
|
mySize.y = height;
|
||||||
myNeedUpdate = true;
|
|
||||||
myNeedInvUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -108,8 +110,9 @@ void View::SetRotation(float angle)
|
|||||||
myRotation = static_cast<float>(fmod(angle, 360));
|
myRotation = static_cast<float>(fmod(angle, 360));
|
||||||
if (myRotation < 0)
|
if (myRotation < 0)
|
||||||
myRotation += 360.f;
|
myRotation += 360.f;
|
||||||
myNeedUpdate = true;
|
|
||||||
myNeedInvUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -123,11 +126,12 @@ void View::SetViewport(const FloatRect& viewport)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void View::Reset(const FloatRect& rectangle)
|
void View::Reset(const FloatRect& rectangle)
|
||||||
{
|
{
|
||||||
myCenter = rectangle.GetCenter();
|
myCenter = rectangle.GetCenter();
|
||||||
mySize = rectangle.GetSize();
|
mySize = rectangle.GetSize();
|
||||||
myRotation = 0;
|
myRotation = 0;
|
||||||
myNeedUpdate = true;
|
|
||||||
myNeedInvUpdate = true;
|
myMatrixUpdated = false;
|
||||||
|
myInvMatrixUpdated = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -191,10 +195,10 @@ void View::Zoom(float factor)
|
|||||||
const Matrix3& View::GetMatrix() const
|
const Matrix3& View::GetMatrix() const
|
||||||
{
|
{
|
||||||
// Recompute the matrix if needed
|
// Recompute the matrix if needed
|
||||||
if (myNeedUpdate)
|
if (!myMatrixUpdated)
|
||||||
{
|
{
|
||||||
myMatrix.SetFromProjection(myCenter, mySize, myRotation);
|
myMatrix.SetFromProjection(myCenter, mySize, myRotation);
|
||||||
myNeedUpdate = false;
|
myMatrixUpdated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return myMatrix;
|
return myMatrix;
|
||||||
@ -205,10 +209,10 @@ const Matrix3& View::GetMatrix() const
|
|||||||
const Matrix3& View::GetInverseMatrix() const
|
const Matrix3& View::GetInverseMatrix() const
|
||||||
{
|
{
|
||||||
// Recompute the matrix if needed
|
// Recompute the matrix if needed
|
||||||
if (myNeedInvUpdate)
|
if (!myInvMatrixUpdated)
|
||||||
{
|
{
|
||||||
myInverseMatrix = GetMatrix().GetInverse();
|
myInverseMatrix = GetMatrix().GetInverse();
|
||||||
myNeedInvUpdate = false;
|
myInvMatrixUpdated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return myInverseMatrix;
|
return myInverseMatrix;
|
||||||
|
Loading…
Reference in New Issue
Block a user