]> git.zerfleddert.de Git - FreeShisen/commitdiff
add scaling.
authorgitknilch <gitknilch@cwde.de>
Thu, 28 Feb 2013 17:06:38 +0000 (18:06 +0100)
committergitknilch <gitknilch@cwde.de>
Thu, 28 Feb 2013 17:06:38 +0000 (18:06 +0100)
Signed-off-by: gitknilch <gitknilch@cwde.de>
src/de/cwde/shisensho/ShisenShoView.java

index 4ff8306aca1868e4dee8e05826545d67ff6084d6..06162c18d9e31164edb9038339b17fc32759ada9 100644 (file)
@@ -86,20 +86,28 @@ class ShisenShoView extends SurfaceView implements SurfaceHolder.Callback {
                // The tile set has 4 rows x 9 columns
                tilesetRows = 4;
                tilesetCols = 9;
-               tileWidth = tileset.getWidth()/tilesetCols;
-               tileHeight = tileset.getHeight()/tilesetRows;
+               int loadedtileWidth = tileset.getWidth()/tilesetCols;
+               int loadedtileHeight = tileset.getHeight()/tilesetRows;
                tile = new Bitmap[tilesetRows*tilesetCols];
 
-               // align to screen
+               // align to screen:
+               // "large" is 16x6, and we want to have a nice border, so we use 17x7 and
+               // choose the lowest scale so everything fits
+               float scalex = ((float) screenWidth/17) / loadedtileWidth;
+               float scaley = ((float) screenHeight/7) / loadedtileHeight;
+               if (scaley < scalex) {
+                       scalex = scaley;
+               } else {
+                       scaley = scalex;
+               }
                Matrix matrix = new Matrix();
-               matrix.setScale(1.0f, 1.0f); // FIXME!
-
-               // TODO: go on.
+               matrix.setScale(scalex, scaley);
 
                int k=0;
                for (int i=0; i<tilesetRows; i++) {
                        for (int j=0; j<tilesetCols; j++) {
-                               tile[k] = Bitmap.createBitmap(tileset, j*tileWidth, i*tileHeight, tileWidth, tileHeight, matrix, false);
+                               tile[k] = Bitmap.createBitmap(tileset, j*loadedtileWidth, i*loadedtileHeight,
+                                               loadedtileWidth, loadedtileHeight, matrix, false);
                                tile[k].setDensity(Bitmap.DENSITY_NONE);
                                k++;
                        }
Impressum, Datenschutz