#include <RVC/RVC.h>
#include <cstring>
#include <iostream>
#include <vector>
#include "IO/FileIO.h"
#include "IO/SavePointMap.h"
const unsigned int pm_sz = pm.
GetSize().cols * pm.
GetSize().rows, len =
sizeof(double) * 3;
std::vector<double> valid_xyzs(pm_sz * 3);
double *valid_data = valid_xyzs.data();
double valid_num = 0;
for (int i = 0; i < pm_sz; i++, pm_data += 3) {
if (pm_data[2] == pm_data[2]) {
memcpy(valid_data, pm_data, len);
valid_data += 3;
valid_num++;
}
}
valid_xyzs.resize(valid_num * 3);
return valid_xyzs;
}
int main(int argc, char **argv) {
size_t actual_size = 0;
SystemListDevices(devices, 10, &actual_size, RVC::SystemListDeviceType::All);
if (actual_size == 0) {
std::cout << "Can not find any RVC Camera!" << std::endl;
return -1;
}
if(devices[0].IsFirmwareMatch() == false){
std::cout << "device firmware mismatch, Please use RVCManager to upgrade the firmware" << std::endl;
return -1;
}
std::cout << "Failed to open camera! Please check whether the camera is connected and make sure it is not occupied and supports X1." << std::endl;
return 1;
}
const std::string save_directory = "./Data/";
MakeDirectories(save_directory);
std::cout << "RVC Camera capture successed!" << std::endl;
std::vector<double> valid_xyzs = ExtractValidPoint(pm);
std::string pm_addr = save_directory + "test.ply";
std::cout << "save point map to file: " << pm_addr << std::endl;
SavePlyFile(pm_addr.c_str(), valid_xyzs.data(), valid_xyzs.size() / 3);
} else {
std::cout << "RVC Camera capture failed!" << std::endl;
}
return 0;
}