#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);
}
#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);
}