diff options
author | Tomaž Vajngerl <tomaz.vajngerl@collabora.com> | 2014-08-03 22:39:05 +0200 |
---|---|---|
committer | Tomaž Vajngerl <tomaz.vajngerl@collabora.com> | 2014-08-03 22:42:20 +0200 |
commit | 2b61e26c4ad81bf410f659e328e758acb637d01b (patch) | |
tree | e9784f8bcb09b83135bf0d4b7c8ffeabf2aa1a7e /android | |
parent | 370f05aabbcb8f348a9739d2ef324b7f72f0afa7 (diff) |
LOAndroid3: correctly calculate which tiles to draw
Change-Id: I195a318c8ce86cfcb12f724e04c115e0de444345
Diffstat (limited to 'android')
-rw-r--r-- | android/experimental/LOAndroid3/src/java/org/libreoffice/LOKitThread.java | 36 |
1 files changed, 19 insertions, 17 deletions
diff --git a/android/experimental/LOAndroid3/src/java/org/libreoffice/LOKitThread.java b/android/experimental/LOAndroid3/src/java/org/libreoffice/LOKitThread.java index 58339bfa1554..a195da097028 100644 --- a/android/experimental/LOAndroid3/src/java/org/libreoffice/LOKitThread.java +++ b/android/experimental/LOAndroid3/src/java/org/libreoffice/LOKitThread.java @@ -26,6 +26,20 @@ public class LOKitThread extends Thread { mInputFile = inputFile; } + RectF normlizeRect(ViewportMetrics metrics) { + RectF rect = metrics.getViewport(); + float zoomFactor = metrics.getZoomFactor(); + return new RectF(rect.left / zoomFactor, rect.top / zoomFactor, rect.right / zoomFactor, rect.bottom / zoomFactor); + } + + Rect roundToTileSize(RectF input, int tileSize) { + int minX = (Math.round(input.left) / tileSize) * tileSize; + int minY = (Math.round(input.top) / tileSize) * tileSize; + int maxX = ((Math.round(input.right) / tileSize) + 1) * tileSize; + int maxY = ((Math.round(input.bottom) / tileSize) + 1) * tileSize; + return new Rect(minX, minY, maxX, maxY); + } + private boolean draw() throws InterruptedException { int pageWidth = mTileProvider.getPageWidth(); int pageHeight = mTileProvider.getPageHeight(); @@ -34,27 +48,15 @@ public class LOKitThread extends Thread { mViewportMetrics.setPageSize(new FloatSize(pageWidth, pageHeight)); GeckoLayerClient layerClient = mApplication.getLayerClient(); - ViewportMetrics metrics = mApplication.getLayerController().getViewportMetrics(); - - RectF viewport = metrics.getClampedViewport(); - float zoomFactor = metrics.getZoomFactor(); - boolean shouldContinue = layerClient.beginDrawing(mViewportMetrics); if (!shouldContinue) { return false; } - int minX = ((int) viewport.left / TILE_SIZE) * TILE_SIZE; - int minY = ((int) viewport.top / TILE_SIZE) * TILE_SIZE; - int maxX = (((int) viewport.right / TILE_SIZE) + 1) * TILE_SIZE; - int maxY = (((int) viewport.bottom / TILE_SIZE) + 1) * TILE_SIZE; - - Rect rect = new Rect( - Math.round(minX / zoomFactor), - Math.round(minY / zoomFactor), - Math.round(maxX / zoomFactor), - Math.round(maxY / zoomFactor)); + ViewportMetrics metrics = mApplication.getLayerController().getViewportMetrics(); + RectF viewport = normlizeRect(metrics); + Rect rect = roundToTileSize(viewport, TILE_SIZE); ArrayList<SubTile> removeTiles = new ArrayList<SubTile>(); for (SubTile tile : layerClient.getTiles()) { @@ -64,8 +66,8 @@ public class LOKitThread extends Thread { } layerClient.getTiles().removeAll(removeTiles); - for (int y = minY; y <= maxY; y+=TILE_SIZE) { - for (int x = minX; x <= maxX; x+=TILE_SIZE) { + for (int y = rect.top; y <= rect.bottom; y += TILE_SIZE) { + for (int x = rect.left; x <= rect.right; x += TILE_SIZE) { if (x > pageWidth) { continue; } |