Image Class¶
Description¶
Image stores an image data and represents an image in memory.
Image raw data can be accessed as byte array. The width/height/etc information are also accessible.
You can always access image data since the first version of EasyAR Sense.
You can do this in iOS
#import <easyar/buffer.oc.h>
#import <easyar/image.oc.h>
easyar_OutputFrame * outputFrame = [outputFrameBuffer peek];
if (outputFrame != nil) {
easyar_Image * i = [[outputFrame inputFrame] image];
easyar_Buffer * b = [i buffer];
char * bytes = calloc([b size], 1);
memcpy(bytes, [b data], [b size]);
// use bytes here
free(bytes);
}
Or in Android
import cn.easyar.*;
OutputFrame outputFrame = outputFrameBuffer.peek();
if (outputFrame != null) {
InputFrame inputFrame = outputFrame.inputFrame();
Image i = inputFrame.image();
Buffer b = i.buffer();
byte[] bytes = new byte[b.size()];
b.copyToByteArray(0, bytes, 0, bytes.length);
// use bytes here
b.dispose();
i.dispose();
inputFrame.dispose();
outputFrame.dispose();
}
Constructor¶
- C
void easyar_Image__ctor(easyar_Buffer * buffer, easyar_PixelFormat format, int width, int height, easyar_Image * * Return)
- C++
Image(std::shared_ptr<Buffer> buffer, PixelFormat format, int width, int height)
- Java
public Image(@Nonnull Buffer buffer, int format, int width, int height)
- Kotlin
constructor(buffer: Buffer, format: Int, width: Int, height: Int)
- Objective-C
+ (easyar_Image *) create:(easyar_Buffer *)buffer format:(easyar_PixelFormat)format width:(int)width height:(int)height
- Swift
public convenience init(_ buffer: Buffer, _ format: PixelFormat, _ width: Int32, _ height: Int32)
- C#
public Image(Buffer buffer, PixelFormat format, int width, int height)
buffer¶
Returns buffer inside image. It can be used to access internal data of image. The content of Buffer shall not be modified, as they may be accessed from other threads.
format¶
Returns image format.
- C
easyar_PixelFormat easyar_Image_format(const easyar_Image * This)
- C++
PixelFormat format()
- Java
public int format()
- Kotlin
fun format(): Int
- Objective-C
- (easyar_PixelFormat)format
- Swift
public func format() -> PixelFormat
- C#
public virtual PixelFormat format()
width¶
Returns image width. There is a padding of (pixelWidth - width) pixels at the right side of the image.
- C
int easyar_Image_width(const easyar_Image * This)
- C++
int width()
- Java
public int width()
- Kotlin
fun width(): Int
- Objective-C
- (int)width
- Swift
public func width() -> Int32
- C#
public virtual int width()
height¶
Returns image height. There is a padding of (pixelHeight - height) pixels at the bottom of the image.
- C
int easyar_Image_height(const easyar_Image * This)
- C++
int height()
- Java
public int height()
- Kotlin
fun height(): Int
- Objective-C
- (int)height
- Swift
public func height() -> Int32
- C#
public virtual int height()
pixelWidth¶
Returns image pixel width for encoding.
- C
int easyar_Image_pixelWidth(const easyar_Image * This)
- C++
int pixelWidth()
- Java
public int pixelWidth()
- Kotlin
fun pixelWidth(): Int
- Objective-C
- (int)pixelWidth
- Swift
public func pixelWidth() -> Int32
- C#
public virtual int pixelWidth()
pixelHeight¶
Returns image pixel height for encoding.
- C
int easyar_Image_pixelHeight(const easyar_Image * This)
- C++
int pixelHeight()
- Java
public int pixelHeight()
- Kotlin
fun pixelHeight(): Int
- Objective-C
- (int)pixelHeight
- Swift
public func pixelHeight() -> Int32
- C#
public virtual int pixelHeight()
create¶
- C
void easyar_Image_create(easyar_Buffer * buffer, easyar_PixelFormat format, int width, int height, int pixelWidth, int pixelHeight, easyar_Image * * Return)
- C++
static std::shared_ptr<Image> create(std::shared_ptr<Buffer> buffer, PixelFormat format, int width, int height, int pixelWidth, int pixelHeight)
- Java
public static @Nonnull Image create(@Nonnull Buffer buffer, int format, int width, int height, int pixelWidth, int pixelHeight)
- Kotlin
companion object fun create(buffer: Buffer, format: Int, width: Int, height: Int, pixelWidth: Int, pixelHeight: Int): Image
- Objective-C
+ (easyar_Image *)create:(easyar_Buffer *)buffer format:(easyar_PixelFormat)format width:(int)width height:(int)height pixelWidth:(int)pixelWidth pixelHeight:(int)pixelHeight
- Swift
public static func create(_ buffer: Buffer, _ format: PixelFormat, _ width: Int32, _ height: Int32, _ pixelWidth: Int32, _ pixelHeight: Int32) -> Image
- C#
public static Image create(Buffer buffer, PixelFormat format, int width, int height, int pixelWidth, int pixelHeight)