/** * <p> * Converts an {@link boofcv.struct.image.GrayF64} into a {@link boofcv.struct.image.GrayS8}. * </p> * * @param input Input image which is being converted. Not modified. * @param output (Optional) The output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 convert(GrayF64 input, GrayS8 output) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertImage.convert(input, output); return output; }
/** * Converts a {@link Planar} into a {@link ImageGray} by computing the average value of each pixel * across all the bands. * * @param input Input Planar image that is being converted. Not modified. * @param output (Optional) The single band output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 average( Planar<GrayS8> input , GrayS8 output ) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertPlanarToGray.average(input, output); return output; }
/** * Converts a {@link InterleavedS8} into a {@link GrayS8} by computing the average value of each pixel * across all the bands. * * @param input (Input) The ImageInterleaved that is being converted. Not modified. * @param output (Optional) The single band output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 average( InterleavedS8 input , GrayS8 output ) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ConvertInterleavedToSingle.average(input, output); return output; }
/** * <p> * Converts an {@link boofcv.struct.image.GrayS32} into a {@link boofcv.struct.image.GrayS8}. * </p> * * @param input Input image which is being converted. Not modified. * @param output (Optional) The output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 convert(GrayS32 input, GrayS8 output) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertImage.convert(input, output); return output; }
/** * <p> * Converts an {@link boofcv.struct.image.GrayF32} into a {@link boofcv.struct.image.GrayS8}. * </p> * * @param input Input image which is being converted. Not modified. * @param output (Optional) The output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 convert(GrayF32 input, GrayS8 output) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertImage.convert(input, output); return output; }
/** * <p> * Converts an {@link boofcv.struct.image.GrayU8} into a {@link boofcv.struct.image.GrayS8}. * </p> * * @param input Input image which is being converted. Not modified. * @param output (Optional) The output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 convert(GrayU8 input, GrayS8 output) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertImage.convert(input, output); return output; }
/** * <p> * Converts an {@link boofcv.struct.image.GrayU16} into a {@link boofcv.struct.image.GrayS8}. * </p> * * @param input Input image which is being converted. Not modified. * @param output (Optional) The output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 convert(GrayU16 input, GrayS8 output) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertImage.convert(input, output); return output; }
/** * <p> * Converts an {@link boofcv.struct.image.GrayS16} into a {@link boofcv.struct.image.GrayS8}. * </p> * * @param input Input image which is being converted. Not modified. * @param output (Optional) The output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 convert(GrayS16 input, GrayS8 output) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertImage.convert(input, output); return output; }
/** * <p> * Converts an {@link boofcv.struct.image.GrayS64} into a {@link boofcv.struct.image.GrayS8}. * </p> * * @param input Input image which is being converted. Not modified. * @param output (Optional) The output image. If null a new image is created. Modified. * @return Converted image. */ public static GrayS8 convert(GrayS64 input, GrayS8 output) { if (output == null) { output = new GrayS8(input.width, input.height); } else { output.reshape(input.width,input.height); } ImplConvertImage.convert(input, output); return output; }
public static <T extends ImageGray<T>> T create(Class<T> type , int width , int height ) { if( type == GrayU8.class) { return (T)new GrayU8(width,height); } else if( type == GrayS8.class) { return (T)new GrayS8(width,height); } else if( type == GrayU16.class) { return (T)new GrayU16(width,height); } else if( type == GrayS16.class) { return (T)new GrayS16(width,height); } else if( type == GrayS32.class) { return (T)new GrayS32(width,height); } else if( type == GrayF32.class) { return (T)new GrayF32(width,height); } else{ throw new IllegalArgumentException("Unknown image type: "+type); } } }
public static <T extends ImageGray<T>> T createSingleBand(Class<T> type, int width, int height) { type = BoofTesting.convertGenericToSpecificType(type); if (type == GrayU8.class) { return (T)new GrayU8(width, height); } else if (type == GrayS8.class) { return (T)new GrayS8(width, height); } else if (type == GrayS16.class) { return (T)new GrayS16(width, height); } else if (type == GrayU16.class) { return (T)new GrayU16(width, height); } else if (type == GrayS32.class) { return (T)new GrayS32(width, height); } else if (type == GrayS64.class) { return (T)new GrayS64(width, height); } else if (type == GrayF32.class) { return (T)new GrayF32(width, height); } else if (type == GrayF64.class) { return (T)new GrayF64(width, height); } else if( (Class)type == GrayI.class ) { // ImageInteger is a generic type, so just create something return (T)new GrayS32(width,height); } throw new RuntimeException("Unknown type: "+type.getSimpleName()); }
GrayF32 suppressed = new GrayF32(input.width,input.height); GrayF32 orientation = new GrayF32(input.width,input.height); GrayS8 direction = new GrayS8(input.width,input.height); GrayU8 detected = new GrayU8(input.width,input.height);
GrayF32 orientation = new GrayF32(inputF32.width,inputF32.height); GrayF32 suppressed = new GrayF32(inputF32.width,inputF32.height); GrayS8 direction = new GrayS8(inputF32.width,inputF32.height); GrayU8 output = new GrayU8(inputF32.width,inputF32.height);