summaryrefslogtreecommitdiff
path: root/android
diff options
context:
space:
mode:
authorTomaž Vajngerl <tomaz.vajngerl@collabora.co.uk>2015-01-21 15:30:54 +0900
committerMiklos Vajna <vmiklos@collabora.co.uk>2015-01-26 10:27:41 +0100
commit872e5d85519f09b85cbde2dfb1c07ff0c825ff8d (patch)
treec6a019460c603fa9c57e263f038bfcb102d90f29 /android
parent784a1765d7e90382d7656eea569c2d66c0ba1c5f (diff)
Revert "android: store tiles in Map for faster access to tiles"
This reverts commit 6263bcfd70bf76dbcdf6b7e35bb02e48e44cbd94. Conflicts: android/experimental/LOAndroid3/src/java/org/mozilla/gecko/gfx/ComposedTileLayer.java Change-Id: I2fbd0b67aa3ccf0f629ce4af8788236d297144e5
Diffstat (limited to 'android')
-rw-r--r--android/experimental/LOAndroid3/src/java/org/mozilla/gecko/gfx/ComposedTileLayer.java55
1 files changed, 27 insertions, 28 deletions
diff --git a/android/experimental/LOAndroid3/src/java/org/mozilla/gecko/gfx/ComposedTileLayer.java b/android/experimental/LOAndroid3/src/java/org/mozilla/gecko/gfx/ComposedTileLayer.java
index d917c03ea2be..ca25438e7c31 100644
--- a/android/experimental/LOAndroid3/src/java/org/mozilla/gecko/gfx/ComposedTileLayer.java
+++ b/android/experimental/LOAndroid3/src/java/org/mozilla/gecko/gfx/ComposedTileLayer.java
@@ -14,18 +14,14 @@ import org.libreoffice.LOKitShell;
import org.libreoffice.TileIdentifier;
import org.mozilla.gecko.util.FloatUtils;
-import java.util.Collections;
-import java.util.Iterator;
-import java.util.Map;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.concurrent.CopyOnWriteArrayList;
public abstract class ComposedTileLayer extends Layer implements ComponentCallbacks2 {
private static final String LOGTAG = ComposedTileLayer.class.getSimpleName();
- protected final ConcurrentMap<TileIdentifier, SubTile> tiles = new ConcurrentHashMap<TileIdentifier, SubTile>();
- protected final Set<TileIdentifier> newTileIds = Collections.newSetFromMap(new ConcurrentHashMap<TileIdentifier, Boolean>());
+ protected final List<SubTile> tiles = new CopyOnWriteArrayList<SubTile>();
protected final IntSize tileSize;
protected RectF currentViewport = new RectF();
@@ -37,7 +33,7 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
}
public void invalidate() {
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
tile.invalidate();
}
}
@@ -45,14 +41,14 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
@Override
public void beginTransaction() {
super.beginTransaction();
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
tile.beginTransaction();
}
}
@Override
public void endTransaction() {
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
tile.endTransaction();
}
super.endTransaction();
@@ -60,7 +56,7 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
@Override
public void draw(RenderContext context) {
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
if (RectF.intersects(tile.getBounds(context), context.viewport)) {
tile.draw(context);
}
@@ -71,7 +67,7 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
protected void performUpdates(RenderContext context) {
super.performUpdates(context);
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
tile.beginTransaction();
tile.refreshTileMetrics();
tile.endTransaction();
@@ -82,7 +78,7 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
@Override
public Region getValidRegion(RenderContext context) {
Region validRegion = new Region();
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
validRegion.op(tile.getValidRegion(context), Region.Op.UNION);
}
@@ -92,7 +88,7 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
@Override
public void setResolution(float newResolution) {
super.setResolution(newResolution);
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
tile.setResolution(newResolution);
}
}
@@ -159,9 +155,14 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
if (x > pageRect.width()) {
continue;
}
- TileIdentifier tileId = new TileIdentifier((int) x, (int) y, currentZoom, tileSize);
- if (!tiles.containsKey(tileId) && !newTileIds.contains(tileId)) {
- newTileIds.add(tileId);
+ boolean contains = false;
+ for (SubTile tile : tiles) {
+ if (tile.id.x == x && tile.id.y == y && tile.id.zoom == currentZoom) {
+ contains = true;
+ }
+ }
+ if (!contains) {
+ TileIdentifier tileId = new TileIdentifier((int) x, (int) y, currentZoom, tileSize);
LOEvent event = LOEventFactory.tileRequest(this, tileId, true);
event.mPriority = getTilePriority();
LOKitShell.sendEvent(event);
@@ -171,18 +172,18 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
}
private void clearMarkedTiles() {
- Iterator<Map.Entry<TileIdentifier, SubTile>> iterator;
- for (iterator = tiles.entrySet().iterator(); iterator.hasNext();) {
- SubTile tile = iterator.next().getValue();
+ List<SubTile> tilesToRemove = new ArrayList<SubTile>();
+ for (SubTile tile : tiles) {
if (tile.markedForRemoval) {
tile.destroy();
- iterator.remove();
+ tilesToRemove.add(tile);
}
}
+ tiles.removeAll(tilesToRemove);
}
private void markTiles() {
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
if (FloatUtils.fuzzyEquals(tile.id.zoom, currentZoom)) {
RectF tileRect = tile.id.getRectF();
if (!RectF.intersects(currentViewport, tileRect)) {
@@ -201,8 +202,7 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
public void addTile(SubTile tile) {
tile.beginTransaction();
- tiles.put(tile.id, tile);
- newTileIds.remove(tile.id);
+ tiles.add(tile);
}
public boolean isStillValid(TileIdentifier tileId) {
@@ -215,7 +215,7 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
public void invalidateTiles(RectF cssRect) {
RectF zoomedRect = RectUtils.scale(cssRect, currentZoom);
- for (SubTile tile : tiles.values()) {
+ for (SubTile tile : tiles) {
if (RectF.intersects(zoomedRect, tile.id.getRectF())) {
LOKitShell.sendEvent(LOEventFactory.tileRerender(this, tile));
}
@@ -241,6 +241,5 @@ public abstract class ComposedTileLayer extends Layer implements ComponentCallba
}
public void cleanupInvalidTile(TileIdentifier tileId) {
- newTileIds.remove(tileId);
}
-} \ No newline at end of file
+}