[opencv]重写视频以及logpolar变换
来源:互联网 发布:加密狗写入软件 编辑:程序博客网 时间:2024/05/21 06:13
一直以为视频的处理挺难的,但是发现写入在opencv里是最简单的最基础的,这个例子挺好玩的,嘿嘿,扭曲,虽然公式不懂~>-<~但是挺好玩的~
LogPolar
把图像映射到极指数空间
void cvLogPolar( const CvArr* src, CvArr* dst, CvPoint2D32f center, double M, int flags=CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS );
- src
- 输入图像。
- dst
- 输出图像。
- center
- 变换的中心,输出图像在这里最精确。
- M
- 幅度的尺度参数,见下面公式。
- flags
- 插值方法和以下选择标志的结合
- CV_WARP_FILL_OUTLIERS -填充输出图像所有像素,如果这些点有和外点对应的,则置零。
- CV_WARP_INVERSE_MAP - 表示矩阵由输出图像到输入图像的逆变换,并且因此可以直接用于像素插值。否则,函数从map_matrix中寻找逆变换。
- fillval
- 用于填充外点的值。
函数cvLogPolar用以下变换变换输入图像:
正变换 (CV_WARP_INVERSE_MAP 未置位):
dst(phi,rho)<-src(x,y)
逆变换 (CV_WARP_INVERSE_MAP 置位):
dst(x,y)<-src(phi,rho),
这里,
rho=M*log(sqrt(x2+y2)) phi=atan(y/x)
此函数模仿人类视网膜中央凹视力,并且对于目标跟踪等可用于快速尺度和旋转变换不变模板匹配。
理解了函数之后呢,开始写入视频~
#include"highgui.h"#include"cv.h"int main(int argc, char* argv[]){CvCapture* capture = 0;char* inputVideo = "test1.avi";char* outputVideo = "output.avi";capture = cvCreateFileCapture(inputVideo);if(!capture){return -1;}IplImage *bgr_frame = cvQueryFrame(capture);//init the video readdouble fps = cvGetCaptureProperty( //get fps zhen lvcapture,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(outputVideo,CV_FOURCC('M','J','P','G'),fps,size);IplImage* logpolar_frame = cvCreateImage(size,IPL_DEPTH_8U,3);while((bgr_frame = cvQueryFrame(capture))!=NULL){cvLogPolar(bgr_frame,logpolar_frame,cvPoint2D32f(bgr_frame->width/2,bgr_frame->height/2),40,CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS);cvWriteFrame(writer,logpolar_frame);}cvReleaseVideoWriter(&writer);cvReleaseImage(&logpolar_frame);cvReleaseCapture(&capture);return(0);}
经过试验发现,CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS,和 CV_INTER_LINEAR or CV_WARP_FILL_OUTLIERS 还有 CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS产生的结果都是一样的。
只有这个 CV_INTER_LINEAR||CV_WARP_FILL_OUTLIERS||CV_WARP_INVERSE_MAP结果不一样~
为什么呢?还请大神指教,俺数学不好……
有试验结果的视频,怎么能传呢?挺好玩的~
先传两个视频的截图吧~好吧~把我们研究室的哥扭曲了~不过他也不会看到~
- [opencv]重写视频以及logpolar变换
- OpenCV笛卡尔坐标到极坐标变换函数LogPolar
- LogPolar 坐标变换
- 【OpenCV】图像变换(六)对数极坐标变换LogPolar&直方图均衡EqualizeHist
- OpenCV入门(十八)--LogPolar
- Opencv step by step - 视频变换
- java opencv 获取视频变换矩阵
- opencv(17)---霍夫变换以及应用
- OpenCV学习——Laplace变换(视频边界检测)
- opencv对摄像头采集视频的几种变换
- 【opencv学习笔记4】视频流的帧图像变换
- 【OpenCV】2nd-播放视频、平滑处理、尺寸变换
- opencv 读取视频以及灰度化
- Android之视频播放以及亮度音量变换
- ffmpeg视频解码以及opencv视频播放参考
- OpenCV--霍夫线变换&霍夫圆变换
- OpenCV 2学习之“摄像头--视频流的霍夫变换“
- OpenCV-调用USB摄像机获取视频流,ROI特定提取,图像变换
- 产品经理(PM)常用原型图设计工具
- SELECT带条件查询
- 实例简介HttpUnit结合JUnit自动测试Web应用
- 学习android的opengl es
- 取消软件自动启动的方法一览【xitongshoucang】
- [opencv]重写视频以及logpolar变换
- java基础之高级应用
- Android中shape的使用
- Exception in thread "main" java.lang.NoClassDefFoundError: com/sun/mail/util/LineInputStream
- 【Win8系统RP输入法切换方法】
- RedHat5.8下ORALCE11g 安装
- OpenGL分格化和二次方程表面
- iOS多线程编程指南
- 免费使用的图表控件XML/SWF Charts 5.08