mirror of
https://github.com/deepinsight/insightface.git
synced 2026-01-18 07:30:18 +00:00
72 lines
2.1 KiB
C++
72 lines
2.1 KiB
C++
/**
|
|
* Created by Jingyu Yan
|
|
* @date 2024-10-01
|
|
*/
|
|
|
|
#include <iostream>
|
|
#include "face_context.h"
|
|
#include "opencv2/opencv.hpp"
|
|
#include "sample/utils/test_helper.h"
|
|
|
|
using namespace inspire;
|
|
|
|
int main(int argc, char** argv) {
|
|
FaceContext ctx;
|
|
CustomPipelineParameter param;
|
|
param.enable_liveness = true;
|
|
param.enable_face_quality = true;
|
|
int32_t ret = ctx.Configuration("test_res/pack/Pikachu", DetectMode::DETECT_MODE_IMAGE, 1, param);
|
|
if (ret != 0) {
|
|
INSPIRE_LOGE("Initialization error");
|
|
return -1;
|
|
}
|
|
auto image = cv::imread("test_res/images/kun.jpg");
|
|
cv::Mat rot90;
|
|
TestUtils::rotate(image, rot90, ROTATION_90);
|
|
|
|
CameraStream stream;
|
|
stream.SetDataFormat(BGR);
|
|
stream.SetRotationMode(ROTATION_90);
|
|
stream.SetDataBuffer(rot90.data, rot90.rows, rot90.cols);
|
|
ctx.FaceDetectAndTrack(stream);
|
|
|
|
std::vector<HyperFaceData> faces;
|
|
for (int i = 0; i < ctx.GetNumberOfFacesCurrentlyDetected(); ++i) {
|
|
// const ByteArray &byteArray = ctx.GetDetectCache()[i];
|
|
HyperFaceData face = {0};
|
|
// ret = DeserializeHyperFaceData(byteArray, face);
|
|
|
|
const FaceBasicData& faceBasic = ctx.GetFaceBasicDataCache()[i];
|
|
ret = DeserializeHyperFaceData((char*)faceBasic.data, faceBasic.dataSize, face);
|
|
INSPIRE_LOGD("OK!");
|
|
|
|
if (ret != HSUCCEED) {
|
|
return -1;
|
|
}
|
|
faces.push_back(face);
|
|
|
|
cv::Rect rect(face.rect.x, face.rect.y, face.rect.width, face.rect.height);
|
|
std::cout << rect << std::endl;
|
|
cv::rectangle(rot90, rect, cv::Scalar(0, 0, 233), 2);
|
|
|
|
for (auto& p : face.keyPoints) {
|
|
cv::Point2f point(p.x, p.y);
|
|
cv::circle(rot90, point, 0, cv::Scalar(0, 0, 255), 5);
|
|
}
|
|
}
|
|
|
|
// cv::imshow("wq", rot90);
|
|
// cv::waitKey(0);
|
|
cv::imwrite("wq.png", rot90);
|
|
|
|
ret = ctx.FacesProcess(stream, faces, param);
|
|
if (ret != HSUCCEED) {
|
|
return -1;
|
|
}
|
|
|
|
// view
|
|
int32_t index = 0;
|
|
INSPIRE_LOGD("liveness: %f", ctx.GetRgbLivenessResultsCache()[index]);
|
|
|
|
return 0;
|
|
} |