【OpenCV教程】Trackbar到底怎么用?

[复制链接]
发表于 2026-1-10 16:18:34 | 显示全部楼层 |阅读模式
@
目次

1.createTrackbar创建滚动条

1.1 API
  1. CV_EXPORTS int createTrackbar(const String& trackbarname, const String& winname,
  2.                               int* value, int count,
  3.                               TrackbarCallback onChange = 0,
  4.                               void* userdata = 0);
复制代码

  • 参数如下
参数寄义trackbarname滚动条名字winname(window name)窗体名字。要先用nameWindow创建好同名窗体,滚动条才会出现value欲控制的变量的地点count欲控制的变量的最大值(最小为0)onChange回调函数,默以为空。假如想要传入,那么其参数是固定的userdata万能指针,默以为空。假如想要传入,通常用一个类的对象的地点。作为可利用的数据库,用来给回调函数提供变量支持
  1. void onChange(int,void*);
复制代码
2.getTrackbarPos得到滚动条当前的值
  1. CV_EXPORTS_W int getTrackbarPos(const String& trackbarname, const String& winname);
复制代码

  • 参数如下
参数寄义trackbarname滚动条名字winname(window name)窗体名字3.利用方式一(recommended)

3.1 原理

不利用createTrackbar函数的参数value、onChange、userdata参数。通过while(1)的无穷循环,在循环中不停地用getTrackbarPos函数动态地获取滚动条的值,然后在循环内部用这些值举行操纵。
3.2 结果
  1. Mat xuenai = imread("xuenai.jpg");
  2. imshow("xuenai",xuenai);
  3. namedWindow("xuenai_rotate");
  4. Mat xuenai_rotate(xuenai.size(), xuenai.type());
  5. createTrackbar("angle","xuenai_rotate", nullptr,360);
  6. while (1) {
  7.     int angle= getTrackbarPos("angle","xuenai_rotate");
  8.     Mat M = getRotationMatrix2D(Point2f(xuenai.cols / 2, xuenai.rows / 2), angle, 1);
  9.     warpAffine(xuenai, xuenai_rotate, M, xuenai.size());
  10.     imshow("xuenai_rotate",xuenai_rotate);
  11.     waitKey(20);
  12. }
复制代码


4.利用方式二

4.1 原理

不利用getTrackbarPos函数,利用createTrackbar的全部参数,在onChange回调函数中完成全部操纵,由于回调函数的参数表是固定的,因此必要userdata传入所需数据。在每次移动滚动条时,相称于调用了一次回调函数,就完成了操纵。末端没有waitKey(0)就表现不了多久。
4.2 结果
  1. class TrackbarUserdata{
  2. public:
  3.     Mat input;
  4.     Mat output;
  5.     int angle=0;
  6.     string winname;
  7. };
  8. void RotateonChange(int,void *userdata) {
  9.     TrackbarUserdata *data = (TrackbarUserdata *) userdata;
  10.     int rows = data->input.rows;
  11.     int cols = data->output.cols;
  12.     Mat M = getRotationMatrix2D(Point2f(rows / 2, cols / 2), data->angle, 1);
  13.     warpAffine(data->input,data->output,M,data->input.size());
  14.     imshow(data->winname,data->output);
  15.     waitKey(10);
  16. }
  17. int main(){
  18.     Mat xuenai = imread("xuenai.jpg");
  19.     imshow("xuenai",xuenai);
  20.     Mat xuenai_rotate(xuenai.size(), xuenai.type());
  21.   
  22.     TrackbarUserdata userdata;
  23.     userdata.input=xuenai;
  24.     userdata.output=xuenai_rotate;
  25.     userdata.winname="xuenai_rotate";
  26.     namedWindow(userdata.winname);
  27.     createTrackbar("angle",userdata.winname, &userdata.angle,360, RotateonChange,&userdata);
  28.     waitKey();
  29.   
  30.     return 0;
  31. }
复制代码



免责声明:如果侵犯了您的权益,请联系站长及时删除侵权内容,谢谢合作!qidao123.com:ToB企服之家,中国第一个企服评测及软件市场,开放入驻,技术点评得现金.

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
回复

使用道具 举报

登录后关闭弹窗

登录参与点评抽奖  加入IT实名职场社区
去登录
快速回复 返回顶部 返回列表