com.google.gwt.canvas.dom.client.CanvasPixelArray.java Source code

Java tutorial

Introduction

Here is the source code for com.google.gwt.canvas.dom.client.CanvasPixelArray.java

Source

/*
 * Copyright 2010 Google Inc.
 * 
 * Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.google.gwt.canvas.dom.client;

import com.google.gwt.core.client.JavaScriptObject;

/**
 * Array-like object holding the actual image data for an ImageData object. For
 * each pixel, this object contains a red, green, blue and alpha value between 0
 * and 255 (in this order). Note that we use ints here to represent the data to
 * avoid complexities stemming from bytes being signed in Java.
 *
 * @see <a href="http://www.w3.org/TR/2dcontext/#canvaspixelarray">HTML Canvas
 *      2D CanvasPixelArray</a>
 */
public class CanvasPixelArray extends JavaScriptObject {

    protected CanvasPixelArray() {
    }

    /**
     * Returns the data value at index i.
     *
     * @param i the data index
     * @return the data value
     */
    public final native int get(int i) /*-{
                                       return this[i] || 0;
                                       }-*/;

    /**
     * Returns the length of the array.
     *
     * @return the array length
     */
    public final native int getLength() /*-{
                                        return this.length;
                                        }-*/;

    /**
     * Sets the data value at position i to the given value.
     *
     * Most browsers will clamp this value to the range 0...255, but that is not
     * enforced in this implementation.
     *
     * @param i index to set.
     * @param value value to set (use values from 0 to 255)
     */
    public final native void set(int i, int value) /*-{
                                                   // FF3.0 doesn't clamp the range. We don't manually clamp it to maximize 
                                                   // performance.
                                                   this[i] = value;
                                                   }-*/;
}