image_manip_warp_mesh.cpp
Go to the documentation of this file.
1 #include <iostream>
2 
3 // Inludes common necessary includes for development using depthai library
4 #include "depthai/depthai.hpp"
5 
6 int main() {
7  using namespace std;
8 
9  // Create pipeline
10  dai::Pipeline pipeline;
11 
12  auto camRgb = pipeline.create<dai::node::ColorCamera>();
13  camRgb->setPreviewSize(500, 500);
14  camRgb->setInterleaved(false);
15  auto maxFrameSize = camRgb->getPreviewWidth() * camRgb->getPreviewHeight() * 3;
16 
17  // Warp preview frame 1
18  auto manip1 = pipeline.create<dai::node::ImageManip>();
19  // Create a custom warp mesh
20  dai::Point2f tl(20, 20);
21  dai::Point2f tr(460, 20);
22  dai::Point2f ml(100, 250);
23  dai::Point2f mr(400, 250);
24  dai::Point2f bl(20, 460);
25  dai::Point2f br(460, 460);
26  manip1->setWarpMesh({tl, tr, ml, mr, bl, br}, 2, 3);
27  manip1->setMaxOutputFrameSize(maxFrameSize);
28 
29  camRgb->preview.link(manip1->inputImage);
30  auto xout1 = pipeline.create<dai::node::XLinkOut>();
31  xout1->setStreamName("out1");
32  manip1->out.link(xout1->input);
33 
34  // Warp preview frame 2
35  auto manip2 = pipeline.create<dai::node::ImageManip>();
36  // Create a custom warp mesh
37  // clang-format off
38  std::vector<dai::Point2f> mesh2 = {
39  {20, 20}, {250, 100}, {460, 20},
40  {100,250}, {250, 250}, {400, 250},
41  {20, 480}, {250,400}, {460,480}
42  };
43  // clang-format on
44  manip2->setWarpMesh(mesh2, 3, 3);
45  manip2->setMaxOutputFrameSize(maxFrameSize);
46 
47  camRgb->preview.link(manip2->inputImage);
48  auto xout2 = pipeline.create<dai::node::XLinkOut>();
49  xout2->setStreamName("out2");
50  manip2->out.link(xout2->input);
51 
52  dai::Device device(pipeline);
53  auto q1 = device.getOutputQueue("out1", 8, false);
54  auto q2 = device.getOutputQueue("out2", 8, false);
55  while(true) {
56  auto in1 = q1->get<dai::ImgFrame>();
57  if(in1) {
58  cv::imshow("Warped preview 1", in1->getCvFrame());
59  }
60  auto in2 = q2->get<dai::ImgFrame>();
61  if(in2) {
62  cv::imshow("Warped preview 2", in2->getCvFrame());
63  }
64  int key = cv::waitKey(1);
65  if(key == 'q' || key == 'Q') return 0;
66  }
67  return 0;
68 }
dai::node::XLinkOut
XLinkOut node. Sends messages over XLink.
Definition: XLinkOut.hpp:14
dai::Pipeline
Represents the pipeline, set of nodes and connections between them.
Definition: Pipeline.hpp:100
tl
Definition: 3rdparty/tl/optional.hpp:106
dai::node::ColorCamera
ColorCamera node. For use with color sensors.
Definition: ColorCamera.hpp:16
dai::Point2f
Definition: Point2f.hpp:16
main
int main()
Definition: image_manip_warp_mesh.cpp:6
dai::Device::getOutputQueue
std::shared_ptr< DataOutputQueue > getOutputQueue(const std::string &name)
Definition: Device.cpp:86
depthai.hpp
dai::node::ImageManip::setWarpMesh
void setWarpMesh(const float *meshData, int numMeshPoints, int width, int height)
Definition: ImageManip.cpp:72
dai::Pipeline::create
std::shared_ptr< N > create()
Definition: Pipeline.hpp:145
dai::ImgFrame
Definition: ImgFrame.hpp:25
dai::node::ImageManip
ImageManip node. Capability to crop, resize, warp, ... incoming image frames.
Definition: ImageManip.hpp:15
dai::Device
Definition: Device.hpp:21
std
Definition: Node.hpp:366
dai::node::ColorCamera::setPreviewSize
void setPreviewSize(int width, int height)
Set preview output size.
Definition: ColorCamera.cpp:121
dai::node::XLinkOut::setStreamName
void setStreamName(const std::string &name)
Definition: XLinkOut.cpp:13


depthai
Author(s): Martin Peterlin
autogenerated on Sat Mar 22 2025 02:58:19