基于opencv读入彩色视频并以灰度格式输出

本文介绍了一个使用OpenCV实现视频从笛卡尔坐标系到极坐标系转换的示例代码。该程序读取一个视频文件,将其每一帧转换为极坐标形式,并保存为新的视频文件。此外,还展示了如何实时显示转换后的视频帧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <cv.h>
#include <highgui.h>
int main(int argc, char **argv)
{
CvCapture* capture = NULL;
capture = cvCreateFileCapture("big_2.avi");
if (!capture) return -1;
//获取视频的第一帧 并存在bgr_frame
IplImage *bgr_frame = cvQueryFrame(capture);
//获得视频的总帧数 CV_CAP_PROP_FPS 帧率
double fps = cvGetCaptureProperty(capture, CV_CAP_PROP_FPS);
//获得原始视频的高度和宽度
CvSize size = cvSize((int)cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_WIDTH),
(int)cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_HEIGHT));
///创建一个视频文件参数分别表示  新建视频的名称 视频压缩的编码格式 新建视频的帧率 新建视频的图像大小
CvVideoWriter *writer = cvCreateVideoWriter("big_out.avi", CV_FOURCC('M', 'J', 'P', 'G'), fps, size);
//创建首地址 并分配存储空间
IplImage* logpolar_frame = cvCreateImage(size, IPL_DEPTH_8U, 3);
// 获取视频的下一帧
while ((bgr_frame = cvQueryFrame(capture)) != NULL)
{
//将视频从笛卡尔坐标系转到极坐标系 参数分别表示 输入图像 输出图像 变换中心 尺度参数 填充输出图像所有参数 + CV_INTER_LINEAR 表示双线性参值(具体什么意思)
cvLogPolar(bgr_frame, logpolar_frame, cvPoint2D32f(bgr_frame->width / 2, bgr_frame->height / 2), 80, CV_INTER_LINEAR + CV_WARP_FILL_OUTLIERS);
//将获取到的每一帧从笛卡尔坐标系转到极坐标系后的参数 存到新建的视频文件
cvWriteFrame(writer, logpolar_frame);
//将获取的视频通过mainwin窗口进行展示
cvShowImage("mainwin", logpolar_frame);
char c = cvWaitKey(33);
//ESC 默认退出
if (c == 27) break;
}
//释放程序中申请的空间
cvReleaseVideoWriter(&writer);
cvReleaseImage(&logpolar_frame);
cvReleaseCapture(&capture);
return(0);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值