summaryrefslogtreecommitdiff
path: root/android/experimental
diff options
context:
space:
mode:
authorTomaž Vajngerl <tomaz.vajngerl@collabora.com>2014-08-03 22:39:05 +0200
committerTomaž Vajngerl <tomaz.vajngerl@collabora.com>2014-08-03 22:42:20 +0200
commit2b61e26c4ad81bf410f659e328e758acb637d01b (patch)
treee9784f8bcb09b83135bf0d4b7c8ffeabf2aa1a7e /android/experimental
parent370f05aabbcb8f348a9739d2ef324b7f72f0afa7 (diff)
LOAndroid3: correctly calculate which tiles to draw
Change-Id: I195a318c8ce86cfcb12f724e04c115e0de444345
Diffstat (limited to 'android/experimental')
-rw-r--r--android/experimental/LOAndroid3/src/java/org/libreoffice/LOKitThread.java36
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;
}