diff options
author | tsahi glik <tsahi.glik@cloudon.com> | 2013-10-07 10:38:24 -0700 |
---|---|---|
committer | Tor Lillqvist <tml@collabora.com> | 2013-10-08 19:57:25 +0000 |
commit | 91caa3dbe222498bd17b02ab6390187d7553d1d1 (patch) | |
tree | d3f71fd3dcb9e06dac58c4b9cd18574541f91b65 | |
parent | 3786609a153b7fa38393eb646557d241af2d3060 (diff) |
Hanlde TopDown -> BottomUp conversion in basebmp DirectCopy logic
Change-Id: Ic6b94e8f01c0151741626f8b50d69597cc401852
Reviewed-on: https://gerrit.libreoffice.org/6155
Reviewed-by: Tor Lillqvist <tml@collabora.com>
Tested-by: Tor Lillqvist <tml@collabora.com>
-rw-r--r-- | basebmp/source/bitmapdevice.cxx | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/basebmp/source/bitmapdevice.cxx b/basebmp/source/bitmapdevice.cxx index 0c8db660d15d..84f5e3c9dff8 100644 --- a/basebmp/source/bitmapdevice.cxx +++ b/basebmp/source/bitmapdevice.cxx @@ -749,21 +749,33 @@ namespace char* srcBuf = (char*)rSrcBitmap->getBuffer().get(); sal_Int32 dstStride = getScanlineStride(); sal_Int32 srcStride = rSrcBitmap->getScanlineStride(); - int bytesPerPixel = (bitsPerPixel[getScanlineFormat()] + 7) >> 3; // round up to bytes + sal_Int32 bytesPerPixel = (bitsPerPixel[getScanlineFormat()] + 7) >> 3; // round up to bytes + bool dstTopDown = isTopDown(); + bool srcTopDown = rSrcBitmap->isTopDown(); if (dstBuf == srcBuf && nSrcY < nDestY) // reverse copy order to avoid overlapping { - dstBuf += dstStride * (getBufferSize().getY() - 1); - srcBuf += srcStride * (getBufferSize().getY() - 1); nSrcY = getBufferSize().getY() - nSrcY - nSrcHeight; nDestY = getBufferSize().getY() - nDestY - nSrcHeight; + srcTopDown = !srcTopDown; + dstTopDown = !dstTopDown; + } + + if (!dstTopDown) + { + dstBuf += dstStride * (getBufferSize().getY() - 1); dstStride = -dstStride; + } + + if (!srcTopDown) + { + srcBuf += srcStride * (rSrcBitmap->getBufferSize().getY() - 1); srcStride = -srcStride; } char* dstline = dstBuf + dstStride * nDestY + nDestX * bytesPerPixel; char* srcline = srcBuf + srcStride * nSrcY + nSrcX * bytesPerPixel; - int lineBytes = nSrcWidth * bytesPerPixel; + sal_Int32 lineBytes = nSrcWidth * bytesPerPixel; for(; 0 < nSrcHeight; nSrcHeight--) { @@ -1916,6 +1928,8 @@ inline sal_uInt32 nextPow2( sal_uInt32 x ) } + + namespace { BitmapDeviceSharedPtr createBitmapDeviceImplInner( const basegfx::B2IVector& rSize, |