Kaydet (Commit) e5e7e706 authored tarafından Tomaž Vajngerl's avatar Tomaž Vajngerl

LOAndroid3: upgrade to latest CairoGLInfo, CairoUtils, FloatSize

Change-Id: I93c0761b1e76848ee8b07c5bcc524c95c036d322
üst 5957f5d0
/* -*- Mode: Java; c-basic-offset: 4; tab-width: 20; indent-tabs-mode: nil; -*- /* -*- Mode: Java; c-basic-offset: 4; tab-width: 20; indent-tabs-mode: nil; -*-
* ***** BEGIN LICENSE BLOCK ***** * This Source Code Form is subject to the terms of the Mozilla Public
* Version: MPL 1.1/GPL 2.0/LGPL 2.1 * License, v. 2.0. If a copy of the MPL was not distributed with this
* * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is Mozilla Android code.
*
* The Initial Developer of the Original Code is Mozilla Foundation.
* Portions created by the Initial Developer are Copyright (C) 2009-2010
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Patrick Walton <pcwalton@mozilla.com>
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
package org.mozilla.gecko.gfx; package org.mozilla.gecko.gfx;
import javax.microedition.khronos.opengles.GL10; import javax.microedition.khronos.opengles.GL10;
/** /** Information needed to render Cairo bitmaps using OpenGL ES. */
* Information needed to render Cairo bitmaps using OpenGL ES.
*/
public class CairoGLInfo { public class CairoGLInfo {
public final int internalFormat; public final int internalFormat;
public final int format; public final int format;
...@@ -50,16 +16,13 @@ public class CairoGLInfo { ...@@ -50,16 +16,13 @@ public class CairoGLInfo {
public CairoGLInfo(int cairoFormat) { public CairoGLInfo(int cairoFormat) {
switch (cairoFormat) { switch (cairoFormat) {
case CairoImage.FORMAT_ARGB32: case CairoImage.FORMAT_ARGB32:
internalFormat = format = GL10.GL_RGBA; internalFormat = format = GL10.GL_RGBA; type = GL10.GL_UNSIGNED_BYTE;
type = GL10.GL_UNSIGNED_BYTE;
break; break;
case CairoImage.FORMAT_RGB24: case CairoImage.FORMAT_RGB24:
internalFormat = format = GL10.GL_RGB; internalFormat = format = GL10.GL_RGB; type = GL10.GL_UNSIGNED_BYTE;
type = GL10.GL_UNSIGNED_BYTE;
break; break;
case CairoImage.FORMAT_RGB16_565: case CairoImage.FORMAT_RGB16_565:
internalFormat = format = GL10.GL_RGB; internalFormat = format = GL10.GL_RGB; type = GL10.GL_UNSIGNED_SHORT_5_6_5;
type = GL10.GL_UNSIGNED_SHORT_5_6_5;
break; break;
case CairoImage.FORMAT_A8: case CairoImage.FORMAT_A8:
case CairoImage.FORMAT_A1: case CairoImage.FORMAT_A1:
......
/* -*- Mode: Java; c-basic-offset: 4; tab-width: 20; indent-tabs-mode: nil; -*- /* -*- Mode: Java; c-basic-offset: 4; tab-width: 20; indent-tabs-mode: nil; -*-
* ***** BEGIN LICENSE BLOCK ***** * This Source Code Form is subject to the terms of the Mozilla Public
* Version: MPL 1.1/GPL 2.0/LGPL 2.1 * License, v. 2.0. If a copy of the MPL was not distributed with this
* * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is Mozilla Android code.
*
* The Initial Developer of the Original Code is Mozilla Foundation.
* Portions created by the Initial Developer are Copyright (C) 2009-2010
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Patrick Walton <pcwalton@mozilla.com>
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
package org.mozilla.gecko.gfx; package org.mozilla.gecko.gfx;
import org.mozilla.gecko.gfx.CairoImage;
import android.graphics.Bitmap; import android.graphics.Bitmap;
import javax.microedition.khronos.opengles.GL10;
/** /**
* Utility methods useful when displaying Cairo bitmaps using OpenGL ES. * Utility methods useful when displaying Cairo bitmaps using OpenGL ES.
...@@ -49,13 +15,13 @@ public class CairoUtils { ...@@ -49,13 +15,13 @@ public class CairoUtils {
public static int bitsPerPixelForCairoFormat(int cairoFormat) { public static int bitsPerPixelForCairoFormat(int cairoFormat) {
switch (cairoFormat) { switch (cairoFormat) {
case CairoImage.FORMAT_A1: return 1; case CairoImage.FORMAT_A1: return 1;
case CairoImage.FORMAT_A8: return 8; case CairoImage.FORMAT_A8: return 8;
case CairoImage.FORMAT_RGB16_565: return 16; case CairoImage.FORMAT_RGB16_565: return 16;
case CairoImage.FORMAT_RGB24: return 24; case CairoImage.FORMAT_RGB24: return 24;
case CairoImage.FORMAT_ARGB32: return 32; case CairoImage.FORMAT_ARGB32: return 32;
default: default:
throw new RuntimeException("Unknown Cairo format"); throw new RuntimeException("Unknown Cairo format");
} }
} }
...@@ -64,21 +30,21 @@ public class CairoUtils { ...@@ -64,21 +30,21 @@ public class CairoUtils {
return CairoImage.FORMAT_ARGB32; /* Droid Pro fix. */ return CairoImage.FORMAT_ARGB32; /* Droid Pro fix. */
switch (config) { switch (config) {
case ALPHA_8: return CairoImage.FORMAT_A8; case ALPHA_8: return CairoImage.FORMAT_A8;
case ARGB_4444: throw new RuntimeException("ARGB_444 unsupported"); case ARGB_4444: throw new RuntimeException("ARGB_444 unsupported");
case ARGB_8888: return CairoImage.FORMAT_ARGB32; case ARGB_8888: return CairoImage.FORMAT_ARGB32;
case RGB_565: return CairoImage.FORMAT_RGB16_565; case RGB_565: return CairoImage.FORMAT_RGB16_565;
default: throw new RuntimeException("Unknown Skia bitmap config"); default: throw new RuntimeException("Unknown Skia bitmap config");
} }
} }
public static Bitmap.Config cairoFormatTobitmapConfig(int format) { public static Bitmap.Config cairoFormatTobitmapConfig(int format) {
switch (format) { switch (format) {
case CairoImage.FORMAT_A8: return Bitmap.Config.ALPHA_8; case CairoImage.FORMAT_A8: return Bitmap.Config.ALPHA_8;
case CairoImage.FORMAT_ARGB32: return Bitmap.Config.ARGB_8888; case CairoImage.FORMAT_ARGB32: return Bitmap.Config.ARGB_8888;
case CairoImage.FORMAT_RGB16_565: return Bitmap.Config.RGB_565; case CairoImage.FORMAT_RGB16_565: return Bitmap.Config.RGB_565;
default: default:
throw new RuntimeException("Unknown CairoImage format"); throw new RuntimeException("Unknown CairoImage format");
} }
} }
} }
......
/* -*- Mode: Java; c-basic-offset: 4; tab-width: 20; indent-tabs-mode: nil; -*- /* -*- Mode: Java; c-basic-offset: 4; tab-width: 20; indent-tabs-mode: nil; -*-
* ***** BEGIN LICENSE BLOCK ***** * This Source Code Form is subject to the terms of the Mozilla Public
* Version: MPL 1.1/GPL 2.0/LGPL 2.1 * License, v. 2.0. If a copy of the MPL was not distributed with this
* * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is Mozilla Android code.
*
* The Initial Developer of the Original Code is Mozilla Foundation.
* Portions created by the Initial Developer are Copyright (C) 2009-2010
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Patrick Walton <pcwalton@mozilla.com>
* Chris Lord <chrislord.net@gmail.com>
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
package org.mozilla.gecko.gfx; package org.mozilla.gecko.gfx;
import org.mozilla.gecko.util.FloatUtils;
import org.json.JSONException; import org.json.JSONException;
import org.json.JSONObject; import org.json.JSONObject;
import org.mozilla.gecko.util.FloatUtils;
public class FloatSize { public class FloatSize {
public final float width, height; public final float width, height;
public FloatSize(FloatSize size) { public FloatSize(FloatSize size) { width = size.width; height = size.height; }
width = size.width; public FloatSize(IntSize size) { width = size.width; height = size.height; }
height = size.height; public FloatSize(float aWidth, float aHeight) { width = aWidth; height = aHeight; }
}
public FloatSize(IntSize size) {
width = size.width;
height = size.height;
}
public FloatSize(float aWidth, float aHeight) {
width = aWidth;
height = aHeight;
}
public FloatSize(JSONObject json) { public FloatSize(JSONObject json) {
try { try {
width = (float) json.getDouble("width"); width = (float)json.getDouble("width");
height = (float) json.getDouble("height"); height = (float)json.getDouble("height");
} catch (JSONException e) { } catch (JSONException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }
} }
@Override @Override
public String toString() { public String toString() { return "(" + width + "," + height + ")"; }
return "(" + width + "," + height + ")";
}
public boolean isPositive() { public boolean isPositive() {
return (width > 0 && height > 0); return (width > 0 && height > 0);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment