boofcv.struct.image.InterleavedI16 Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of boofcv-ip Show documentation
Show all versions of boofcv-ip Show documentation
BoofCV is an open source Java library for real-time computer vision and robotics applications.
/*
* Copyright (c) 2011-2017, Peter Abeles. All Rights Reserved.
*
* This file is part of BoofCV (http://boofcv.org).
*
* 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 boofcv.struct.image;
/**
*
* {@link boofcv.struct.image.ImageInterleaved} for data of type short.
*
*
* @author Peter Abeles
*/
public abstract class InterleavedI16> extends InterleavedInteger {
public short data[];
/**
* Creates a new image with an arbitrary number of bands/colors.
*
* @param width number of columns in the image.
* @param height number of rows in the image.
* @param numBands number of bands/colors in the image.
*/
public InterleavedI16(int width, int height, int numBands) {
super(width, height, numBands);
}
public InterleavedI16() {
}
@Override
public String toString_element(int index) {
return String.format("%04x",data[index]&0xFFFF);
}
@Override
public ImageDataType getDataType() {
return ImageDataType.I16;
}
/**
* Returns the pixel's value for all the bands as an array.
*
* @param x pixel coordinate.
* @param y pixel coordinate.
* @param storage If not null then the pixel's value is written here. If null a new array is created.
* @return The pixel's value.
*/
public short[] get(int x, int y, short[] storage) {
if (!isInBounds(x, y))
throw new ImageAccessException("Requested pixel is out of bounds");
if (storage == null) {
storage = new short[numBands];
}
int index = getIndex(x, y, 0);
for (int i = 0; i < numBands; i++, index++) {
storage[i] = data[index];
}
return storage;
}
/**
* Sets the pixel's value for all the bands using an array.
*
* @param x pixel coordinate.
* @param y pixel coordinate.
* @param value The pixel's new value for each band.
*/
public void set(int x, int y, short... value) {
if (!isInBounds(x, y))
throw new ImageAccessException("Requested pixel is out of bounds");
int index = getIndex(x, y, 0);
for (int i = 0; i < numBands; i++, index++) {
data[index] = value[i];
}
}
/**
* Returns the value of the specified band in the specified pixel.
*
* @param x pixel coordinate.
* @param y pixel coordinate.
* @param band which color band in the pixel
* @param value The new value of the element.
*/
public void setBand(int x, int y, int band, short value) {
if (!isInBounds(x, y))
throw new ImageAccessException("Requested pixel is out of bounds.");
if (band < 0 || band >= numBands)
throw new ImageAccessException("Invalid band requested.");
data[getIndex(x, y, band)] = value;
}
@Override
public void unsafe_set(int x, int y, int... value) {
int index = getIndex(x, y, 0);
for (int i = 0; i < numBands; i++, index++) {
data[index] = (short)value[i];
}
}
@Override
public void setBand(int x, int y, int band, int value) {
if (!isInBounds(x, y))
throw new ImageAccessException("Requested pixel is out of bounds.");
if (band < 0 || band >= numBands)
throw new ImageAccessException("Invalid band requested.");
data[getIndex(x, y, band)] = (short)value;
}
@Override
protected Object _getData() {
return data;
}
@Override
protected Class getPrimitiveDataType() {
return short.class;
}
@Override
protected void _setData(Object data) {
this.data = (short[]) data;
}
}