Class ImageTracker
ImageTracker mendeteksi dan melacak kartu planar.
ImageTracker memakai buffer kamera (1 + SimultaneousNum). Gunakan setBufferCapacity kamera untuk mengatur tidak kurang dari jumlah buffer kamera yang dipakai semua komponen.
Setelah dibuat, panggil start/stop untuk mulai/berhenti beroperasi. Panggilan start/stop sangat ringan.
Saat tidak diperlukan lagi, panggil close untuk menutupnya. Jangan digunakan lagi setelah close.
ImageTracker menerima input melalui feedbackFrameSink FeedbackFrame. Hubungkan FeedbackFrameSource ke feedbackFrameSink untuk digunakan.
Sebelum Target dapat dilacak ImageTracker, muat dulu via loadTarget/unloadTarget. Hasil load/unload bisa didapat lewat callback antarmuka.
ImageTracker
Metode
isAvailable
bool easyar_ImageTracker_isAvailable(void)
static bool isAvailable()
public static boolean isAvailable()
companion object fun isAvailable(): Boolean
public static func isAvailable() -> Bool
public static bool isAvailable()
Mengembalikan
feedbackFrameSink
Port input FeedbackFrame. Anggota InputFrame dalam FeedbackFrame wajib memiliki gambar, timestamp, dan parameter kamera. Kamera mendukung model pinhole dan fisheye.
void easyar_ImageTracker_feedbackFrameSink(easyar_ImageTracker * This, easyar_FeedbackFrameSink * * Return)
std::shared_ptr<FeedbackFrameSink> feedbackFrameSink()
public @Nonnull FeedbackFrameSink feedbackFrameSink()
fun feedbackFrameSink(): FeedbackFrameSink
- (easyar_FeedbackFrameSink *)feedbackFrameSink
public func feedbackFrameSink() -> FeedbackFrameSink
public virtual FeedbackFrameSink feedbackFrameSink()
Mengembalikan
bufferRequirement
Jumlah buffer kamera yang ditempati oleh komponen saat ini.
int easyar_ImageTracker_bufferRequirement(easyar_ImageTracker * This)
public int bufferRequirement()
fun bufferRequirement(): Int
public func bufferRequirement() -> Int32
public virtual int bufferRequirement()
Mengembalikan
outputFrameSource
void easyar_ImageTracker_outputFrameSource(easyar_ImageTracker * This, easyar_OutputFrameSource * * Return)
std::shared_ptr<OutputFrameSource> outputFrameSource()
public @Nonnull OutputFrameSource outputFrameSource()
fun outputFrameSource(): OutputFrameSource
- (easyar_OutputFrameSource *)outputFrameSource
public func outputFrameSource() -> OutputFrameSource
public virtual OutputFrameSource outputFrameSource()
Mengembalikan
create
void easyar_ImageTracker_create(easyar_ImageTracker * * Return)
static std::shared_ptr<ImageTracker> create()
public static @Nonnull ImageTracker create()
companion object fun create(): ImageTracker
+ (easyar_ImageTracker *)create
public static func create() -> ImageTracker
public static ImageTracker create()
Mengembalikan
createWithMode
Dibuat dengan mode pelacakan spesifik. Di ponsel low-end, gunakan ImageTrackerMode.PreferPerformance untuk kinerja lebih baik walau pelacakan sedikit berkurang.
void easyar_ImageTracker_createWithMode(easyar_ImageTrackerMode trackMode, easyar_ImageTracker * * Return)
static std::shared_ptr<ImageTracker> createWithMode(ImageTrackerMode trackMode)
public static @Nonnull ImageTracker createWithMode(int trackMode)
companion object fun createWithMode(trackMode: Int): ImageTracker
+ (easyar_ImageTracker *)createWithMode:(easyar_ImageTrackerMode)trackMode
public static func createWithMode(_ trackMode: ImageTrackerMode) -> ImageTracker
public static ImageTracker createWithMode(ImageTrackerMode trackMode)
Parameter
Mengembalikan
createWithConfig
Dibuat dengan konfigurasi spesifik.
void easyar_ImageTracker_createWithConfig(easyar_ImageTrackerConfig * config, easyar_ImageTracker * * Return)
static std::shared_ptr<ImageTracker> createWithConfig(std::shared_ptr<ImageTrackerConfig> config)
public static @Nonnull ImageTracker createWithConfig(@Nonnull ImageTrackerConfig config)
companion object fun createWithConfig(config: ImageTrackerConfig): ImageTracker
+ (easyar_ImageTracker *)createWithConfig:(easyar_ImageTrackerConfig *)config
public static func createWithConfig(_ config: ImageTrackerConfig) -> ImageTracker
public static ImageTracker createWithConfig(ImageTrackerConfig config)
Parameter
Mengembalikan
setResultPostProcessing
Atur pemrosesan hasil.
enablePersistentTargetInstance default false. Saat diaktifkan, jika InputFrame mengandung info spasial, targetInstances di ImageTrackerResult akan mencakup semua instance terdeteksi (termasuk yang tidak sedang dilacak).
enableMotionFusion default false. Saat diaktifkan, jika InputFrame mengandung info waktu dan spasial, pose targetInstances di ImageTrackerResult akan diproses pakai RealTimeCoordinateTransform.
void easyar_ImageTracker_setResultPostProcessing(easyar_ImageTracker * This, bool enablePersistentTargetInstance, bool enableMotionFusion)
void setResultPostProcessing(bool enablePersistentTargetInstance, bool enableMotionFusion)
public void setResultPostProcessing(boolean enablePersistentTargetInstance, boolean enableMotionFusion)
fun setResultPostProcessing(enablePersistentTargetInstance: Boolean, enableMotionFusion: Boolean): Unit
- (void)setResultPostProcessing:(bool)enablePersistentTargetInstance enableMotionFusion:(bool)enableMotionFusion
public func setResultPostProcessing(_ enablePersistentTargetInstance: Bool, _ enableMotionFusion: Bool) -> Void
public virtual void setResultPostProcessing(bool enablePersistentTargetInstance, bool enableMotionFusion)
Parameter
| Nama |
Tipe |
Deskripsi |
| enablePersistentTargetInstance |
Boolean |
|
| enableMotionFusion |
Boolean |
|
Mengembalikan
setResultAsyncMode
Mengatur mode hasil asinkron. Jika hasil dikeluarkan melalui outputFrameSource, atur ke true; jika hasil diperoleh melalui getSyncResult, atur ke false. Secara default enableAsync adalah true. Mode sinkron hanya berlaku jika bingkai input berisi informasi spasial dan menggunakan Lisensi XR.
bool easyar_ImageTracker_setResultAsyncMode(easyar_ImageTracker * This, bool enableAsync)
bool setResultAsyncMode(bool enableAsync)
public boolean setResultAsyncMode(boolean enableAsync)
fun setResultAsyncMode(enableAsync: Boolean): Boolean
- (bool)setResultAsyncMode:(bool)enableAsync
public func setResultAsyncMode(_ enableAsync: Bool) -> Bool
public virtual bool setResultAsyncMode(bool enableAsync)
Parameter
| Nama |
Tipe |
Deskripsi |
| enableAsync |
Boolean |
|
Mengembalikan
start
Memulai algoritma pelacakan.
bool easyar_ImageTracker_start(easyar_ImageTracker * This)
public func start() -> Bool
public virtual bool start()
Mengembalikan
stop
Menjeda algoritma pelacakan. Panggil start untuk memulai ulang pelacakan.
void easyar_ImageTracker_stop(easyar_ImageTracker * This)
public func stop() -> Void
public virtual void stop()
Mengembalikan
close
Tutup. Tidak boleh digunakan lagi setelah ditutup.
void easyar_ImageTracker_close(easyar_ImageTracker * This)
public func close() -> Void
public virtual void close()
Mengembalikan
loadTarget
Memuat satu Target ke dalam tracker. Target hanya dapat dikenali dan dilacak setelah berhasil dimuat ke tracker.
Metode ini asinkron. Proses pemuatan mungkin memerlukan waktu. Selama ini, deteksi target baru/hilang mungkin lebih lama dari biasa, tetapi pelacakan setelah deteksi tidak terpengaruh. Untuk mengetahui hasil pemuatan, proses data callback. Callback akan dipanggil pada thread yang ditentukan CallbackScheduler. Thread pelacakan dan operasi lain (selain load/unload) tidak akan terblokir.
void easyar_ImageTracker_loadTarget(easyar_ImageTracker * This, easyar_Target * target, easyar_CallbackScheduler * callbackScheduler, easyar_FunctorOfVoidFromTargetAndBool callback)
void loadTarget(std::shared_ptr<Target> target, std::shared_ptr<CallbackScheduler> callbackScheduler, std::function<void(std::shared_ptr<Target>, bool)> callback)
public void loadTarget(@Nonnull Target target, @Nonnull CallbackScheduler callbackScheduler, @Nonnull FunctorOfVoidFromTargetAndBool callback)
fun loadTarget(target: Target, callbackScheduler: CallbackScheduler, callback: FunctorOfVoidFromTargetAndBool): Unit
- (void)loadTarget:(easyar_Target *)target callbackScheduler:(easyar_CallbackScheduler *)callbackScheduler callback:(void (^)(easyar_Target * target, bool status))callback
public func loadTarget(_ target: Target, _ callbackScheduler: CallbackScheduler, _ callback: @escaping (Target, Bool) -> Void) -> Void
public virtual void loadTarget(Target target, CallbackScheduler callbackScheduler, Action<Target, bool> callback)
Parameter
Mengembalikan
unloadTarget
Membongkar Target dari tracker.
Metode ini asinkron. Proses pembongkaran mungkin memerlukan waktu. Selama ini, deteksi target baru/hilang mungkin lebih lama dari biasa, tetapi pelacakan setelah deteksi tidak terpengaruh. Untuk mengetahui hasil pembongkaran, proses data callback. Callback akan dipanggil pada thread yang ditentukan CallbackScheduler. Thread pelacakan dan operasi lain (selain load/unload) tidak akan terblokir.
void easyar_ImageTracker_unloadTarget(easyar_ImageTracker * This, easyar_Target * target, easyar_CallbackScheduler * callbackScheduler, easyar_FunctorOfVoidFromTargetAndBool callback)
void unloadTarget(std::shared_ptr<Target> target, std::shared_ptr<CallbackScheduler> callbackScheduler, std::function<void(std::shared_ptr<Target>, bool)> callback)
public void unloadTarget(@Nonnull Target target, @Nonnull CallbackScheduler callbackScheduler, @Nonnull FunctorOfVoidFromTargetAndBool callback)
fun unloadTarget(target: Target, callbackScheduler: CallbackScheduler, callback: FunctorOfVoidFromTargetAndBool): Unit
- (void)unloadTarget:(easyar_Target *)target callbackScheduler:(easyar_CallbackScheduler *)callbackScheduler callback:(void (^)(easyar_Target * target, bool status))callback
public func unloadTarget(_ target: Target, _ callbackScheduler: CallbackScheduler, _ callback: @escaping (Target, Bool) -> Void) -> Void
public virtual void unloadTarget(Target target, CallbackScheduler callbackScheduler, Action<Target, bool> callback)
Parameter
Mengembalikan
targets
Mengembalikan target yang saat ini telah dimuat ke dalam tracker. Jika load/unload asinkron sedang berjalan, nilai kembalian sebelum selesai tidak akan mencerminkan hasilnya.
void easyar_ImageTracker_targets(const easyar_ImageTracker * This, easyar_ListOfTarget * * Return)
std::vector<std::shared_ptr<Target>> targets()
public java.util.@Nonnull ArrayList<@Nonnull Target> targets()
fun targets(): ArrayList<Target>
- (NSArray<easyar_Target *> *)targets
public func targets() -> [Target]
public virtual List<Target> targets()
Mengembalikan
setSimultaneousNum
Mengatur jumlah target maksimum yang dapat dilacak oleh tracker. Nilai default adalah 1.
bool easyar_ImageTracker_setSimultaneousNum(easyar_ImageTracker * This, int num)
bool setSimultaneousNum(int num)
public boolean setSimultaneousNum(int num)
fun setSimultaneousNum(num: Int): Boolean
- (bool)setSimultaneousNum:(int)num
public func setSimultaneousNum(_ num: Int32) -> Bool
public virtual bool setSimultaneousNum(int num)
Parameter
| Nama |
Tipe |
Deskripsi |
| num |
Int32 |
|
Mengembalikan
simultaneousNum
Mendapatkan jumlah target maksimum yang dapat dilacak oleh tracker. Nilai default adalah 1.
int easyar_ImageTracker_simultaneousNum(const easyar_ImageTracker * This)
public int simultaneousNum()
fun simultaneousNum(): Int
public func simultaneousNum() -> Int32
public virtual int simultaneousNum()
Mengembalikan
getSyncResult
Dapatkan hasil output sinkron. Jika ImageTracker dijeda, atau mode hasil asinkron belum disetel false via setResultAsyncMode, kembalian akan kosong.
void easyar_ImageTracker_getSyncResult(easyar_ImageTracker * This, easyar_MotionInputData * motionInputData, easyar_OptionalOfImageTrackerResult * Return)
std::optional<std::shared_ptr<ImageTrackerResult>> getSyncResult(std::shared_ptr<MotionInputData> motionInputData)
public @Nullable ImageTrackerResult getSyncResult(@Nonnull MotionInputData motionInputData)
fun getSyncResult(motionInputData: MotionInputData): ImageTrackerResult?
- (easyar_ImageTrackerResult *)getSyncResult:(easyar_MotionInputData *)motionInputData
public func getSyncResult(_ motionInputData: MotionInputData) -> ImageTrackerResult?
public virtual Optional<ImageTrackerResult> getSyncResult(MotionInputData motionInputData)
Parameter
Mengembalikan