Sprite::capInsets -> Sprite::centerRect (#16770)

* Sprite::capInsets -> Sprite::centerRect

as requested by @minggo

* fixes flip issues in Sprite with slice 9
This commit is contained in:
Ricardo Quesada 2016-10-29 17:52:33 -07:00 committed by GitHub
parent 3ab1be61a7
commit e0809d869c
6 changed files with 280 additions and 116 deletions

View File

@ -311,7 +311,7 @@ Sprite::Sprite(void)
, _texture(nullptr) , _texture(nullptr)
, _spriteFrame(nullptr) , _spriteFrame(nullptr)
, _insideBounds(true) , _insideBounds(true)
, _capInsetsNormalized(0,0,1,1) , _centerRectNormalized(0,0,1,1)
, _numberOfSlices(1) , _numberOfSlices(1)
, _quads(nullptr) , _quads(nullptr)
, _strechFactor(Vec2::ONE) , _strechFactor(Vec2::ONE)
@ -436,10 +436,10 @@ void Sprite::updatePoly()
CCASSERT(_numberOfSlices == 9, "Invalid number of slices"); CCASSERT(_numberOfSlices == 9, "Invalid number of slices");
// center rect // center rect
const float x1 = _capInsetsNormalized.origin.x; const float cx1 = _centerRectNormalized.origin.x;
const float y1 = _capInsetsNormalized.origin.y; const float cy1 = _centerRectNormalized.origin.y;
const float x2 = _capInsetsNormalized.origin.x + _capInsetsNormalized.size.width; const float cx2 = _centerRectNormalized.origin.x + _centerRectNormalized.size.width;
const float y2 = _capInsetsNormalized.origin.y + _capInsetsNormalized.size.height; const float cy2 = _centerRectNormalized.origin.y + _centerRectNormalized.size.height;
// "O"riginal rect // "O"riginal rect
const float oox = _rect.origin.x; const float oox = _rect.origin.x;
@ -449,46 +449,91 @@ void Sprite::updatePoly()
// textCoords Data: Y must be inverted. // textCoords Data: Y must be inverted.
const float u0 = oox + osw * 0; const float u0 = oox + osw * 0;
const float u1 = oox + osw * x1; const float u1 = oox + osw * cx1;
const float u2 = oox + osw * x2; const float u2 = oox + osw * cx2;
const float v0 = ooy + osh - (osh * y1); const float v0 = ooy + osh - (osh * cy1);
const float v1 = ooy + osh * (1-y2); const float v1 = ooy + osh * (1 - cy2);
const float v2 = ooy + osh * 0; const float v2 = ooy + osh * 0;
const Rect texRects[9] = { const Rect texRects[9] = {
Rect(u0, v0, osw * x1, osh * y1), // bottom-left Rect(u0, v0, osw * cx1, osh * cy1), // bottom-left
Rect(u1, v0, osw * (x2-x1), osh * y1), // bottom Rect(u1, v0, osw * (cx2-cx1), osh * cy1), // bottom
Rect(u2, v0, osw * (1-x2), osh * y1), // bottom-right Rect(u2, v0, osw * (1-cx2), osh * cy1), // bottom-right
Rect(u0, v1, osw * x1, osh * (y2-y1)), // left Rect(u0, v1, osw * cx1, osh * (cy2-cy1)), // left
Rect(u1, v1, osw * (x2-x1), osh * (y2-y1)), // center Rect(u1, v1, osw * (cx2-cx1), osh * (cy2-cy1)), // center
Rect(u2, v1, osw * (1-x2), osh * (y2-y1)), // right Rect(u2, v1, osw * (1-cx2), osh * (cy2-cy1)), // right
Rect(u0, v2, osw * x1, osh * (1-y2)), // top-left Rect(u0, v2, osw * cx1, osh * (1-cy2)), // top-left
Rect(u1, v2, osw * (x2-x1), osh * (1-y2)), // top Rect(u1, v2, osw * (cx2-cx1), osh * (1-cy2)), // top
Rect(u2, v2, osw * (1-x2), osh * (1-y2)), // top-right Rect(u2, v2, osw * (1-cx2), osh * (1-cy2)), // top-right
}; };
// vertex Data. // vertex Data.
const float x2_x1_strech = osw * (x2-x1) * _strechFactor.x;
const float y2_y1_strech = osh * (y2-y1) * _strechFactor.y; // sizes
float x0_s = osw * cx1;
float x1_s = osw * (cx2-cx1) * _strechFactor.x;
float x2_s = osw * (1-cx2);
float y0_s = osh * cy1;
float y1_s = osh * (cy2-cy1) * _strechFactor.y;
float y2_s = osh * (1-cy2);
// It is easier to call "updateXY", but it will be slower.
// so the flipping is calculated here at the cost of adding
// just a little bit more of complexity.
// swap sizes to calculate offset correctly
if (_flippedX)
std::swap(x0_s, x2_s);
if (_flippedY)
std::swap(y0_s, y2_s);
// origins
float x0 = 0;
float x1 = x0 + x0_s;
float x2 = x1 + x1_s;
float y0 = 0;
float y1 = y0 + y0_s;
float y2 = y1 + y1_s;
// swap origin, but restore size to its original value
if (_flippedX) {
std::swap(x0, x2);
std::swap(x0_s, x2_s);
}
if (_flippedY) {
std::swap(y0, y2);
std::swap(y0_s, y2_s);
}
const Rect verticesRects[9] = { const Rect verticesRects[9] = {
Rect(osw * 0, osh * 0, osw * x1, osh * y1), // bottom-left Rect(x0, y0, x0_s, y0_s), // bottom-left
Rect(osw * x1, osh * 0, x2_x1_strech, osh * y1), // bottom Rect(x1, y0, x1_s, y0_s), // bottom
Rect(osw * x1 + x2_x1_strech, osh * 0, osw * (1-x2), osh * y1), // bottom-right Rect(x2, y0, x2_s, y0_s), // bottom-right
Rect(osw * 0, osh * y1, osw * x1, y2_y1_strech), // left Rect(x0, y1, x0_s, y1_s), // left
Rect(osw * x1, osh * y1, x2_x1_strech, y2_y1_strech), // center Rect(x1, y1, x1_s, y1_s), // center
Rect(osw * x1 + x2_x1_strech, osh * y1, osw * (1-x2), y2_y1_strech), // right Rect(x2, y1, x2_s, y1_s), // right
Rect(osw * 0, osh * y1 + y2_y1_strech, osw * x1, osh * (1-y2)), // top-left Rect(x0, y2, x0_s, y2_s), // top-left
Rect(osw * x1, osh * y1 + y2_y1_strech, x2_x1_strech, osh * (1-y2)), // top Rect(x1, y2, x1_s, y2_s), // top
Rect(osw * x1 + x2_x1_strech, osh * y1 + y2_y1_strech, osw * (1-x2), osh * (1-y2)), // top-right Rect(x2, y2, x2_s, y2_s), // top-right
}; };
const int rotatedIdx[] = {6, 3, 0, 7, 4, 1, 8, 5, 2}; static const int normalIdx[] = {
0, 1, 2,
3, 4, 5,
6, 7 ,8
};
static const int rotatedIdx[] = {
6, 3, 0,
7, 4, 1,
8, 5, 2};
const int* idx = _rectRotated ? rotatedIdx : normalIdx;
for (int i=0; i<_numberOfSlices; ++i) { for (int i=0; i<_numberOfSlices; ++i) {
const int texIdx = _rectRotated ? rotatedIdx[i] : i; int texIdx = idx[i];
setTextureCoords(texRects[texIdx], &_quads[i]); setTextureCoords(texRects[texIdx], &_quads[i]);
setVertexCoords(verticesRects[i], _rect.size, &_quads[i]); setVertexCoords(verticesRects[i], _rect.size, &_quads[i]);
} }
@ -496,14 +541,14 @@ void Sprite::updatePoly()
} }
} }
void Sprite::setCapInsetsNormalized(const cocos2d::Rect &rectTopLeft) void Sprite::setCenterRectNormalized(const cocos2d::Rect &rectTopLeft)
{ {
// FIMXE: Rect is has origin on top-left (like text coordinate). // FIMXE: Rect is has origin on top-left (like text coordinate).
// but all the logic has been done using bottom-left as origin. So it is easier to invert Y // but all the logic has been done using bottom-left as origin. So it is easier to invert Y
// here, than in the rest of the places... but it is not as clean. // here, than in the rest of the places... but it is not as clean.
Rect rect(rectTopLeft.origin.x, 1 - rectTopLeft.origin.y - rectTopLeft.size.height, rectTopLeft.size.width, rectTopLeft.size.height); Rect rect(rectTopLeft.origin.x, 1 - rectTopLeft.origin.y - rectTopLeft.size.height, rectTopLeft.size.width, rectTopLeft.size.height);
if (!_capInsetsNormalized.equals(rect)) { if (!_centerRectNormalized.equals(rect)) {
_capInsetsNormalized = rect; _centerRectNormalized = rect;
// convert it to 1-slice // convert it to 1-slice
if (rect.equals(Rect(0,0,1,1))) { if (rect.equals(Rect(0,0,1,1))) {
@ -532,7 +577,7 @@ void Sprite::setCapInsetsNormalized(const cocos2d::Rect &rectTopLeft)
} }
} }
void Sprite::setCapInsets(const cocos2d::Rect &rectInPoints) void Sprite::setCenterRect(const cocos2d::Rect &rectInPoints)
{ {
if (!_originalContentSize.equals(Size::ZERO)) if (!_originalContentSize.equals(Size::ZERO))
{ {
@ -541,20 +586,23 @@ void Sprite::setCapInsets(const cocos2d::Rect &rectInPoints)
const float y = rect.origin.y / _rect.size.height; const float y = rect.origin.y / _rect.size.height;
const float w = rect.size.width / _rect.size.width; const float w = rect.size.width / _rect.size.width;
const float h = rect.size.height / _rect.size.height; const float h = rect.size.height / _rect.size.height;
setCapInsetsNormalized(Rect(x,y,w,h)); setCenterRectNormalized(Rect(x,y,w,h));
} }
} }
Rect Sprite::getCapInsetsNormalized() const Rect Sprite::getCenterRectNormalized() const
{ {
// FIXME: _capInsetsNormalized is in bottom-left coords, but should converted to top-left // FIXME: _centerRectNormalized is in bottom-left coords, but should converted to top-left
Rect ret(_capInsetsNormalized.origin.x, 1 - _capInsetsNormalized.origin.y - _capInsetsNormalized.size.height, _capInsetsNormalized.size.width, _capInsetsNormalized.size.height); Rect ret(_centerRectNormalized.origin.x,
1 - _centerRectNormalized.origin.y - _centerRectNormalized.size.height,
_centerRectNormalized.size.width,
_centerRectNormalized.size.height);
return ret; return ret;
} }
Rect Sprite::getCapInsets() const Rect Sprite::getCenterRect() const
{ {
Rect rect = getCapInsetsNormalized(); Rect rect = getCenterRectNormalized();
rect.origin.x *= _rect.size.width; rect.origin.x *= _rect.size.width;
rect.origin.y *= _rect.size.height; rect.origin.y *= _rect.size.height;
rect.size.width *= _rect.size.width; rect.size.width *= _rect.size.width;
@ -1120,13 +1168,13 @@ void Sprite::updateStretchFactor()
} }
else else
{ {
const float x1 = _rect.size.width * _capInsetsNormalized.origin.x; const float x1 = _rect.size.width * _centerRectNormalized.origin.x;
const float x2 = _rect.size.width * _capInsetsNormalized.size.width; const float x2 = _rect.size.width * _centerRectNormalized.size.width;
const float x3 = _rect.size.width * (1 - _capInsetsNormalized.origin.x - _capInsetsNormalized.size.width); const float x3 = _rect.size.width * (1 - _centerRectNormalized.origin.x - _centerRectNormalized.size.width);
const float y1 = _rect.size.height * _capInsetsNormalized.origin.y; const float y1 = _rect.size.height * _centerRectNormalized.origin.y;
const float y2 = _rect.size.height * _capInsetsNormalized.size.height; const float y2 = _rect.size.height * _centerRectNormalized.size.height;
const float y3 = _rect.size.height * (1 - _capInsetsNormalized.origin.y - _capInsetsNormalized.size.height); const float y3 = _rect.size.height * (1 - _centerRectNormalized.origin.y - _centerRectNormalized.size.height);
const float x_factor = (adjustedWidth - x1 - x3) / x2; const float x_factor = (adjustedWidth - x1 - x3) / x2;
const float y_factor = (adjustedHeight - y1 - y3) / y2; const float y_factor = (adjustedHeight - y1 - y3) / y2;
@ -1140,10 +1188,12 @@ void Sprite::setFlippedX(bool flippedX)
if (_flippedX != flippedX) if (_flippedX != flippedX)
{ {
_flippedX = flippedX; _flippedX = flippedX;
for (ssize_t i = 0; i < _polyInfo.triangles.vertCount; i++) { for (ssize_t i = 0; i < _polyInfo.triangles.vertCount; i++) {
auto& v = _polyInfo.triangles.verts[i].vertices; auto& v = _polyInfo.triangles.verts[i].vertices;
v.x = _contentSize.width -v.x; v.x = _contentSize.width - v.x;
} }
if (_textureAtlas) { if (_textureAtlas) {
setDirty(true); setDirty(true);
} }
@ -1160,10 +1210,12 @@ void Sprite::setFlippedY(bool flippedY)
if (_flippedY != flippedY) if (_flippedY != flippedY)
{ {
_flippedY = flippedY; _flippedY = flippedY;
for (ssize_t i = 0; i < _polyInfo.triangles.vertCount; i++) { for (ssize_t i = 0; i < _polyInfo.triangles.vertCount; i++) {
auto& v = _polyInfo.triangles.verts[i].vertices; auto& v = _polyInfo.triangles.verts[i].vertices;
v.y = _contentSize.height -v.y; v.y = _contentSize.height - v.y;
} }
if (_textureAtlas) { if (_textureAtlas) {
setDirty(true); setDirty(true);
} }
@ -1279,7 +1331,7 @@ void Sprite::setSpriteFrame(SpriteFrame *spriteFrame)
} }
if (spriteFrame->hasCenterRect()) if (spriteFrame->hasCenterRect())
{ {
setCapInsets(spriteFrame->getCapInsets()); setCenterRect(spriteFrame->getCenterRect());
} }
} }

View File

@ -248,7 +248,7 @@ public:
virtual void setVertexRect(const Rect& rect); virtual void setVertexRect(const Rect& rect);
/** /**
* setCapInsetsNormalized * setCenterRectNormalized
* *
* Useful to implement "9 sliced" sprites. * Useful to implement "9 sliced" sprites.
* The default value is (0,0) - (1,1), which means that only one "slice" will be used: From top-left (0,0) to bottom-right (1,1). * The default value is (0,0) - (1,1), which means that only one "slice" will be used: From top-left (0,0) to bottom-right (1,1).
@ -259,27 +259,27 @@ public:
* *
* Limitations: Does not work when the sprite is part of `SpriteBatchNode`. * Limitations: Does not work when the sprite is part of `SpriteBatchNode`.
*/ */
virtual void setCapInsetsNormalized(const Rect& rect); virtual void setCenterRectNormalized(const Rect& rect);
/** /**
* getCapInsetsNormalized * getCenterRectNormalized
* *
* Returns the CapInsets in normalized coordinates * Returns the CenterRect in normalized coordinates
*/ */
virtual Rect getCapInsetsNormalized() const; virtual Rect getCenterRectNormalized() const;
/* setCapInsets /* setCenterRect
* *
* Like `setCapInsetsNormalized`, but instead of being in normalized coordinates, it is in points coordinates * Like `setCenterRectNormalized`, but instead of being in normalized coordinates, it is in points coordinates
*/ */
virtual void setCapInsets(const Rect& rect); virtual void setCenterRect(const Rect& rect);
/** /**
* @brief Returns the Cap Insets rect * @brief Returns the Cap Insets rect
* *
* @return Scale9Sprite's cap inset. * @return Scale9Sprite's cap inset.
*/ */
virtual Rect getCapInsets() const; virtual Rect getCenterRect() const;
/** @{ /** @{
@ -661,7 +661,7 @@ protected:
Rect _rect; /// Rectangle of Texture2D Rect _rect; /// Rectangle of Texture2D
bool _rectRotated; /// Whether the texture is rotated bool _rectRotated; /// Whether the texture is rotated
Rect _capInsetsNormalized; /// Rectangle to implement "slice 9" Rect _centerRectNormalized; /// Rectangle to implement "slice 9"
int _numberOfSlices; /// how many sprite slices: 1 or 9 int _numberOfSlices; /// how many sprite slices: 1 or 9
Vec2 _strechFactor; /// strech factor to match the contentSize. for 1- and 9- slice sprites Vec2 _strechFactor; /// strech factor to match the contentSize. for 1- and 9- slice sprites
Size _originalContentSize; /// original content size Size _originalContentSize; /// original content size

View File

@ -104,7 +104,7 @@ bool SpriteFrame::initWithTexture(Texture2D* texture, const Rect& rect, bool rot
_originalSize = CC_SIZE_PIXELS_TO_POINTS( _originalSizeInPixels ); _originalSize = CC_SIZE_PIXELS_TO_POINTS( _originalSizeInPixels );
_rotated = rotated; _rotated = rotated;
_anchorPoint = Vec2(NAN, NAN); _anchorPoint = Vec2(NAN, NAN);
_capInsetsNormalized = Rect(NAN, NAN, NAN, NAN); _centerRect = Rect(NAN, NAN, NAN, NAN);
return true; return true;
} }
@ -121,7 +121,7 @@ bool SpriteFrame::initWithTextureFilename(const std::string& filename, const Rec
_originalSize = CC_SIZE_PIXELS_TO_POINTS( _originalSizeInPixels ); _originalSize = CC_SIZE_PIXELS_TO_POINTS( _originalSizeInPixels );
_rotated = rotated; _rotated = rotated;
_anchorPoint = Vec2(NAN, NAN); _anchorPoint = Vec2(NAN, NAN);
_capInsetsNormalized = Rect(NAN, NAN, NAN, NAN); _centerRect = Rect(NAN, NAN, NAN, NAN);
return true; return true;
} }
@ -155,14 +155,14 @@ void SpriteFrame::setRectInPixels(const Rect& rectInPixels)
_rect = CC_RECT_PIXELS_TO_POINTS(rectInPixels); _rect = CC_RECT_PIXELS_TO_POINTS(rectInPixels);
} }
void SpriteFrame::setCapInsets(const Rect& centerRect) void SpriteFrame::setCenterRectInPixels(const Rect& centerRect)
{ {
_capInsetsNormalized = CC_RECT_PIXELS_TO_POINTS(centerRect); _centerRect = CC_RECT_PIXELS_TO_POINTS(centerRect);
} }
bool SpriteFrame::hasCenterRect() const bool SpriteFrame::hasCenterRect() const
{ {
return !std::isnan(_capInsetsNormalized.origin.x); return !std::isnan(_centerRect.origin.x);
} }
const Vec2& SpriteFrame::getOffset() const const Vec2& SpriteFrame::getOffset() const

View File

@ -139,7 +139,7 @@ public:
* *
* @return The center rect of the sprite frame in points * @return The center rect of the sprite frame in points
*/ */
const Rect& getCapInsets() const { return _capInsetsNormalized; } const Rect& getCenterRect() const { return _centerRect; }
/** /**
* setCenterRect * setCenterRect
@ -153,7 +153,7 @@ public:
* Limitations: Does not work when the sprite is part of `SpriteBatchNode`. * Limitations: Does not work when the sprite is part of `SpriteBatchNode`.
* @param centerRect the Rect in points * @param centerRect the Rect in points
*/ */
void setCapInsets(const Rect& centerRect); void setCenterRectInPixels(const Rect& centerRect);
/** hasCenterRect /** hasCenterRect
@return Whether or not it has a centerRect @return Whether or not it has a centerRect
@ -292,7 +292,7 @@ protected:
Rect _rectInPixels; Rect _rectInPixels;
bool _rotated; bool _rotated;
Rect _rect; Rect _rect;
Rect _capInsetsNormalized; Rect _centerRect;
Vec2 _offsetInPixels; Vec2 _offsetInPixels;
Size _originalSizeInPixels; Size _originalSizeInPixels;
Texture2D *_texture; Texture2D *_texture;

View File

@ -135,6 +135,7 @@ SpriteTests::SpriteTests()
ADD_TEST_CASE(SpriteSlice9Test7); ADD_TEST_CASE(SpriteSlice9Test7);
ADD_TEST_CASE(SpriteSlice9Test8); ADD_TEST_CASE(SpriteSlice9Test8);
ADD_TEST_CASE(SpriteSlice9Test9); ADD_TEST_CASE(SpriteSlice9Test9);
ADD_TEST_CASE(SpriteSlice9Test10);
}; };
//------------------------------------------------------------------ //------------------------------------------------------------------
@ -5269,9 +5270,9 @@ SpriteSlice9Test1::SpriteSlice9Test1()
s3->runAction(action3); s3->runAction(action3);
if (i==2) { if (i==2) {
s3->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s3->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
s2->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s2->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
s1->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s1->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
} }
// "anchor points" // "anchor points"
@ -5334,9 +5335,9 @@ SpriteSlice9Test2::SpriteSlice9Test2()
s3->runAction(action3); s3->runAction(action3);
if (i==2) { if (i==2) {
s3->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s3->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
s2->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s2->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
s1->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s1->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
} }
// "anchor points" // "anchor points"
@ -5398,9 +5399,9 @@ SpriteSlice9Test3::SpriteSlice9Test3()
// enable slice 9, only in the first row // enable slice 9, only in the first row
if (i==2) { if (i==2) {
s1->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s1->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
s2->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s2->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
s3->setCapInsetsNormalized(Rect(0.4, 0.4, 0.2, 0.2)); s3->setCenterRectNormalized(Rect(0.4, 0.4, 0.2, 0.2));
} }
@ -5463,9 +5464,9 @@ SpriteSlice9Test4::SpriteSlice9Test4()
// enable slice 9, only in the first row // enable slice 9, only in the first row
if (i==2) { if (i==2) {
s1->setCapInsets(CC_RECT_PIXELS_TO_POINTS(Rect(6, 14, 2, 4))); s1->setCenterRect(CC_RECT_PIXELS_TO_POINTS(Rect(6, 14, 2, 4)));
s2->setCapInsets(CC_RECT_PIXELS_TO_POINTS(Rect(6, 14, 2, 4))); s2->setCenterRect(CC_RECT_PIXELS_TO_POINTS(Rect(6, 14, 2, 4)));
s3->setCapInsets(CC_RECT_PIXELS_TO_POINTS(Rect(6, 14, 2, 4))); s3->setCenterRect(CC_RECT_PIXELS_TO_POINTS(Rect(6, 14, 2, 4)));
} }
// "anchor points" // "anchor points"
@ -5507,7 +5508,7 @@ SpriteSlice9Test5::SpriteSlice9Test5()
s1->setPosition(s.width/2-s.width/3, s.height/2); s1->setPosition(s.width/2-s.width/3, s.height/2);
s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s1->setContentSize(Size(s.width/3, s.height)); s1->setContentSize(Size(s.width/3, s.height));
s1->setCapInsetsNormalized(Rect(0,0,1,1)); s1->setCenterRectNormalized(Rect(0,0,1,1));
_sprites[0] = s1; _sprites[0] = s1;
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
@ -5517,7 +5518,7 @@ SpriteSlice9Test5::SpriteSlice9Test5()
s2->setPosition(s.width*2/4, s.height/2); s2->setPosition(s.width*2/4, s.height/2);
s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s2->setContentSize(Size(s.width/3, s.height)); s2->setContentSize(Size(s.width/3, s.height));
s2->setCapInsetsNormalized(Rect(0,0,1,1)); s2->setCenterRectNormalized(Rect(0,0,1,1));
_sprites[1] = s2; _sprites[1] = s2;
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
@ -5527,7 +5528,7 @@ SpriteSlice9Test5::SpriteSlice9Test5()
s3->setPosition(s.width/2+s.width/3, s.height/2); s3->setPosition(s.width/2+s.width/3, s.height/2);
s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s3->setContentSize(Size(s.width/3, s.height)); s3->setContentSize(Size(s.width/3, s.height));
s3->setCapInsetsNormalized(Rect(0,0,1,1)); s3->setCenterRectNormalized(Rect(0,0,1,1));
_sprites[2] = s3; _sprites[2] = s3;
scheduleUpdate(); scheduleUpdate();
@ -5555,7 +5556,7 @@ void SpriteSlice9Test5::update(float dt)
} }
Rect rect(x,y,0.2, 0.2); Rect rect(x,y,0.2, 0.2);
_sprites[i]->setCapInsetsNormalized(rect); _sprites[i]->setCenterRectNormalized(rect);
} }
} }
@ -5580,7 +5581,7 @@ SpriteSlice9Test6::SpriteSlice9Test6()
s1->setPosition(s.width/2-s.width/3, s.height/2); s1->setPosition(s.width/2-s.width/3, s.height/2);
s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s1->setContentSize(Size(s.width/3, s.height)); s1->setContentSize(Size(s.width/3, s.height));
s1->setCapInsetsNormalized(Rect(0,0,1,1)); s1->setCenterRectNormalized(Rect(0,0,1,1));
_sprites[0] = s1; _sprites[0] = s1;
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
@ -5590,7 +5591,7 @@ SpriteSlice9Test6::SpriteSlice9Test6()
s2->setPosition(s.width*2/4, s.height/2); s2->setPosition(s.width*2/4, s.height/2);
s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s2->setContentSize(Size(s.width/3, s.height)); s2->setContentSize(Size(s.width/3, s.height));
s2->setCapInsetsNormalized(Rect(0,0,1,1)); s2->setCenterRectNormalized(Rect(0,0,1,1));
_sprites[1] = s2; _sprites[1] = s2;
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
@ -5600,7 +5601,7 @@ SpriteSlice9Test6::SpriteSlice9Test6()
s3->setPosition(s.width/2+s.width/3, s.height/2); s3->setPosition(s.width/2+s.width/3, s.height/2);
s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s3->setContentSize(Size(s.width/3, s.height)); s3->setContentSize(Size(s.width/3, s.height));
s3->setCapInsetsNormalized(Rect(0,0,1,1)); s3->setCenterRectNormalized(Rect(0,0,1,1));
_sprites[2] = s3; _sprites[2] = s3;
scheduleUpdate(); scheduleUpdate();
@ -5628,7 +5629,7 @@ void SpriteSlice9Test6::update(float dt)
} }
Rect rect((1-x)/2, (1-y)/2, x, y); Rect rect((1-x)/2, (1-y)/2, x, y);
_sprites[i]->setCapInsetsNormalized(rect); _sprites[i]->setCenterRectNormalized(rect);
} }
} }
@ -5653,7 +5654,7 @@ SpriteSlice9Test7::SpriteSlice9Test7()
s1->setPosition(s.width/2-s.width/3, s.height/2); s1->setPosition(s.width/2-s.width/3, s.height/2);
s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s1->setContentSize(Size(s.width/3, s.height)); s1->setContentSize(Size(s.width/3, s.height));
s1->setCapInsetsNormalized(Rect(0,0,0.5,0.5)); s1->setCenterRectNormalized(Rect(0,0,0.5,0.5));
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
auto s2 = Sprite::create("Images/grossinis_heads.png"); auto s2 = Sprite::create("Images/grossinis_heads.png");
@ -5662,7 +5663,7 @@ SpriteSlice9Test7::SpriteSlice9Test7()
s2->setPosition(s.width*2/4, s.height/2); s2->setPosition(s.width*2/4, s.height/2);
s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s2->setContentSize(Size(s.width/3, s.height)); s2->setContentSize(Size(s.width/3, s.height));
s2->setCapInsetsNormalized(Rect(0.25,0.25,0.5,0.5)); s2->setCenterRectNormalized(Rect(0.25,0.25,0.5,0.5));
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
auto s3 = Sprite::create("Images/grossinis_heads.png"); auto s3 = Sprite::create("Images/grossinis_heads.png");
@ -5671,7 +5672,7 @@ SpriteSlice9Test7::SpriteSlice9Test7()
s3->setPosition(s.width/2+s.width/3, s.height/2); s3->setPosition(s.width/2+s.width/3, s.height/2);
s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s3->setContentSize(Size(s.width/3, s.height)); s3->setContentSize(Size(s.width/3, s.height));
s3->setCapInsetsNormalized(Rect(0.5,0.5,0.5,0.5)); s3->setCenterRectNormalized(Rect(0.5,0.5,0.5,0.5));
} }
//------------------------------------------------------------------ //------------------------------------------------------------------
@ -5687,29 +5688,63 @@ SpriteSlice9Test8::SpriteSlice9Test8()
SpriteFrameCache::getInstance()->addSpriteFramesWithFile("animations/grossini.plist"); SpriteFrameCache::getInstance()->addSpriteFramesWithFile("animations/grossini.plist");
//
// flip BEFORE contentSize
//
auto s1 = Sprite::createWithSpriteFrameName("grossinis_sister1.png"); auto s1 = Sprite::createWithSpriteFrameName("grossinis_sister1.png");
addChild(s1); addChild(s1);
s1->setPosition(s.width/2-s.width/3, s.height/2); s1->setPosition(s.width/2-s.width/3, s.height*2/3);
s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s1->setCapInsetsNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f)); s1->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s1->setContentSize(s1->getContentSize()*2);
s1->setFlippedX(true); s1->setFlippedX(true);
s1->setContentSize(s1->getContentSize()*2);
auto s2 = Sprite::createWithSpriteFrameName("grossini.png"); auto s2 = Sprite::createWithSpriteFrameName("grossini.png");
addChild(s2); addChild(s2);
s2->setPosition(s.width*2/4, s.height/2); s2->setPosition(s.width*2/4, s.height*2/3);
s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s2->setCapInsetsNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f)); s2->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s2->setFlippedX(true);
s2->setFlippedY(true);
s2->setContentSize(s2->getContentSize()*2); s2->setContentSize(s2->getContentSize()*2);
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
auto s3 = Sprite::createWithSpriteFrameName("grossinis_sister2.png"); auto s3 = Sprite::createWithSpriteFrameName("grossinis_sister2.png");
addChild(s3); addChild(s3);
s3->setPosition(s.width/2+s.width/3, s.height/2); s3->setPosition(s.width/2+s.width/3, s.height*2/3);
s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s3->setCapInsetsNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f)); s3->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s3->setContentSize(s3->getContentSize()*2);
s3->setFlippedY(true); s3->setFlippedY(true);
s3->setContentSize(s3->getContentSize()*2);
//
// flip AFTER contentSize
//
auto s4 = Sprite::createWithSpriteFrameName("grossinis_sister1.png");
addChild(s4);
s4->setPosition(s.width/2-s.width/3, s.height*1/3);
s4->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s4->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s4->setFlippedX(true);
s4->setContentSize(s4->getContentSize()*2);
auto s5 = Sprite::createWithSpriteFrameName("grossini.png");
addChild(s5);
s5->setPosition(s.width*2/4, s.height*1/3);
s5->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s5->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s5->setFlippedX(true);
s5->setFlippedY(true);
s5->setContentSize(s5->getContentSize()*2);
//Create reference sprite that's rotating based on there anchor point
auto s6 = Sprite::createWithSpriteFrameName("grossinis_sister2.png");
addChild(s6);
s6->setPosition(s.width/2+s.width/3, s.height*1/3);
s6->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s6->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s6->setFlippedY(true);
s6->setContentSize(s6->getContentSize()*2);
} }
//------------------------------------------------------------------ //------------------------------------------------------------------
@ -5721,6 +5756,73 @@ SpriteSlice9Test9::SpriteSlice9Test9()
{ {
Size s = Director::getInstance()->getVisibleSize(); Size s = Director::getInstance()->getVisibleSize();
SpriteFrameCache::getInstance()->addSpriteFramesWithFile("animations/grossini_family.plist");
SpriteFrameCache::getInstance()->addSpriteFramesWithFile("animations/grossini.plist");
// flipped BEFORE content size
auto s1 = Sprite::createWithSpriteFrameName("grossinis_sister1.png");
addChild(s1);
s1->setPosition(s.width/2-s.width/3, s.height*2/3);
s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s1->setCenterRectNormalized(Rect(2/3.f, 2/3.f, 1/3.f, 1/3.f));
s1->setFlippedX(true);
s1->setContentSize(s1->getContentSize()*2);
auto s2 = Sprite::createWithSpriteFrameName("grossini.png");
addChild(s2);
s2->setPosition(s.width*2/4, s.height*2/3);
s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s2->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 2/3.f, 2/3.f));
s2->setFlippedX(true);
s2->setFlippedY(true);
s2->setContentSize(s2->getContentSize()*2);
auto s3 = Sprite::createWithSpriteFrameName("grossinis_sister2.png");
addChild(s3);
s3->setPosition(s.width/2+s.width/3, s.height*2/3);
s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s3->setCenterRectNormalized(Rect(0.1f, 0.1f, 0.8f, 0.8f));
s3->setFlippedY(true);
s3->setContentSize(s3->getContentSize()*2);
// flipped AFTER content size
auto s4 = Sprite::createWithSpriteFrameName("grossinis_sister1.png");
addChild(s4);
s4->setPosition(s.width/2-s.width/3, s.height*1/3);
s4->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s4->setCenterRectNormalized(Rect(2/3.f, 2/3.f, 1/3.f, 1/3.f));
s4->setContentSize(s4->getContentSize()*2);
s4->setFlippedX(true);
auto s5 = Sprite::createWithSpriteFrameName("grossini.png");
addChild(s5);
s5->setPosition(s.width*2/4, s.height*1/3);
s5->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s5->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 2/3.f, 2/3.f));
s5->setContentSize(s5->getContentSize()*2);
s5->setFlippedX(true);
s5->setFlippedY(true);
auto s6 = Sprite::createWithSpriteFrameName("grossinis_sister2.png");
addChild(s6);
s6->setPosition(s.width/2+s.width/3, s.height*1/3);
s6->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s6->setCenterRectNormalized(Rect(0.1f, 0.1f, 0.8f, 0.8f));
s6->setContentSize(s6->getContentSize()*2);
s6->setFlippedY(true);
}
//------------------------------------------------------------------
//
// Slice9 Test #10
//
//------------------------------------------------------------------
SpriteSlice9Test10::SpriteSlice9Test10()
{
Size s = Director::getInstance()->getVisibleSize();
SpriteFrameCache::getInstance()->addSpriteFramesWithFile("Images/blocks9ss.plist"); SpriteFrameCache::getInstance()->addSpriteFramesWithFile("Images/blocks9ss.plist");
@ -5728,7 +5830,7 @@ SpriteSlice9Test9::SpriteSlice9Test9()
addChild(s1); addChild(s1);
s1->setPosition(s.width/2-s.width/3, s.height/2); s1->setPosition(s.width/2-s.width/3, s.height/2);
s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s1->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s1->setCapInsetsNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f)); s1->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s1->setContentSize(s1->getContentSize()*1.5); s1->setContentSize(s1->getContentSize()*1.5);
s1->setFlippedX(true); s1->setFlippedX(true);
@ -5736,7 +5838,7 @@ SpriteSlice9Test9::SpriteSlice9Test9()
addChild(s2); addChild(s2);
s2->setPosition(s.width*2/4, s.height/2); s2->setPosition(s.width*2/4, s.height/2);
s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s2->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s2->setCapInsetsNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f)); s2->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s2->setContentSize(s2->getContentSize()*1.5); s2->setContentSize(s2->getContentSize()*1.5);
//Create reference sprite that's rotating based on there anchor point //Create reference sprite that's rotating based on there anchor point
@ -5744,8 +5846,7 @@ SpriteSlice9Test9::SpriteSlice9Test9()
addChild(s3); addChild(s3);
s3->setPosition(s.width/2+s.width/3, s.height/2); s3->setPosition(s.width/2+s.width/3, s.height/2);
s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE); s3->setAnchorPoint(Vec2::ANCHOR_MIDDLE);
s3->setCapInsetsNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f)); s3->setCenterRectNormalized(Rect(1/3.f, 1/3.f, 1/3.f, 1/3.f));
s3->setContentSize(s3->getContentSize()*1.5); s3->setContentSize(s3->getContentSize()*1.5);
s3->setFlippedY(true); s3->setFlippedY(true);
} }

View File

@ -802,15 +802,6 @@ protected:
cocos2d::Vec3 rotation; cocos2d::Vec3 rotation;
}; };
class SpriteGetSpriteFrameTest : public SpriteTestDemo
{
public:
CREATE_FUNC(SpriteGetSpriteFrameTest);
SpriteGetSpriteFrameTest();
virtual std::string title() const override { return "getSpriteFrameTest()"; };
virtual std::string subtitle() const override { return "Testing it"; }
};
class SpriteSlice9Test1 : public SpriteTestDemo class SpriteSlice9Test1 : public SpriteTestDemo
{ {
public: public:
@ -883,7 +874,7 @@ public:
CREATE_FUNC(SpriteSlice9Test7); CREATE_FUNC(SpriteSlice9Test7);
SpriteSlice9Test7(); SpriteSlice9Test7();
virtual std::string title() const override { return "Slice 9 Test #7"; }; virtual std::string title() const override { return "Slice 9 Test #7"; };
virtual std::string subtitle() const override { return "Testing offset"; } virtual std::string subtitle() const override { return "Offset"; }
}; };
class SpriteSlice9Test8 : public SpriteTestDemo class SpriteSlice9Test8 : public SpriteTestDemo
@ -892,7 +883,7 @@ public:
CREATE_FUNC(SpriteSlice9Test8); CREATE_FUNC(SpriteSlice9Test8);
SpriteSlice9Test8(); SpriteSlice9Test8();
virtual std::string title() const override { return "Slice 9 Test #8"; }; virtual std::string title() const override { return "Slice 9 Test #8"; };
virtual std::string subtitle() const override { return "Testing flipX, flipY"; } virtual std::string subtitle() const override { return "Flipped sprites"; }
}; };
class SpriteSlice9Test9 : public SpriteTestDemo class SpriteSlice9Test9 : public SpriteTestDemo
@ -901,7 +892,27 @@ public:
CREATE_FUNC(SpriteSlice9Test9); CREATE_FUNC(SpriteSlice9Test9);
SpriteSlice9Test9(); SpriteSlice9Test9();
virtual std::string title() const override { return "Slice 9 Test #9"; }; virtual std::string title() const override { return "Slice 9 Test #9"; };
virtual std::string subtitle() const override { return "Testing rotated frames"; } virtual std::string subtitle() const override { return "Flipped sprites #2"; }
};
class SpriteSlice9Test10 : public SpriteTestDemo
{
public:
CREATE_FUNC(SpriteSlice9Test10);
SpriteSlice9Test10();
virtual std::string title() const override { return "Slice 10 Test #9"; };
virtual std::string subtitle() const override { return "Rotated Sprites"; }
};
class SpriteGetSpriteFrameTest : public SpriteTestDemo
{
public:
CREATE_FUNC(SpriteGetSpriteFrameTest);
SpriteGetSpriteFrameTest();
virtual std::string title() const override { return "Sprite::getSpriteFrame(*)"; };
virtual std::string subtitle() const override { return "setting after getting should be the same"; }
}; };
#endif #endif