日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

opencv2.2.0源代码(include文件)分析

發布時間:2023/12/10 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 opencv2.2.0源代码(include文件)分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

由于openCV2.2.0源文件很龐大,這里我只分析openCV2.2.0文件組織結構的各個模塊的include文件(重點分析各個模塊下引用的算法和實現的功能),而不是src文件。這里分析各個模塊有助于更好的從整體把握和理解openCV2.2.0。這里只是自己做草稿部分,便于以后修改查找。有理解不對的,希望大家指出。--瘋子_007

?

首先分析的是highgui目錄下的highgui_c.h和highgui.cpp文件:

highgui_c.h分三部分:基本的GUI函數庫,視頻接口,和過時的函數庫。基本的GUI函數庫包括:創建窗體,設置窗體屬性,獲取窗體屬性,在窗體內顯示圖片,改變窗體大小,移動窗體,銷毀窗體(包括銷毀所有窗體);獲取給定句柄的窗體名,創建和顯示滾動條,恢復和設置滾動條位置;鼠標回調事件,設置鼠標事件回調,枚舉鼠標類型;載入圖片,保存圖片,改變圖片結構;按鍵等待。視頻接口包括:定義攝像頭結構,通過視頻文件獲取幀,從攝像頭獲取視頻文件,幀處理的特殊函數(cvRetrieveFrame),抓取幀,釋放視頻文件;恢復或者設置攝像頭屬性,返回攝像頭類型;定義寫視頻指針結構體,四色編碼,打開編碼屬性對話框,初始化寫視頻指針,將幀流寫入寫視頻指針,釋放寫視頻指針。過時的函數庫。將一些功能相同的函數,重新命名,保持舊代碼的連接性。

highgui.cpp在CV命名空間枚舉相應的一些函數和定義了VideoCapture,VideoWriter類,采用面向對象的思想進行編程,更容易理解和整體把握。

?

詳細分析如下: . /highgui/include/opencv2/highgui/highgui_c.h

基本GUI函數:

支持QT模塊一些函數(省略)

創建窗體:CVAPI(int) cvNamedWindow( const char* name, int flagsCV_DEFAULT(CV_WINDOW_AUTOSIZE) );

設置窗體屬性:CVAPI(void) cvSetWindowProperty(const char* name, intprop_id, double prop_value);

獲取窗體屬性:cvGetWindowProperty(const char* name, int prop_id);

在窗體內顯示圖片:CVAPI(void) cvShowImage( const char* name, const CvArr*image );

改變窗體大小:CVAPI(void) cvResizeWindow( const char* name, int width,int height );

移動窗體大小:CVAPI(void) cvMoveWindow( const char* name, int x, int y);

銷毀窗體(包括連接窗體的滾動條):CVAPI(void) cvDestroyWindow( const char* name);

銷毀所有窗體:CVAPI(void) cvDestroyAllWindows(void);

獲取該窗體句柄(命令行形式獲取HWWD,圖形窗口形式獲取widget):CVAPI(void*)cvGetWindowHandle( const char* name );

獲取給定句柄的窗體名:CVAPI(const char*) cvGetWindowName( void*window_handle );

?

位置回調定義1: typedef void (CV_CDECL *CvTrackbarCallback)(intpos);

在給定的窗體創建和顯示滾動條1: CVAPI(int) cvCreateTrackbar( const char*trackbar_name, const char* window_name, int* value, int count,CvTrackbarCallback on_change CV_DEFAULT(NULL));

位置回調定義2: typedef void (CV_CDECL *CvTrackbarCallback2)(int pos,void* userdata);

在給定的窗體創建和顯示滾動條2: CVAPI(int) cvCreateTrackbar2( const char*trackbar_name, const char* window_name,int* value, int count,CvTrackbarCallback2 on_change, void* userdata CV_DEFAULT(0));

恢復或者設置滾動條位置:CVAPI(int) cvGetTrackbarPos( const char*trackbar_name, const char* window_name ); CVAPI(void)cvSetTrackbarPos( const char* trackbar_name, const char*window_name, int pos );

枚舉鼠標事件

enum

{

???????CV_EVENT_MOUSEMOVE =0,// 鼠標移動

???????CV_EVENT_LBUTTONDOWN =1,// 鼠標左擊

???????CV_EVENT_RBUTTONDOWN =2,// 鼠標右擊

???????CV_EVENT_MBUTTONDOWN =3,// 鼠標中鍵單價

????????CV_EVENT_LBUTTONUP=4,//

??????CV_EVENT_RBUTTONUP =5,//

???????CV_EVENT_MBUTTONUP=6,//

??????CV_EVENT_LBUTTONDBLCLK =7,// 鼠標左鍵雙擊

??????CV_EVENT_RBUTTONDBLCLK =8,// 鼠標右鍵雙擊

?????CV_EVENT_MBUTTONDBLCLK =9 // 鼠標中鍵雙擊

};

enum

{

CV_EVENT_FLAG_LBUTTON =1,

CV_EVENT_FLAG_RBUTTON =2,

CV_EVENT_FLAG_MBUTTON =4,

CV_EVENT_FLAG_CTRLKEY =8,

CV_EVENT_FLAG_SHIFTKEY =16,

CV_EVENT_FLAG_ALTKEY =32

};

鼠標回調事件定義 typedef void (CV_CDECL *CvMouseCallback )(int event,int x, int y, int flags, void* param);

設置鼠標事件回調:CVAPI(void) cvSetMouseCallback( const char*window_name, CvMouseCallback on_mouse, void* paramCV_DEFAULT(NULL));

?

?enum

{

CV_LOAD_IMAGE_UNCHANGED =-1,

CV_LOAD_IMAGE_GRAYSCALE =0,

CV_LOAD_IMAGE_COLOR =1,

CV_LOAD_IMAGE_ANYDEPTH =2,

CV_LOAD_IMAGE_ANYCOLOR =4

};

?

從文件中調入圖片(iscolor 默認參數是CV_LOAD_IMAGE_UNCHANGED):

CVAPI(IplImage*) cvLoadImage( const char* filename, int iscolorCV_DEFAULT(CV_LOAD_IMAGE_COLOR)); CVAPI(CvMat*) cvLoadImageM( constchar* filename, int iscolor CV_DEFAULT(CV_LOAD_IMAGE_COLOR)); enum{ CV_IMWRITE_JPEG_QUALITY =1, CV_IMWRITE_PNG_COMPRESSION =16,CV_IMWRITE_PXM_BINARY =32 };

保存圖片: CVAPI(int) cvSaveImage( const char* filename, const CvArr*image,const int* params CV_DEFAULT(0) );

對存儲在緩沖中的圖進行解碼:

CVAPI(IplImage*) cvDecodeImage( const CvMat* buf, int iscolorCV_DEFAULT(CV_LOAD_IMAGE_COLOR)); CVAPI(CvMat*) cvDecodeImageM(const CvMat* buf, int iscolor CV_DEFAULT(CV_LOAD_IMAGE_COLOR));

對圖像進行編碼,并將結果保存到單通道的8UC1矩陣中:CVAPI(CvMat*) cvEncodeImage( constchar* ext, const CvArr* image, const int* params CV_DEFAULT(0) );enum { CV_CVTIMG_FLIP =1, CV_CVTIMG_SWAP_RB =2 };

改變圖像結構:CVAPI(void) cvConvertImage( const CvArr* src, CvArr* dst,int flags CV_DEFAULT(0));

?

按鍵等待:CVAPI(int) cvWaitKey(int delay CV_DEFAULT(0));

?

視頻文件和攝像頭接口

定義攝像頭結構體:typedef struct CvCapture CvCapture;

通過視頻文件獲取幀:

CVAPI(CvCapture*) cvCreateFileCapture( const char* filename);

enum

?{

CV_CAP_ANY =0, // autodetect

CV_CAP_MIL =100, // MIL proprietarydrivers

CV_CAP_VFW =200, // platformnative

CV_CAP_V4L =200,

CV_CAP_V4L2 =200,

CV_CAP_FIREWARE =300, // IEEE 1394drivers

CV_CAP_FIREWIRE =300,

CV_CAP_IEEE1394 =300,

CV_CAP_DC1394 =300,

CV_CAP_CMU1394 =300,

CV_CAP_STEREO =400, // TYZXproprietary drivers

CV_CAP_TYZX =400,

CV_TYZX_LEFT =400,

CV_TYZX_RIGHT =401,

CV_TYZX_COLOR =402,

CV_TYZX_Z =403,

CV_CAP_QT =500, // QuickTime

CV_CAP_UNICAP =600, // Unicapdrivers

CV_CAP_DSHOW =700, // DirectShow (viavideoInput)

CV_CAP_PVAPI =800 // PvAPI, ProsilicaGigE SDK

?};

?

從攝像頭獲取視頻文件:(index為camera_index + domain_offset(CV_CAP_*))CVAPI(CvCapture*) cvCreateCameraCapture( int index );

抓取幀,成功返回1,否則為0:CVAPI(int) cvGrabFrame( CvCapture* capture );

得到cvGrabFrame獲取的幀,此函數應用在一些幀處理,比如幀減壓,旋轉:(千萬不要釋放或者修改返回幀)CVAPI(IplImage*)cvRetrieveFrame( CvCapture* capture, int streamIdx CV_DEFAULT(0));

連接cvGrabFrame和cvRetrieveFrame函數:(千萬不要釋放或者修改返回幀) CVAPI(IplImage*)cvQueryFrame( CvCapture* capture );

釋放獲取或者讀取的視頻文件,釋放資源:CVAPI(void) cvReleaseCapture( CvCapture**capture );

?

enum

{

CV_CAP_PROP_POS_MSEC =0,

CV_CAP_PROP_POS_FRAMES =1,

CV_CAP_PROP_POS_AVI_RATIO =2,

CV_CAP_PROP_FRAME_WIDTH =3,

CV_CAP_PROP_FRAME_HEIGHT =4,

CV_CAP_PROP_FPS =5,

CV_CAP_PROP_FOURCC =6,

CV_CAP_PROP_FRAME_COUNT =7,

CV_CAP_PROP_FORMAT =8,

CV_CAP_PROP_MODE =9,

CV_CAP_PROP_BRIGHTNESS =10,

CV_CAP_PROP_CONTRAST =11,

CV_CAP_PROP_SATURATION =12,

CV_CAP_PROP_HUE =13,

CV_CAP_PROP_GAIN =14,

CV_CAP_PROP_EXPOSURE =15,

CV_CAP_PROP_CONVERT_RGB =16,

CV_CAP_PROP_WHITE_BALANCE =17,

CV_CAP_PROP_RECTIFICATION =18,

?CV_CAP_PROP_MONOCROME =19

?};

恢復或者設置攝像頭屬性:CVAPI(double) cvGetCaptureProperty( CvCapture*capture, int property_id ); CVAPI(int) cvSetCaptureProperty(CvCapture* capture, int property_id, double value );

返回攝像頭類型:CVAPI(int) cvGetCaptureDomain( CvCapture* capture);

定義寫視頻指針結構體:typedef struct CvVideoWriter CvVideoWriter;

對四色進行編碼:CV_INLINE int CV_FOURCC(char c1, char c2, char c3, charc4) { return (c1 & 255) + ((c2 &255) << 8) + ((c3&255) << 16) + ((c4& 255) << 24); }

打開編碼選項對話框(windows下) #define CV_FOURCC_PROMPT -1

默認編碼方式(linux下) #define CV_FOURCC_DEFAULT CV_FOURCC('I', 'Y','U', 'V')

初始化寫視頻指針:CVAPI(CvVideoWriter*) cvCreateVideoWriter( const char*filename, int fourcc,double fps, CvSize frame_size, int is_colorCV_DEFAULT(1));

將幀寫到視頻指針中:CVAPI(int) cvWriteFrame( CvVideoWriter* writer, constIplImage* image );

釋放寫視頻指針:CVAPI(void) cvReleaseVideoWriter( CvVideoWriter** writer);

?

過時的函數或同意不同名的函數

?#define cvCaptureFromFile cvCreateFileCapture//從視頻文件讀取視頻

#define cvCaptureFromCAM cvCreateCameraCapture//從攝像頭讀取視頻

#define cvCaptureFromAVI cvCaptureFromFile//

#define cvCreateAVIWriter cvCreateVideoWriter//創建寫視頻指針

#define cvWriteToAVI cvWriteFrame//寫入寫視頻指針

#define cvAddSearchPath(path)//增加路徑

#define cvvInitSystem cvInitSystem//

#define cvvNamedWindow cvNamedWindow//創建窗體

#define cvvShowImage cvShowImage//在窗體內顯示圖片

#define cvvResizeWindow cvResizeWindow//設置窗體大小

#define cvvDestroyWindow cvDestroyWindow//銷毀窗體

#define cvvCreateTrackbar cvCreateTrackbar//創建滾動條

#define cvvLoadImage(name) cvLoadImage((name),1)//載入圖片

#define cvvSaveImage cvSaveImage//保存圖片

#define cvvAddSearchPath cvAddSearchPath//增加路徑

#define cvvWaitKey(name) cvWaitKey(0)//按鍵等待

#define cvvWaitKeyEx(name,delay) cvWaitKey(delay)//按鍵等待

#define cvvConvertImage cvConvertImage//圖片結構改變

#define HG_AUTOSIZE CV_WINDOW_AUTOSIZE//

#define set_preprocess_func cvSetPreprocessFuncWin32//

#define set_postprocess_func cvSetPostprocessFuncWin32//

?

/highgui/include/opencv2/highgui/highgui.hpp 此C++頭文件,引入: structCvCapture; struct CvVideoWriter;在CV命名空間枚舉相應的一些函數和定義了VideoCapture,VideoWriter類,采用面向對象的思想進行編程,更容易理解和整體把握。

詳細的代碼如下:

namespace cv

{

enum { WINDOW_AUTOSIZE=1 };

CV_EXPORTS_W void namedWindow( const string&winname, int flags CV_DEFAULT(WINDOW_AUTOSIZE) ); CV_EXPORTS_W voiddestroyWindow( const string& winname );CV_EXPORTS_W int startWindowThread(); CV_EXPORTS_W voidsetWindowProperty(const string& winname, intprop_id, double prop_value);//YV CV_EXPORTS_W doublegetWindowProperty(const string& winname, intprop_id);//YV //Only for Qt

//------------------------ CV_EXPORTS

CvFont fontQt(const string& nameFont, intpointSize CV_DEFAULT(-1), Scalar color CV_DEFAULT(Scalar::all(0)),int weight CV_DEFAULT(CV_FONT_NORMAL), int styleCV_DEFAULT(CV_STYLE_NORMAL), int spacing CV_DEFAULT(0));

CV_EXPORTS void addText( const Mat& img, conststring& text, Point org, CvFont font);

CV_EXPORTS void displayOverlay(const string&winname, const string& text, int delayms);

CV_EXPORTS void displayStatusBar(const string&winname, const string& text, int delayms);

?

typedef void (CV_CDECL *OpenGLCallback)(void* userdata);

CV_EXPORTS void createOpenGLCallback(conststring& winname, CvOpenGLCallback callbackOpenGL,void* userdata CV_DEFAULT(0));

CV_EXPORTS void saveWindowParameters(conststring& windowName);

CV_EXPORTS void loadWindowParameters(conststring& windowName);

CV_EXPORTS int startLoop(int (*pt2Func)(int argc, char *argv[]),int argc, char* argv[]);

CV_EXPORTS void stopLoop();

typedef void (CV_CDECL *ButtonCallback)(int state, void*userdata);

CV_EXPORTS int createButton( const string&bar_name, ButtonCallback on_change , void* userdataCV_DEFAULT(NULL), int type CV_DEFAULT(CV_PUSH_BUTTON), boolinitial_button_state CV_DEFAULT(0));//-------------------------

?

CV_EXPORTS_W void imshow( const string& winname,const Mat& mat );

typedef void (CV_CDECL *TrackbarCallback)(int pos, void*userdata);

CV_EXPORTS int createTrackbar( const string&trackbarname, const string& winname, int* value,int count, TrackbarCallback onChange CV_DEFAULT(0), void* userdataCV_DEFAULT(0));

CV_EXPORTS_W int getTrackbarPos( const string&trackbarname, const string& winname );

CV_EXPORTS_W void setTrackbarPos( const string&trackbarname, const string& winname, int pos );

typedef void (*MouseCallback )(int event, int x, int y, intflags, void* param); //! assigns callback for mouse eventsCV_EXPORTS void setMouseCallback( const string&windowName, MouseCallback onMouse, void* param=0); CV_EXPORTS_W Matimread( const string& filename, int flags=1 );CV_EXPORTS_W bool imwrite( const string& filename,const Mat& img, const vector&params=vector());

CV_EXPORTS_W Mat imdecode( const Mat& buf, intflags );

?CV_EXPORTS_W bool imencode( conststring& ext, const Mat& img, CV_OUTvector& buf, const vector&params=vector());

CV_EXPORTS_W int waitKey(int delay=0);

#ifndef CV_NO_VIDEO_CAPTURE_CPP_API

template<> void CV_EXPORTSPtr::delete_obj();

template<> void CV_EXPORTSPtr::delete_obj();

class CV_EXPORTS_W VideoCapture

{

public:

CV_WRAP VideoCapture();

CV_WRAP VideoCapture(conststring& filename);

CV_WRAP VideoCapture(int device);

virtual ~VideoCapture();

CV_WRAP virtual bool open(conststring& filename);

?CV_WRAP virtualbool open(int device);

CV_WRAP virtual bool isOpened()const;

CV_WRAP virtual void release();

CV_WRAP virtual bool grab();

CV_WRAP virtual bool retrieve(CV_OUTMat& image, int channel=0);

?virtualVideoCapture& operator>> (CV_OUT Mat&image);

CV_WRAP virtual bool read(CV_OUTMat& image);

CV_WRAP virtual bool set(int propId,double value);

CV_WRAP virtual double get(intpropId);

protected:

Ptr cap;

};

class CV_EXPORTS_W VideoWriter

{

public:

CV_WRAP VideoWriter();

CV_WRAP VideoWriter(conststring& filename, int fourcc, double fps, SizeframeSize, bool isColor=true);

virtual ~VideoWriter(); C

V_WRAP virtual bool open(conststring& filename, int fourcc, double fps, SizeframeSize, bool isColor=true);

CV_WRAP virtual bool isOpened()

const; virtualVideoWriter& operator<< (const Mat&image);

CV_WRAP virtual void write(constMat& image);

protected:

Ptr writer;

};

?

modulescoreincludeopencv2coretypes_c.h

前面的是一些宏定義,是為了兼容C,C++。對于一些函數的調用方式,建議補充一點補充知識:http://blog.csdn.net/yongdun_007/archive/2010/12/21/6090281.aspx,這個頭文件是很重要的一個文件,建議大家都看看,這里定義了opencv用到的所有的數據類型和結構。詳細如下:

types_c.h包括:常用的宏指令和內聯函數,隨機數的生成,圖像數據類型,矩陣數據類型,多維稠密矩陣,多維稀疏矩陣,稀疏矩陣迭代,直方圖,其他數據類型定義(包括矩形,終止準則,點和變量,size變量和Box變量,片和部分,尺度或者角度),動態數據結構(包括內存存儲,序列,節點或者集,圖結構,鏈和輪廓),序列類型,序列的讀/寫操作,對序列的操作(包括圖的微操作),保持數據結構的穩定性,系統數據類型。

?

常用的宏指令和內聯函數:

#define CV_PI??3.1415926535897932384626433832795//定義PI大小

#define CV_LOG20.69314718055994530941723212145818//定義log2

?

#define CV_SWAP(a,b,t) ((t) = (a), (a) = (b), (b) =(t))//交換a,b

?

#ifndef MIN

#define MIN(a,b)? ((a) >(b) ? (b) : (a))//求a,b最小值

#endif

?

#ifndef MAX

#define MAX(a,b)? ((a) <(b) ? (b) : (a))//求a,b最大值

#endif

?

?

#define? CV_IMIN(a,b)? ((a) ^ (((a)^(b)) &(((a) < (b)) - 1)))//

?

#define? CV_IMAX(a,b)? ((a) ^ (((a)^(b)) &(((a) > (b)) - 1)))//

?

?

#ifndef __cplusplus

#define?CV_IABS(a)????(((a)^ ((a) < 0 ? -1 : 0)) - ((a) < 0 ? -1: 0))

#else

#define?CV_IABS(a)????abs(a)

#endif

#define?CV_CMP(a,b)???(((a) > (b)) - ((a) < (b)))

#define?CV_SIGN(a)????CV_CMP((a),0)

?

// 返回和參數最接近的整數值

CV_INLINE? int?cvRound( double value )

?

//返回不大于參數的最大整數值

CV_INLINE? int?cvFloor( double value )

?

//返回不小于參數的最小整數值

CV_INLINE? int?cvCeil( double value )

?

//對參數開平方并進行求倒

#define cvInvSqrt(value) ((float)(1./sqrt(value)))

//對參數開平方

#define cvSqrt(value)?((float)sqrt(value))

?

//判定是否為合法數

CV_INLINE int cvIsNaN( double value )

//判定是否為無窮?

CV_INLINE int cvIsInf( double value )

?

隨機數的生成

?

typedef uint64 CvRNG;

?

//初始化隨機數生成器狀態

CV_INLINE CvRNG cvRNG( int64 seed CV_DEFAULT(-1))

//返回32位無符號整型并更新RNG

CV_INLINE unsigned cvRandInt( CvRNG* rng )

//返回浮點型隨機數并更新RNG

CV_INLINE double cvRandReal( CvRNG* rng )

?

圖像數據類型

?

#ifndef HAVE_IPL

?

?

?

//定義深度位數

#define IPL_DEPTH_SIGN 0x80000000

#defineIPL_DEPTH_1U????1

#defineIPL_DEPTH_8U????8

#defineIPL_DEPTH_16U??16

#defineIPL_DEPTH_32F??32

?

//定義有符號深度位數

#define IPL_DEPTH_8S? (IPL_DEPTH_SIGN|8)

#define IPL_DEPTH_16S (IPL_DEPTH_SIGN|16)

#define IPL_DEPTH_32S (IPL_DEPTH_SIGN|32)

?

//定義數據順序

#define IPL_DATA_ORDER_PIXEL? 0

#define IPL_DATA_ORDER_PLANE? 1

?

//定義圖像原點位置

#define IPL_ORIGIN_TL 0 //左上

#define IPL_ORIGIN_BL 1 //左下

?

//定義掃描線位數

#define IPL_ALIGN_4BYTES??4

#defineIPL_ALIGN_8BYTES??8

#define IPL_ALIGN_16BYTES 16

#define IPL_ALIGN_32BYTES 32

?

//定義掃描線對齊

#defineIPL_ALIGN_DWORD??IPL_ALIGN_4BYTES

#defineIPL_ALIGN_QWORD??IPL_ALIGN_8BYTES

?

//定義掃描線寬度狀態

#defineIPL_BORDER_CONSTANT??0 //掃描線連續

#define IPL_BORDER_REPLICATE? 1//雙掃描線

#defineIPL_BORDER_REFLECT???2 //帶陰影掃描線

#defineIPL_BORDER_WRAP??????3 //波浪掃描線

?

//定義圖像結構體

typedef struct _IplImage

{

???int?nSize;????????????

???int?ID;???????????????

???int?nChannels;????????

???int?alphaChannel;?????

???int?depth;????????????

???charcolorModel[4];????

???charchannelSeq[4];????

???int?dataOrder;????????

???int?origin;???????????

???int?align;????????????

???int?width;????????????

???int?height;???????????

???struct _IplROI*roi;???

???struct _IplImage*maskROI;?????

???void?*imageId;????????????????

???struct _IplTileInfo *tileInfo;?

???int?imageSize;????????

???char*imageData;???????

???int?widthStep;????????

???int?BorderMode[4];????

???int?BorderConst[4];???

???char *imageDataOrigin;?

}

IplImage;

?

//定義圖像分塊信息結構體

typedef struct _IplTileInfo IplTileInfo;

?

//定義圖像感興趣區域

typedef struct _IplROI

{

???int? coi; //感興趣通道

???int? xOffset; //X坐標值

???int? yOffset; //y坐標值

???int?width;??//感興趣區域寬度

???int? height;?//感興趣區域高度

}

IplROI;

?

//定義卷積核結構體

typedef struct _IplConvKernel

{

???int? nCols;

???int? nRows;

???int? anchorX;

???int? anchorY;

???int *values;

???int? nShiftR;

}

IplConvKernel;

?

//定義快速卷積核結構體

typedef struct _IplConvKernelFP

{

???int? nCols;

???int? nRows;

???int? anchorX;

???int? anchorY;

???float *values;

}

IplConvKernelFP;

?

#define IPL_IMAGE_HEADER 1

#defineIPL_IMAGE_DATA??2

#defineIPL_IMAGE_ROI???4

?

#endif

?

//定義邊界模式

#defineIPL_BORDER_REFLECT_101???4 //帶有陰影

#defineIPL_BORDER_TRANSPARENT???5 //透明

?

#define IPL_IMAGE_MAGIC_VAL?((int)sizeof(IplImage))

#define CV_TYPE_NAME_IMAGE "opencv-image"

?

#define CV_IS_IMAGE_HDR(img)

???((img) != NULL && ((constIplImage*)(img))->nSize == sizeof(IplImage))

?

#define CV_IS_IMAGE(img)

???(CV_IS_IMAGE_HDR(img) &&((IplImage*)img)->imageData != NULL)

?

//定義存儲在圖像的雙精度數據

#define IPL_DEPTH_64F? 64

?

//定義從給定圖像,給定數據類型,給定坐標(col,row)獲取圖像像素值

#define CV_IMAGE_ELEM( image, elemtype, row, col)??????

(((elemtype*)((image)->imageData +(image)->widthStep*(row)))[(col)])

?

?

矩陣數據類型

?

//

#defineCV_CN_MAX????512??//定義矩陣數據最大值

#defineCV_CN_SHIFT??3????//

#define CV_DEPTH_MAX? (1<< CV_CN_SHIFT) //

?

//定義矩陣數據類型

#define CV_8U??0

#define CV_8S??1

#define CV_16U? 2

#define CV_16S? 3

#define CV_32S? 4

#define CV_32F? 5

#define CV_64F? 6

#define CV_USRTYPE1 7

?

//

#defineCV_MAT_DEPTH_MASK??????(CV_DEPTH_MAX - 1)

#defineCV_MAT_DEPTH(flags)????((flags) & CV_MAT_DEPTH_MASK)

?

//

#define CV_MAKETYPE(depth,cn) (CV_MAT_DEPTH(depth) + (((cn)-1)<< CV_CN_SHIFT))

#define CV_MAKE_TYPE CV_MAKETYPE

?

//

#define CV_8UC1 CV_MAKETYPE(CV_8U,1)

#define CV_8UC2 CV_MAKETYPE(CV_8U,2)

#define CV_8UC3 CV_MAKETYPE(CV_8U,3)

#define CV_8UC4 CV_MAKETYPE(CV_8U,4)

#define CV_8UC(n) CV_MAKETYPE(CV_8U,(n))

?

//

#define CV_8SC1 CV_MAKETYPE(CV_8S,1)

#define CV_8SC2 CV_MAKETYPE(CV_8S,2)

#define CV_8SC3 CV_MAKETYPE(CV_8S,3)

#define CV_8SC4 CV_MAKETYPE(CV_8S,4)

#define CV_8SC(n) CV_MAKETYPE(CV_8S,(n))

?

//

#define CV_16UC1 CV_MAKETYPE(CV_16U,1)

#define CV_16UC2 CV_MAKETYPE(CV_16U,2)

#define CV_16UC3 CV_MAKETYPE(CV_16U,3)

#define CV_16UC4 CV_MAKETYPE(CV_16U,4)

#define CV_16UC(n) CV_MAKETYPE(CV_16U,(n))

?

//

#define CV_16SC1 CV_MAKETYPE(CV_16S,1)

#define CV_16SC2 CV_MAKETYPE(CV_16S,2)

#define CV_16SC3 CV_MAKETYPE(CV_16S,3)

#define CV_16SC4 CV_MAKETYPE(CV_16S,4)

#define CV_16SC(n) CV_MAKETYPE(CV_16S,(n))

?

//

#define CV_32SC1 CV_MAKETYPE(CV_32S,1)

#define CV_32SC2 CV_MAKETYPE(CV_32S,2)

#define CV_32SC3 CV_MAKETYPE(CV_32S,3)

#define CV_32SC4 CV_MAKETYPE(CV_32S,4)

#define CV_32SC(n) CV_MAKETYPE(CV_32S,(n))

?

//

#define CV_32FC1 CV_MAKETYPE(CV_32F,1)

#define CV_32FC2 CV_MAKETYPE(CV_32F,2)

#define CV_32FC3 CV_MAKETYPE(CV_32F,3)

#define CV_32FC4 CV_MAKETYPE(CV_32F,4)

#define CV_32FC(n) CV_MAKETYPE(CV_32F,(n))

?

//

#define CV_64FC1 CV_MAKETYPE(CV_64F,1)

#define CV_64FC2 CV_MAKETYPE(CV_64F,2)

#define CV_64FC3 CV_MAKETYPE(CV_64F,3)

#define CV_64FC4 CV_MAKETYPE(CV_64F,4)

#define CV_64FC(n) CV_MAKETYPE(CV_64F,(n))

?

//

#define CV_AUTO_STEP? 0x7fffffff

#define CV_WHOLE_ARR? cvSlice( 0,0x3fffffff )

?

//

#defineCV_MAT_CN_MASK?????????((CV_CN_MAX - 1) << CV_CN_SHIFT)

#defineCV_MAT_CN(flags)???????((((flags) & CV_MAT_CN_MASK)>> CV_CN_SHIFT) + 1)

#defineCV_MAT_TYPE_MASK???????(CV_DEPTH_MAX*CV_CN_MAX - 1)

#defineCV_MAT_TYPE(flags)?????((flags) & CV_MAT_TYPE_MASK)

#define CV_MAT_CONT_FLAG_SHIFT? 14

#defineCV_MAT_CONT_FLAG???????(1 << CV_MAT_CONT_FLAG_SHIFT)

#defineCV_IS_MAT_CONT(flags)??((flags) & CV_MAT_CONT_FLAG)

#defineCV_IS_CONT_MAT?????????CV_IS_MAT_CONT

#defineCV_SUBMAT_FLAG_SHIFT???15

#defineCV_SUBMAT_FLAG?????????(1 << CV_SUBMAT_FLAG_SHIFT)

#defineCV_IS_SUBMAT(flags)????((flags) & CV_MAT_SUBMAT_FLAG)

?

//

#defineCV_MAGIC_MASK??????0xFFFF0000

#defineCV_MAT_MAGIC_VAL???0x42420000

#defineCV_TYPE_NAME_MAT???"opencv-matrix"

?

//定義矩陣結構體

typedef struct CvMat

{

???int type;

???int step;

?

???

???int* refcount;

???int hdr_refcount;

?

???union

???{

???????uchar* ptr;

???????short* s;

???????int* i;

???????float* fl;

???????double* db;

???} data;

?

#ifdef __cplusplus

???union

???{

???????int rows;

???????int height;

???};

?

???union

???{

???????int cols;

???????int width;

???};

#else

???int rows;

???int cols;

#endif

?

}

CvMat;

?

//判斷矩陣頭指針

#define CV_IS_MAT_HDR(mat)

???((mat) != NULL &&

???(((const CvMat*)(mat))->type &CV_MAGIC_MASK) == CV_MAT_MAGIC_VAL&&

???((const CvMat*)(mat))->cols > 0&& ((constCvMat*)(mat))->rows > 0)

?

//

#define CV_IS_MAT_HDR_Z(mat)

???((mat) != NULL &&

???(((const CvMat*)(mat))->type &CV_MAGIC_MASK) == CV_MAT_MAGIC_VAL&&

???((const CvMat*)(mat))->cols >= 0&& ((constCvMat*)(mat))->rows >= 0)

?

//

#define CV_IS_MAT(mat)

???(CV_IS_MAT_HDR(mat) && ((constCvMat*)(mat))->data.ptr != NULL)

?

//

#define CV_IS_MASK_ARR(mat)

???(((mat)->type & (CV_MAT_TYPE_MASK& ~CV_8SC1)) == 0)

?

#define CV_ARE_TYPES_EQ(mat1, mat2)

???((((mat1)->type ^ (mat2)->type)& CV_MAT_TYPE_MASK) == 0)

?

//

#define CV_ARE_CNS_EQ(mat1, mat2)

???((((mat1)->type ^ (mat2)->type)& CV_MAT_CN_MASK) == 0)

?

//

#define CV_ARE_DEPTHS_EQ(mat1, mat2)

???((((mat1)->type ^ (mat2)->type)& CV_MAT_DEPTH_MASK) == 0)

?

//

#define CV_ARE_SIZES_EQ(mat1, mat2)

???((mat1)->rows == (mat2)->rows&& (mat1)->cols ==(mat2)->cols)

?

#define CV_IS_MAT_CONST(mat)?

???(((mat)->rows|(mat)->cols) == 1)

?

//

?

#define CV_ELEM_SIZE1(type)

???((((sizeof(size_t)<<28)|0x8442211)>> CV_MAT_DEPTH(type)*4)& 15)

?

//

?

#define CV_ELEM_SIZE(type)

???(CV_MAT_CN(type) <<((((sizeof(size_t)/4+1)*16384|0x3a50)>> CV_MAT_DEPTH(type)*2)& 3))

?

//

#define IPL2CV_DEPTH(depth)

???((((CV_8U)+(CV_16U<<4)+(CV_32F<<8)+(CV_64F<<16)+(CV_8S<<20)+

???(CV_16S<<24)+(CV_32S<<28))>> ((((depth) & 0xF0)>> 2) +

???(((depth) & IPL_DEPTH_SIGN) ? 20 : 0)))& 15)

?

//初始化矩陣

?

CV_INLINE CvMat cvMat( int rows, int cols, int type, void* dataCV_DEFAULT(NULL))

?

//快速將數據添加到矩陣

#define CV_MAT_ELEM_PTR_FAST( mat, row, col, pix_size)?

???(assert( (unsigned)(row) < (unsigned)(mat).rows&&??

????????????(unsigned)(col) < (unsigned)(mat).cols),??

????(mat).data.ptr + (size_t)(mat).step*(row) + (pix_size)*(col))

?

//快速將數據添加到矩陣(1)

#define CV_MAT_ELEM_PTR( mat, row, col)????????????????

???CV_MAT_ELEM_PTR_FAST( mat, row, col, CV_ELEM_SIZE((mat).type) )

?

//快速將數據添加到矩陣(2)

#define CV_MAT_ELEM( mat, elemtype, row, col)??????????

???(*(elemtype*)CV_MAT_ELEM_PTR_FAST( mat, row, col,sizeof(elemtype)))

?

//從矩陣中獲取數據

CV_INLINE?double? cvmGet( const CvMat* mat, int row,int col )

?

//將數據添加到矩陣

CV_INLINE? void?cvmSet( CvMat* mat, int row, int col, double value )

?

//設置矩陣數據類型

CV_INLINE int cvIplDepth( int type )

?

多維稠密矩陣

?

//

#defineCV_MATND_MAGIC_VAL???0x42430000

#defineCV_TYPE_NAME_MATND???"opencv-nd-matrix"

?

//

#defineCV_MAX_DIM???????????32

#defineCV_MAX_DIM_HEAP??????(1 << 16)

?

//定義稠密矩陣結構體

typedef struct CvMatND

{

???int type;

???int dims;

?

???int* refcount;

???int hdr_refcount;

?

???union

???{

???????uchar* ptr;

???????float* fl;

???????double* db;

???????int* i;

???????short* s;

???} data;

?

???struct

???{

???????int size;

???????int step;

???}

???dim[CV_MAX_DIM];

}

CvMatND;

?

//

#define CV_IS_MATND_HDR(mat)

???((mat) != NULL && (((constCvMatND*)(mat))->type &CV_MAGIC_MASK) == CV_MATND_MAGIC_VAL)

?

//

#define CV_IS_MATND(mat)

???(CV_IS_MATND_HDR(mat) && ((constCvMatND*)(mat))->data.ptr != NULL)

?

多維稀疏矩陣

?

//

#defineCV_SPARSE_MAT_MAGIC_VAL???0x42440000

#defineCV_TYPE_NAME_SPARSE_MAT???"opencv-sparse-matrix"

?

//

struct CvSet;

?

//定義稀疏矩陣結構體

typedef struct CvSparseMat

{

???int type;

???int dims;

???int* refcount;

???int hdr_refcount;

?

???struct CvSet* heap;

???void** hashtable;

???int hashsize;

???int valoffset;

???int idxoffset;

???int size[CV_MAX_DIM];

}

CvSparseMat;

?

//

#define CV_IS_SPARSE_MAT_HDR(mat)

???((mat) != NULL &&

???(((const CvSparseMat*)(mat))->type &CV_MAGIC_MASK) == CV_SPARSE_MAT_MAGIC_VAL)

?

//

#define CV_IS_SPARSE_MAT(mat)

???CV_IS_SPARSE_MAT_HDR(mat)

?

稀疏矩陣迭代

?

//定義稀疏矩陣迭代體結構體

typedef struct CvSparseNode

{

???unsigned hashval;

???struct CvSparseNode* next;

}

CvSparseNode;

?

//定義稀疏矩陣迭代器

typedef struct CvSparseMatIterator

{

???CvSparseMat* mat;

???CvSparseNode* node;

???int curidx;

}

CvSparseMatIterator;

?

#defineCV_NODE_VAL(mat,node)??((void*)((uchar*)(node) + (mat)->valoffset))

#defineCV_NODE_IDX(mat,node)??((int*)((uchar*)(node) + (mat)->idxoffset))

?

直方圖

?

typedef int CvHistType;

?

//

#defineCV_HIST_MAGIC_VAL????0x42450000

#define CV_HIST_UNIFORM_FLAG? (1<< 10)

?

//維區域是否設置的標簽

#defineCV_HIST_RANGES_FLAG??(1 << 11)

?

//定義矩陣狀態

#defineCV_HIST_ARRAY????????0 //數組直方圖

#defineCV_HIST_SPARSE???????1 //稀疏直方圖

#defineCV_HIST_TREE?????????CV_HIST_SPARSE //樹形直方圖

?

?

#defineCV_HIST_UNIFORM??????1

?

//定義直方圖結構體

typedef struct CvHistogram

{

???int????type;

???CvArr*? bins;

???float??thresh[CV_MAX_DIM][2];?

???float**thresh2;???????????????

???CvMatNDmat;???????????????????

}

CvHistogram;

?

//

#define CV_IS_HIST( hist )

???((hist) != NULL?&&

????(((CvHistogram*)(hist))->type &CV_MAGIC_MASK) == CV_HIST_MAGIC_VAL&&

????(hist)->bins != NULL)

?

//

#define CV_IS_UNIFORM_HIST( hist )

???(((hist)->type &CV_HIST_UNIFORM_FLAG) != 0)

?

//

#define CV_IS_SPARSE_HIST( hist )

???CV_IS_SPARSE_MAT((hist)->bins)

?

//

#define CV_HIST_HAS_RANGES( hist )

???(((hist)->type &CV_HIST_RANGES_FLAG) != 0)

?

//

?

其他數據類型應用定義------矩形

?

//定義矩形結構體

typedef struct CvRect

{

???int x;

???int y;

???int width;

???int height;

}

CvRect;

?

//矩形初始化

CV_INLINE?CvRect? cvRect( int x, int y, int width,int height )

{

???CvRect r;

?

???r.x = x;

???r.y = y;

???r.width = width;

???r.height = height;

?

???return r;

}

?

//在感興趣通道上設置圖的感興趣區域

CV_INLINE?IplROI? cvRectToROI( CvRect rect, int coi)

?

//獲取感興趣區域的矩形大小

CV_INLINE?CvRect? cvROIToRect( IplROI roi )

?

其他數據類型應用定義------終止準則

?

//

#defineCV_TERMCRIT_ITER???1

#define CV_TERMCRIT_NUMBER?CV_TERMCRIT_ITER

#defineCV_TERMCRIT_EPS????2

?

//定義迭代算法的終止準則結構體

typedef struct CvTermCriteria

{

???int???type;?

???int???max_iter;

???double epsilon;

}

CvTermCriteria;

?

//初始化終止準則

CV_INLINE?CvTermCriteria? cvTermCriteria( int type,int max_iter, double epsilon )?

?

其他數據類型應用定義------點和變量

?

//定義整型二維點

typedef struct CvPoint

{

???int x;

???int y;

}

CvPoint;

?

//初始化二維點

CV_INLINE?CvPoint? cvPoint( int x, int y )

{

???CvPoint p;

?

???p.x = x;

???p.y = y;

?

???return p;

}

?

//定義浮點型二維點

typedef struct CvPoint2D32f

{

???float x;

???float y;

}

CvPoint2D32f;

?

//初始化浮點型二維點

CV_INLINE?CvPoint2D32f? cvPoint2D32f( double x,double y )

{

???CvPoint2D32f p;

?

???p.x = (float)x;

???p.y = (float)y;

?

???return p;

}

?

//

CV_INLINE?CvPoint2D32f? cvPointTo32f( CvPoint point)

{

???return cvPoint2D32f( (float)point.x, (float)point.y );

}

?

?

CV_INLINE?CvPoint? cvPointFrom32f( CvPoint2D32f point)

{

???CvPoint ipt;

???ipt.x = cvRound(point.x);

???ipt.y = cvRound(point.y);

?

???return ipt;

}

?

//定義浮點型三維點

typedef struct CvPoint3D32f

{

???float x;

???float y;

???float z;

}

CvPoint3D32f;

?

//初始化浮點型三維點

CV_INLINE?CvPoint3D32f? cvPoint3D32f( double x,double y, double z )

{

???CvPoint3D32f p;

?

???p.x = (float)x;

???p.y = (float)y;

???p.z = (float)z;

?

???return p;

}

?

//定義雙精度型二維點

typedef struct CvPoint2D64f

{

???double x;

???double y;

}

CvPoint2D64f;

?

//初始化雙精度型二維點

CV_INLINE?CvPoint2D64f? cvPoint2D64f( double x,double y )

{

???CvPoint2D64f p;

?

???p.x = x;

???p.y = y;

?

???return p;

}

?

//定義雙精度型三維點

typedef struct CvPoint3D64f

{

???double x;

???double y;

???double z;

}

CvPoint3D64f;

?

//初始化雙精度型三維點

CV_INLINE?CvPoint3D64f? cvPoint3D64f( double x,double y, double z )

{

???CvPoint3D64f p;

?

???p.x = x;

???p.y = y;

???p.z = z;

?

???return p;

}

?

?

其他數據類型應用定義------size變量和Box箱變量

?

//定義size

typedef struct

{

???int width;

???int height;

}

CvSize;

?

//初始化size

CV_INLINE?CvSize? cvSize( int width, int height )

{

???CvSize s;

?

???s.width = width;

???s.height = height;

?

???return s;

}

?

//定義二維浮點型size

typedef struct CvSize2D32f

{

???float width;

???float height;

}

CvSize2D32f;

?

//初始化二維浮點型size

CV_INLINE?CvSize2D32f? cvSize2D32f( double width,double height )

{

???CvSize2D32f s;

?

???s.width = (float)width;

???s.height = (float)height;

?

???return s;

}

?

//定義二維箱

typedef struct CvBox2D

{

???CvPoint2D32f center;?

???CvSize2D32f?size;???

???floatangle;?????????

?????????????????????????

}

CvBox2D;

?

//定義線性迭代狀態

typedef struct CvLineIterator

{

???

???uchar* ptr;

?

???

???int? err;

???int? plus_delta;

???int? minus_delta;

???int? plus_step;

???int? minus_step;

}

CvLineIterator;

?

?

?

其他數據類型應用定義------片,部分

?

//定義片

typedef struct CvSlice

{

???int? start_index, end_index;

}

CvSlice;

?

//初始化片

CV_INLINE?CvSlice? cvSlice( int start, int end )

{

???CvSlice slice;

???slice.start_index = start;

???slice.end_index = end;

?

???return slice;

}

?

#define CV_WHOLE_SEQ_END_INDEX 0x3fffffff

#define CV_WHOLE_SEQ? cvSlice(0,CV_WHOLE_SEQ_END_INDEX)

?

?

其他數據類型應用定義------尺度,角度

?

//定義角度結構體

typedef struct CvScalar

{

???double val[4];

}

CvScalar;

?

//初始化角度

CV_INLINE?CvScalar? cvScalar( double val0, doubleval1 CV_DEFAULT(0),

??????????????????????????????double val2 CV_DEFAULT(0), double val3 CV_DEFAULT(0))

{

???CvScalar scalar;

???scalar.val[0] = val0; scalar.val[1] = val1;

???scalar.val[2] = val2; scalar.val[3] = val3;

???return scalar;

}

?

?

CV_INLINE?CvScalar? cvRealScalar( double val0 )

{

???CvScalar scalar;

???scalar.val[0] = val0;

???scalar.val[1] = scalar.val[2] = scalar.val[3] = 0;

???return scalar;

}

?

CV_INLINE?CvScalar? cvScalarAll( double val0123 )

{

???CvScalar scalar;

???scalar.val[0] = val0123;

???scalar.val[1] = val0123;

???scalar.val[2] = val0123;

???scalar.val[3] = val0123;

???return scalar;

}

動態數據結構-內存存儲

?

//定義內存塊結構

typedef struct CvMemBlock

{

???struct CvMemBlock*? prev;

???struct CvMemBlock*? next;

}

CvMemBlock;

?

#defineCV_STORAGE_MAGIC_VAL???0x42890000

?

typedef struct CvMemStorage

{

???int signature;

???CvMemBlock*bottom;??????????

???CvMemBlock*top;?????????????

???struct? CvMemStorage* parent;

???intblock_size;??????????????

???intfree_space;??????????????

}

CvMemStorage;

?

#define CV_IS_STORAGE(storage)?

???((storage) != NULL&&??????

???(((CvMemStorage*)(storage))->signature& CV_MAGIC_MASK) == CV_STORAGE_MAGIC_VAL)

?

?

typedef struct CvMemStoragePos

{

???CvMemBlock* top;

???int free_space;

}

CvMemStoragePos;

?

?

動態數據結構-序列(線性)

?

//定義序列塊結構體

typedef struct CvSeqBlock

{

???struct CvSeqBlock*? prev;

???struct CvSeqBlock*? next;

?int???start_index;????????

?????????????????????????????

???int???count;????????????

???schar*data;?????????????

}

CvSeqBlock;

?

?

//定義序列節點

#defineCV_TREE_NODE_FIELDS(node_type)??????????????????????????????

???int??????flags;?????????????????

???int??????header_size;???????????

???struct???node_type* h_prev;?????

???struct???node_type* h_next;?????

???struct???node_type* v_prev;?????

???struct???node_type* v_next?

?

//讀和寫序列(動態的添加和刪除元素)????????????????????????????#defineCV_SEQUENCE_FIELDS()????????????????

???CV_TREE_NODE_FIELDS(CvSeq);??????????????????????????????????????????

???int??????total;??????????

???int??????elem_size;??????

???schar*???block_max;??????

???schar*???ptr;????????????

???int??????delta_elems;????

???CvMemStorage*storage;????

???CvSeqBlock* free_blocks;??

???CvSeqBlock*first;???????

?

//定義序列結構體

typedef struct CvSeq

{

???CV_SEQUENCE_FIELDS()

}

CvSeq;

?

#defineCV_TYPE_NAME_SEQ????????????"opencv-sequence"

#defineCV_TYPE_NAME_SEQ_TREE???????"opencv-sequence-tree"

?

動態數據結構-節點(集)

(節點順序是不被保護的,他們可看成介于元素間的空隙,但被插入后就保留在該地方,判斷有元素,看MSB‘mose-significantor sign bit’的標志位)

?

//定義序列節點屬性

#defineCV_SET_ELEM_FIELDS(elem_type)??

???int?flags;????????????????????????

???struct elem_type* next_free;

?

//設置序列元素

typedef struct CvSetElem

{

???CV_SET_ELEM_FIELDS(CvSetElem)

}

CvSetElem;

?

//

#defineCV_SET_FIELDS()?????

???CV_SEQUENCE_FIELDS()????

???CvSetElem*free_elems;??

???int active_count;

?

//

typedef struct CvSet

{

???CV_SET_FIELDS()

}

CvSet;

?

?

#define CV_SET_ELEM_IDX_MASK??((1 << 26) -1)

#define CV_SET_ELEM_FREE_FLAG? (1<< (sizeof(int)*8-1))

?

//定義元素指針被設置與否

#define CV_IS_SET_ELEM( ptr )?(((CvSetElem*)(ptr))->flags >= 0)

?

動態數據結構-圖結構

?

?

?

//定義圖邊屬性

#defineCV_GRAPH_EDGE_FIELDS()?????

???intflags;?????????????????????

???floatweight;??????????????????

???struct CvGraphEdge*next[2];???

???struct CvGraphVtx* vtx[2];

?

?

//定義圖節點屬性

#defineCV_GRAPH_VERTEX_FIELDS()???

???intflags;?????????????????????

???struct CvGraphEdge* first;

?

//定義圖邊結構體

typedef struct CvGraphEdge

{

???CV_GRAPH_EDGE_FIELDS()

}

CvGraphEdge;

?

//定義圖節點結構體

typedef struct CvGraphVtx

{

???CV_GRAPH_VERTEX_FIELDS()

}

CvGraphVtx;

?

//定義二維圖

typedef struct CvGraphVtx2D

{

???CV_GRAPH_VERTEX_FIELDS()

???CvPoint2D32f* ptr;

}

CvGraphVtx2D;

?

?

?

//定義圖屬性

#define?CV_GRAPH_FIELDS()??

???CV_SET_FIELDS()?????????

???CvSet* edges;

?

//定義圖結構

typedef struct CvGraph

{

???CV_GRAPH_FIELDS()

}

CvGraph;

?

#define CV_TYPE_NAME_GRAPH "opencv-graph"

?

動態數據結構-鏈和輪廓

?

//定義鏈結構

typedef struct CvChain

{

???CV_SEQUENCE_FIELDS()

???CvPoint? origin;

}

CvChain;

?

//定義輪廓屬性

#define CV_CONTOUR_FIELDS()?

???CV_SEQUENCE_FIELDS()????

???CvRectrect;????????????

???intcolor;??????????????

???int reserved[3];

?

//定義輪廓結構體

typedef struct CvContour

{

???CV_CONTOUR_FIELDS()

}

CvContour;

?

typedef CvContour CvPoint2DSeq;

?

序列類型

?

//表示稠密序列

#defineCV_SEQ_MAGIC_VAL????????????0x42990000

#define CV_IS_SEQ(seq)

???((seq) != NULL &&(((CvSeq*)(seq))->flags &CV_MAGIC_MASK) == CV_SEQ_MAGIC_VAL)

?

//表示稀疏序列

#defineCV_SET_MAGIC_VAL????????????0x42980000

#define CV_IS_SET(set)

???((set) != NULL &&(((CvSeq*)(set))->flags &CV_MAGIC_MASK) == CV_SET_MAGIC_VAL)

?

//表示稠密序列元素位數

#defineCV_SEQ_ELTYPE_BITS??????????12

#defineCV_SEQ_ELTYPE_MASK??????????((1 << CV_SEQ_ELTYPE_BITS) - 1)

?

//

#defineCV_SEQ_ELTYPE_POINT?????????CV_32SC2?

#defineCV_SEQ_ELTYPE_CODE??????????CV_8UC1??

?

//

#defineCV_SEQ_ELTYPE_GENERIC???????0

#defineCV_SEQ_ELTYPE_PTR???????????CV_USRTYPE1

#defineCV_SEQ_ELTYPE_PPOINT????????CV_SEQ_ELTYPE_PTR?

#defineCV_SEQ_ELTYPE_INDEX?????????CV_32SC1?

#defineCV_SEQ_ELTYPE_GRAPH_EDGE????0?

#defineCV_SEQ_ELTYPE_GRAPH_VERTEX??0?

#defineCV_SEQ_ELTYPE_TRIAN_ATR?????0?

#define CV_SEQ_ELTYPE_CONNECTED_COMP0?

#defineCV_SEQ_ELTYPE_POINT3D???????CV_32FC3?

?

//表示稠密序列類型位數

#defineCV_SEQ_KIND_BITS???????2

#defineCV_SEQ_KIND_MASK???????(((1 << CV_SEQ_KIND_BITS) -1)<<CV_SEQ_ELTYPE_BITS)

?

//稠密序列的三種類型

#defineCV_SEQ_KIND_GENERIC????(0 << CV_SEQ_ELTYPE_BITS)

#defineCV_SEQ_KIND_CURVE??????(1 << CV_SEQ_ELTYPE_BITS)

#defineCV_SEQ_KIND_BIN_TREE???(2 << CV_SEQ_ELTYPE_BITS)

?

//稀疏序列的三種類型

#defineCV_SEQ_KIND_GRAPH??????(1 << CV_SEQ_ELTYPE_BITS)

#defineCV_SEQ_KIND_SUBDIV2D???(2 << CV_SEQ_ELTYPE_BITS)

?

#defineCV_SEQ_FLAG_SHIFT??????(CV_SEQ_KIND_BITS + CV_SEQ_ELTYPE_BITS)

?

//曲線序列的類型標志

#defineCV_SEQ_FLAG_CLOSED????(1 << CV_SEQ_FLAG_SHIFT)

#defineCV_SEQ_FLAG_SIMPLE????(0 << CV_SEQ_FLAG_SHIFT)

#defineCV_SEQ_FLAG_CONVEX????(0 << CV_SEQ_FLAG_SHIFT)

#defineCV_SEQ_FLAG_HOLE??????(2 << CV_SEQ_FLAG_SHIFT)

?

//圖序列的類型標志

#define CV_GRAPH_FLAG_ORIENTED (1<< CV_SEQ_FLAG_SHIFT)

?

#defineCV_GRAPH??????????????CV_SEQ_KIND_GRAPH

#defineCV_ORIENTED_GRAPH?????(CV_SEQ_KIND_GRAPH|CV_GRAPH_FLAG_ORIENTED)

?

//定義點集

#defineCV_SEQ_POINT_SET??????(CV_SEQ_KIND_GENERIC| CV_SEQ_ELTYPE_POINT)

#defineCV_SEQ_POINT3D_SET????(CV_SEQ_KIND_GENERIC| CV_SEQ_ELTYPE_POINT3D)

#defineCV_SEQ_POLYLINE???????(CV_SEQ_KIND_CURVE? |CV_SEQ_ELTYPE_POINT)

#defineCV_SEQ_POLYGON????????(CV_SEQ_FLAG_CLOSED | CV_SEQ_POLYLINE )

#defineCV_SEQ_CONTOUR????????CV_SEQ_POLYGON

#define CV_SEQ_SIMPLE_POLYGON?(CV_SEQ_FLAG_SIMPLE | CV_SEQ_POLYGON? )

?

//定義曲線鏈表

#defineCV_SEQ_CHAIN??????????(CV_SEQ_KIND_CURVE? |CV_SEQ_ELTYPE_CODE)

#defineCV_SEQ_CHAIN_CONTOUR??(CV_SEQ_FLAG_CLOSED | CV_SEQ_CHAIN)

?

//用二叉樹表示輪廓集

#defineCV_SEQ_POLYGON_TREE???(CV_SEQ_KIND_BIN_TREE? |CV_SEQ_ELTYPE_TRIAN_ATR)

?

//連接部分的序列表示

#define CV_SEQ_CONNECTED_COMP?(CV_SEQ_KIND_GENERIC? |CV_SEQ_ELTYPE_CONNECTED_COMP)

?

//整數表示的序列

#defineCV_SEQ_INDEX??????????(CV_SEQ_KIND_GENERIC?| CV_SEQ_ELTYPE_INDEX)

?

#define CV_SEQ_ELTYPE( seq)??((seq)->flags &CV_SEQ_ELTYPE_MASK)

#define CV_SEQ_KIND( seq)????((seq)->flags & CV_SEQ_KIND_MASK)

?

//標記檢測

#define CV_IS_SEQ_INDEX( seq)?????((CV_SEQ_ELTYPE(seq) == CV_SEQ_ELTYPE_INDEX)&&

????????????????????????????????????(CV_SEQ_KIND(seq) == CV_SEQ_KIND_GENERIC))

?

#define CV_IS_SEQ_CURVE( seq)?????(CV_SEQ_KIND(seq) == CV_SEQ_KIND_CURVE)

#define CV_IS_SEQ_CLOSED( seq)????(((seq)->flags & CV_SEQ_FLAG_CLOSED)!= 0)

#define CV_IS_SEQ_CONVEX( seq)????0

#define CV_IS_SEQ_HOLE( seq)??????(((seq)->flags & CV_SEQ_FLAG_HOLE)!= 0)

#define CV_IS_SEQ_SIMPLE( seq)????1

?

//類型檢測

#define CV_IS_SEQ_POINT_SET( seq )

???((CV_SEQ_ELTYPE(seq) == CV_32SC2 || CV_SEQ_ELTYPE(seq) ==CV_32FC2))

?

#define CV_IS_SEQ_POINT_SUBSET( seq )

???(CV_IS_SEQ_INDEX( seq ) || CV_SEQ_ELTYPE(seq) ==CV_SEQ_ELTYPE_PPOINT)

?

#define CV_IS_SEQ_POLYLINE( seq)??

???(CV_SEQ_KIND(seq) == CV_SEQ_KIND_CURVE&& CV_IS_SEQ_POINT_SET(seq))

?

#define CV_IS_SEQ_POLYGON( seq)??

???(CV_IS_SEQ_POLYLINE(seq) &&CV_IS_SEQ_CLOSED(seq))

?

#define CV_IS_SEQ_CHAIN( seq)??

???(CV_SEQ_KIND(seq) == CV_SEQ_KIND_CURVE&& (seq)->elem_size== 1)

?

#define CV_IS_SEQ_CONTOUR( seq )??

???(CV_IS_SEQ_CLOSED(seq) &&(CV_IS_SEQ_POLYLINE(seq) || CV_IS_SEQ_CHAIN(seq)))

?

#define CV_IS_SEQ_CHAIN_CONTOUR( seq )

???(CV_IS_SEQ_CHAIN( seq ) &&CV_IS_SEQ_CLOSED( seq ))

?

#define CV_IS_SEQ_POLYGON_TREE( seq )

???(CV_SEQ_ELTYPE (seq) ==?CV_SEQ_ELTYPE_TRIAN_ATR&&???

???CV_SEQ_KIND( seq ) ==? CV_SEQ_KIND_BIN_TREE)

?

#define CV_IS_GRAPH( seq)???

???(CV_IS_SET(seq) &&CV_SEQ_KIND((CvSet*)(seq)) == CV_SEQ_KIND_GRAPH)

?

#define CV_IS_GRAPH_ORIENTED( seq)??

???(((seq)->flags &CV_GRAPH_FLAG_ORIENTED) != 0)

?

#define CV_IS_SUBDIV2D( seq )?

???(CV_IS_SET(seq) &&CV_SEQ_KIND((CvSet*)(seq)) == CV_SEQ_KIND_SUBDIV2D)

?

序列的讀/寫操作????????????????????????????????

?

//定義序列寫的屬性

#defineCV_SEQ_WRITER_FIELDS()???

???int?????????header_size;?????????????????????????????????????

???CvSeq*??????seq;??????????????????

???CvSeqBlock*?block;???????????????????????

???schar*??????ptr;?????????????????

???schar*??????block_min;?

???schar*??????block_max;?

?

//定義序列寫結構體

typedef struct CvSeqWriter

{

???CV_SEQ_WRITER_FIELDS()

}

CvSeqWriter;

?

?

//定義序列讀的屬性

#defineCV_SEQ_READER_FIELDS()?????????????????????????????????????

???int?????????header_size;??????????????????????????????????????

???CvSeq*??????seq;???????????????????

???CvSeqBlock*?block;????????????????????????

???schar*??????ptr;????????

???schar*??????block_min;?

???schar*??????block_max;??????

???int?????????delta_index;?????

???schar*??????prev_elem;?

?

?

//定義序列讀的結構體

typedef struct CvSeqReader

{

???CV_SEQ_READER_FIELDS()

}

CvSeqReader;

?

對序列的操作

?

#define? CV_SEQ_ELEM( seq, elem_type,index)???????????????????

?

(??assert(sizeof((seq)->first[0]) == sizeof(CvSeqBlock)&&?????

???(seq)->elem_size ==sizeof(elem_type)),?????????????????????

???(elem_type*)((seq)->first&& (unsigned)index<??????????????

???(unsigned)((seq)->first->count)????????????????????????????

???(seq)->first->data + (index) *sizeof(elem_type):??????????

???cvGetSeqElem( (CvSeq*)(seq), (index) )))

#define CV_GET_SEQ_ELEM( elem_type, seq, index ) CV_SEQ_ELEM((seq), elem_type, (index) )

?

//在序列中增加元素

#define CV_WRITE_SEQ_ELEM_VAR( elem_ptr, writer)????

{????????????????????????????????????????????????????

???if( (writer).ptr >= (writer).block_max)?????????

???{????????????????????????????????????????????????

???????cvCreateSeqBlock(&writer);??????????????????

???}????????????????????????????????????????????????

???memcpy((writer).ptr, elem_ptr,(writer).seq->elem_size);

???(writer).ptr +=(writer).seq->elem_size;?????????

}

?

#define CV_WRITE_SEQ_ELEM( elem, writer)????????????

{????????????????????????????????????????????????????

???assert( (writer).seq->elem_size == sizeof(elem));

???if( (writer).ptr >= (writer).block_max)?????????

???{????????????????????????????????????????????????

???????cvCreateSeqBlock(&writer);??????????????????

???}????????????????????????????????????????????????

???assert( (writer).ptr <= (writer).block_max -sizeof(elem));

???memcpy((writer).ptr, &(elem),sizeof(elem));?????

???(writer).ptr +=sizeof(elem);????????????????????

}

?

?

//向前移動讀序列位置

#define CV_NEXT_SEQ_ELEM( elem_size, reader)????????????????

{????????????????????????????????????????????????????????????

???if( ((reader).ptr += (elem_size)) >=(reader).block_max )

???{????????????????????????????????????????????????????????

???????cvChangeSeqBlock( &(reader), 1);????????????????????

???}????????????????????????????????????????????????????????

}

?

?

//向前移動讀序列位置

#define CV_PREV_SEQ_ELEM( elem_size, reader)???????????????

{???????????????????????????????????????????????????????????

???if( ((reader).ptr -= (elem_size)) <(reader).block_min )

???{???????????????????????????????????????????????????????

???????cvChangeSeqBlock( &(reader), -1);??????????????????

???}???????????????????????????????????????????????????????

}

?

//讀序列中元素并向前移動讀位置

#define CV_READ_SEQ_ELEM( elem, reader)??????????????????????

{?????????????????????????????????????????????????????????????

???assert( (reader).seq->elem_size ==sizeof(elem));?????????

???memcpy( &(elem), (reader).ptr,sizeof((elem)));???????????

???CV_NEXT_SEQ_ELEM( sizeof(elem), reader)??????????????????

}

?

//讀序列中元素并向前移動讀位置

#define CV_REV_READ_SEQ_ELEM( elem, reader)????????????????????

{???????????????????????????????????????????????????????????????

???assert( (reader).seq->elem_size ==sizeof(elem));???????????

???memcpy(&(elem), (reader).ptr,sizeof((elem)));??????????????

???CV_PREV_SEQ_ELEM( sizeof(elem), reader)????????????????????

}

?

?

#define CV_READ_CHAIN_POINT( _pt, reader)?????????????????????????????

{??????????????????????????????????????????????????????????????????????

???(_pt) =(reader).pt;???????????????????????????????????????????????

???if( (reader).ptr)?????????????????????????????????????????????????

???{??????????????????????????????????????????????????????????????????

???????CV_READ_SEQ_ELEM( (reader).code,(reader));????????????????????

???????assert( ((reader).code & ~7) == 0);???????????????????????????

???????(reader).pt.x +=(reader).deltas[(int)(reader).code][0];???????

???????(reader).pt.y +=(reader).deltas[(int)(reader).code][1];???????

???}??????????????????????????????????????????????????????????????????

}

?

#define CV_CURRENT_POINT( reader )?(*((CvPoint*)((reader).ptr)))

#define CV_PREV_POINT( reader)????(*((CvPoint*)((reader).prev_elem)))

?

//讀邊序列

#define CV_READ_EDGE( pt1, pt2, reader)??????????????

{?????????????????????????????????????????????????????

???assert( sizeof(pt1) == sizeof(CvPoint)&&?????????

???????????sizeof(pt2) == sizeof(CvPoint)&&?????????

???????????reader.seq->elem_size == sizeof(CvPoint));

???(pt1) = CV_PREV_POINT( reader);??????????????????

???(pt2) = CV_CURRENT_POINT( reader);???????????????

???(reader).prev_elem =(reader).ptr;????????????????

???CV_NEXT_SEQ_ELEM( sizeof(CvPoint),(reader));?????

}

?

?

對序列的操作-圖的微操作

?

?

//返回給定頂點的圖邊緣????????????????????????????

#define? CV_NEXT_GRAPH_EDGE( edge,vertex )

????(assert((edge)->vtx[0] == (vertex) ||(edge)->vtx[1] ==(vertex)),?

?????(edge)->next[(edge)->vtx[1] ==(vertex)])

?

?

保持數據結構的連續性的說明

?

//文件存儲的“黑箱”定義

typedef struct CvFileStorage CvFileStorage;

?

//存儲標記

#defineCV_STORAGE_READ?????????0

#defineCV_STORAGE_WRITE????????1

#defineCV_STORAGE_WRITE_TEXT???CV_STORAGE_WRITE

#define CV_STORAGE_WRITE_BINARY?CV_STORAGE_WRITE

#defineCV_STORAGE_APPEND???????2

?

//屬性列表

typedef struct CvAttrList

{

???const char**attr;????????

???struct CvAttrList*next;??

}

CvAttrList;

?

CV_INLINE CvAttrList cvAttrList( const char** attrCV_DEFAULT(NULL),

????????????????????????????????CvAttrList* next CV_DEFAULT(NULL) )

{

???CvAttrList l;

???l.attr = attr;

???l.next = next;

?

???return l;

}

?

struct CvTypeInfo;

?

#defineCV_NODE_NONE???????0

#defineCV_NODE_INT????????1

#defineCV_NODE_INTEGER????CV_NODE_INT

#defineCV_NODE_REAL???????2

#defineCV_NODE_FLOAT??????CV_NODE_REAL

#defineCV_NODE_STR????????3

#defineCV_NODE_STRING?????CV_NODE_STR

#defineCV_NODE_REF????????4

#defineCV_NODE_SEQ????????5

#defineCV_NODE_MAP????????6

#defineCV_NODE_TYPE_MASK??7

?

#define CV_NODE_TYPE(flags)? ((flags)& CV_NODE_TYPE_MASK)

?

?

#defineCV_NODE_FLOW???????8

#defineCV_NODE_USER???????16

#defineCV_NODE_EMPTY??????32

#defineCV_NODE_NAMED??????64

?

#defineCV_NODE_IS_INT(flags)???????(CV_NODE_TYPE(flags) == CV_NODE_INT)

#defineCV_NODE_IS_REAL(flags)??????(CV_NODE_TYPE(flags) == CV_NODE_REAL)

#defineCV_NODE_IS_STRING(flags)????(CV_NODE_TYPE(flags) == CV_NODE_STRING)

#defineCV_NODE_IS_SEQ(flags)???????(CV_NODE_TYPE(flags) == CV_NODE_SEQ)

#defineCV_NODE_IS_MAP(flags)???????(CV_NODE_TYPE(flags) == CV_NODE_MAP)

#define CV_NODE_IS_COLLECTION(flags) (CV_NODE_TYPE(flags)>= CV_NODE_SEQ)

#defineCV_NODE_IS_FLOW(flags)??????(((flags) & CV_NODE_FLOW) != 0)

#defineCV_NODE_IS_EMPTY(flags)?????(((flags) & CV_NODE_EMPTY) != 0)

#defineCV_NODE_IS_USER(flags)??????(((flags) & CV_NODE_USER) != 0)

#defineCV_NODE_HAS_NAME(flags)?????(((flags) & CV_NODE_NAMED) != 0)

?

#define CV_NODE_SEQ_SIMPLE 256

#define CV_NODE_SEQ_IS_SIMPLE(seq) (((seq)->flags& CV_NODE_SEQ_SIMPLE) != 0)

?

typedef struct CvString

{

???int len;

???char* ptr;

}

CvString;

?

//所有的元素名字以哈希表中,增加搜索速度

typedef struct CvStringHashNode{

???unsigned hashval;

???CvString str;

???struct CvStringHashNode* next;

}

CvStringHashNode;

?

typedef struct CvGenericHash CvFileNodeHash;

?

?

typedef struct CvFileNode

{

???int tag;

???struct CvTypeInfo* info;

???union

???{

???????double f;

???????inti;???

???????CvString str;

???????CvSeq* seq;

???????CvFileNodeHash* map;

???} data;

}

CvFileNode;

?

#ifdef __cplusplus

extern "C" {

#endif

typedef int (CV_CDECL *CvIsInstanceFunc)( const void* struct_ptr);

typedef void (CV_CDECL *CvReleaseFunc)( void** struct_dblptr);

typedef void* (CV_CDECL *CvReadFunc)( CvFileStorage* storage,CvFileNode* node );

typedef void (CV_CDECL *CvWriteFunc)( CvFileStorage* storage,const char* name,

?????????????????????????????????????const void* struct_ptr, CvAttrList attributes );

typedef void* (CV_CDECL *CvCloneFunc)( const void* struct_ptr);

#ifdef __cplusplus

}

#endif

?

typedef struct CvTypeInfo

{

???int flags;

???int header_size;

???struct CvTypeInfo* prev;

???struct CvTypeInfo* next;

???const char* type_name;

???CvIsInstanceFunc is_instance;

???CvReleaseFunc release;

???CvReadFunc read;

???CvWriteFunc write;

???CvCloneFunc clone;

}

CvTypeInfo;

?

?

系統數據類型

?

typedef struct CvPluginFuncInfo

{

???void** func_addr;

???void* default_func_addr;

???const char* func_names;

???int search_modules;

???int loaded_from;

}

CvPluginFuncInfo;

?

typedef struct CvModuleInfo

{

???struct CvModuleInfo* next;

???const char* name;

???const char* version;

???CvPluginFuncInfo* func_tab;

}

CvModuleInfo;

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的opencv2.2.0源代码(include文件)分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

四虎www com| 亚洲精品自在在线观看 | 天天操天天弄 | 国产成人亚洲在线观看 | 久久美女免费视频 | 美女黄频在线观看 | 国产高清成人 | 在线观看视频 | 精品一区二区在线播放 | 亚洲一区二区精品视频 | 久久久久久久久久电影 | 久久99精品久久久久婷婷 | 欧美xxxxx在线视频 | 在线观看中文字幕第一页 | 色天天中文 | 亚洲人av免费网站 | 黄色a在线 | 人人爽人人 | 久久综合久久综合这里只有精品 | 免费在线观看成年人视频 | 久久艹免费 | 俺要去色综合狠狠 | 亚洲女同videos | 国产色影院 | 日韩免费av在线 | 激情婷婷亚洲 | 免费福利视频导航 | 综合久久影院 | 麻豆免费视频网站 | 国产精品一区二区美女视频免费看 | 一区二区三区精品久久久 | 日韩免费高清 | 国产一级在线观看 | 国产区精品视频 | 成人av播放| 91视频这里只有精品 | 天堂在线一区二区三区 | 午夜精品久久久久久中宇69 | 欧美一级视频免费 | 国产精品久久久一区二区三区网站 | 久久午夜精品 | 精品一区三区 | 一级黄色片在线播放 | 999亚洲国产996395 | 久久久精品99 | 亚洲美女视频在线观看 | 超碰国产在线观看 | 九九亚洲视频 | 欧美成人手机版 | 久久99最新地址 | 色婷婷狠狠五月综合天色拍 | 亚洲九九 | 欧美特一级 | 蜜臀av网址 | 国产精品1区2区3区 久久免费视频7 | 99视频播放 | 在线视频 区 | 三上悠亚一区二区在线观看 | 欧美激情综合色 | 欧美激情奇米色 | 中文字幕在线视频一区 | 精品视频免费播放 | 欧美日韩精品区 | 欧美激情第八页 | 中文字幕日韩国产 | 久久爱影视i | 国精产品999国精产 久久久久 | av女优中文字幕在线观看 | 黄色日本免费 | 91精品国产一区二区三区 | 久草视频在线新免费 | 国产老太婆免费交性大片 | 天天色欧美 | 男女啪啪视屏 | 特级片免费看 | 丁香六月天 | 国产一区二区三区免费在线观看 | 国产男女爽爽爽免费视频 | 97在线精品国自产拍中文 | 国产明星视频三级a三级点| 00av视频| 999成人精品| 久久国产手机看片 | 亚洲一区二区三区毛片 | 国产精品成人自拍 | 91av综合 | 日日夜夜操av | 波多野结衣一区二区 | 欧美中文字幕久久 | 久久久精品免费看 | 久久成人精品电影 | 色婷婷在线视频 | 婷婷五天天在线视频 | 国产日本亚洲高清 | 久久线视频 | 在线看污网站 | 右手影院亚洲欧美 | 精品久久久亚洲 | 热re99久久精品国产66热 | 免费精品在线视频 | 亚洲精品视频久久 | 国产人成一区二区三区影院 | 亚洲五月婷婷 | 97精品久久 | 人人澡人人爱 | 97超碰免费在线观看 | 久99久中文字幕在线 | 免费视频成人 | 91亚洲在线 | 中国一级片在线观看 | 亚洲综合激情五月 | 中文字幕在线免费观看视频 | 久久艹久久 | 91完整版在线观看 | 色综合天天综合网国产成人网 | 美女黄视频免费看 | 深夜福利视频一区二区 | 欧美亚洲国产一卡 | 日韩视频在线观看免费 | 欧美一区二区三区在线观看 | www.com.日本一级 | 日本久久中文字幕 | 国产伦理一区二区三区 | 国产精品久久久久久一二三四五 | 久久久久久久久久免费 | 国产高清综合 | 97精品国产| 91av播放| 综合色亚洲 | v片在线看 | 国内精品久久久久久久久久久 | www亚洲国产| 久久99精品视频 | 色吊丝在线永久观看最新版本 | 久久国产a | 一区二区三区在线视频111 | 亚洲毛片在线观看. | 精品久久久久国产 | 黄色aaa级片 | 欧美精品免费一区二区 | 激情综合婷婷 | 激情视频免费观看 | 视频成人| 国产特级毛片aaaaaaa高清 | 欧美韩国日本在线 | 亚洲视频1区2区 | 精品一区免费 | www免费看片com | 国产欧美精品一区二区三区 | 五月综合色 | 男女精品久久 | 午夜av剧场 | 国产成人精品国内自产拍免费看 | 97人人超| 国产一级性生活视频 | 国产小视频91 | 欧洲激情在线 | 欧美影院久久 | 激情五月***国产精品 | 久久免费看 | 婷婷丁香综合 | 97成人超碰 | 成人av网站在线播放 | 国产高清视频在线免费观看 | 久久线视频 | av韩国在线 | 又爽又黄在线观看 | 青青草国产成人99久久 | 色a资源在线 | 欧洲激情综合 | 精品国产欧美一区二区三区不卡 | 人人草天天草 | 国产色爽 | 欧美精品久久久久久久久久久 | 久久视频精品 | 亚洲国产黄色片 | 久久免费黄色网址 | 亚洲综合精品在线 | 欧美精品资源 | 久久精品99国产精品日本 | 中国一级片在线播放 | 久久精选视频 | 日一日干一干 | 国产成人精品一区二区三区福利 | 国产精品女人网站 | 欧美国产一区在线 | 99九九视频 | 91麻豆精品国产91 | 国产精品青青 | 日韩免费小视频 | 国产资源精品在线观看 | 欧美性生爱 | 欧美精品xxx | 亚洲电影院 | 99成人免费视频 | 五月天亚洲综合 | 免费色婷婷 | 成人黄色电影在线 | 久久精品一区二区 | 成年免费在线视频 | 精品中文字幕在线播放 | 中文字幕观看视频 | 国产精品久久久久久久免费大片 | 久久久久久蜜桃一区二区 | 丁香六月婷婷开心 | 国产99久久久国产精品 | 日本少妇久久久 | 色国产在线 | 免费看国产a | 毛片网免费 | 国产粉嫩在线 | 黄色软件在线观看视频 | 97人人模人人爽人人喊中文字 | 欧美aaa级片 | 91视频在线| 91女子私密保健养生少妇 | 免费看色的网站 | 久久国产精品第一页 | 久久精品亚洲 | 国产成人在线免费观看 | 美女网站视频色 | 在线观看av国产 | 国产精品自在欧美一区 | 99精品在线播放 | 欧美日韩视频一区二区三区 | 亚洲欧美成人综合 | 国产午夜三级一二三区 | 午夜av激情 | 久久午夜精品视频 | 高潮久久久 | 国产一级做a | 黄色日本免费 | 97超碰成人 | 欧美日韩网站 | 免费视频18| 在线观看视频91 | 92中文资源在线 | 亚洲精品456在线播放 | 国产精选在线 | 午夜av在线电影 | 国产精品丝袜在线 | 中日韩免费视频 | 天天干天天在线 | 午夜色场| 黄色小说网站在线 | 日本黄色免费播放 | 91精品国产乱码久久桃 | 久久艹99| 狠狠色丁香久久综合网 | 久久免费视频网 | 97成人在线观看视频 | 美女黄视频免费看 | 国产一级在线免费观看 | 久久香蕉国产 | 日韩高清免费在线 | 亚洲精品成人av在线 | 波多野结衣在线观看一区 | 亚洲午夜久久久久久久久 | 国产成人三级在线播放 | 成人免费在线视频观看 | 亚洲欧洲av在线 | 日本精品一区二区三区在线播放视频 | 国产成人久久av | 激情综合五月天 | 免费看污网站 | 亚洲国产精品成人女人久久 | 国产98色在线 | 日韩 | 欧美一区二区三区在线视频观看 | 青春草免费在线视频 | 手机av资源 | 久久无码精品一区二区三区 | 日韩免费b | 麻豆传媒视频在线播放 | 91视频久久久 | 亚洲成人精品 | 99视频在线免费播放 | 玖玖在线看 | 日韩欧美亚州 | 成人午夜电影在线观看 | 亚洲成av| 国产999免费视频 | 97夜夜澡人人爽人人免费 | 日本一区二区高清不卡 | 字幕网资源站中文字幕 | 四虎在线观看视频 | 国产亚洲精品成人av久久影院 | 99久久精品免费一区 | 人人艹视频 | 久草在线资源网 | 五月婷婷六月丁香 | 伊人五月婷 | 欧美日韩中文字幕综合视频 | 欧美久久久久久久久久久 | 国产成人在线免费观看 | 日韩精品一区二区三区三炮视频 | 亚洲精品一区二区三区新线路 | av色网站| 香蕉视频在线看 | 天堂av网站| 日本中文字幕久久 | 亚洲污视频 | 精品国产视频一区 | 91成年人在线观看 | 久久免费国产 | 精品视频免费久久久看 | 国产日韩欧美在线免费观看 | 日韩字幕在线 | 日韩高清一区 | 日韩在线免费视频观看 | 一区二区三区四区免费视频 | 天天干,天天操 | 人人爱夜夜操 | 91人人射 | 久久久久国产精品一区二区 | 国内精品视频久久 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 久久久久久久久久久久久9999 | 欧美一级片播放 | 亚洲va欧美va国产va黑人 | 国产精品大片免费观看 | 五月婷婷视频 | 91av视频| 亚洲国产日韩精品 | 婷婷在线播放 | 97在线视频观看 | 国产精品v a免费视频 | 成人综合婷婷国产精品久久免费 | 久久99电影 | 欧美日韩在线观看视频 | 国产成人一区二区三区在线观看 | 麻豆高清免费国产一区 | 国产精品一区二区在线 | 日韩精品中文字幕在线观看 | 国产玖玖精品视频 | 美女视频黄是免费的 | 国产精品久久一 | 四虎成人精品永久免费av | 久久草草影视免费网 | 国产精品久久久毛片 | 国产成人综合精品 | 激情婷婷色| 天天插天天爱 | 国产精品片 | 天天摸天天舔 | 在线小视频你懂的 | 国产婷婷vvvv激情久 | 特级毛片在线观看 | 人人爽人人 | 成人啊 v | 久久免费视屏 | 激情综合色综合久久综合 | 日韩xxxbbb | 精品一区二区在线看 | 亚洲精品视频播放 | 日韩av高潮 | 免费网站污| 在线免费亚洲 | 欧美二区三区91 | 狠狠色狠狠综合久久 | 国产网红在线观看 | 国产精品嫩草影院99网站 | 992tv在线观看网站 | 国产女人40精品一区毛片视频 | 丁香 久久 综合 | 欧美韩日在线 | www黄| 奇米777777 | 成年人免费在线播放 | 日韩在线免费小视频 | 日韩欧美有码在线 | 99热这里只有精品国产首页 | 91大片成人网 | 国产成人精品一区二区三区在线 | 国产一区二区三区高清播放 | www.久久久精品 | av高清一区二区三区 | 91精品国产91热久久久做人人 | 久久免费的视频 | 97人人视频 | 婷婷色视频 | 丁香 久久 综合 | 国产精品1000 | 国产91精品一区二区麻豆网站 | 永久免费毛片在线观看 | 国产一区二区精品在线 | 91精品在线观看视频 | 99re视频在线观看 | 亚洲精品女 | 婷婷久久五月天 | 香蕉色综合 | 一区二区视频欧美 | 久久久亚洲影院 | www最近高清中文国语在线观看 | 亚洲狠狠丁香婷婷综合久久久 | 天天综合网~永久入口 | 国产原创在线 | 91一区二区三区在线观看 | 亚洲精品国产拍在线 | 婷婷色狠狠 | 国产视频一区二区在线播放 | 日韩国产欧美视频 | 日韩视频一区二区在线观看 | 日韩欧美电影 | 99国产情侣在线播放 | 欧美在线观看视频一区二区三区 | 国产精品理论在线观看 | 狠狠综合久久 | 黄色成人在线 | 国产精品永久久久久久久www | 91在线视频 | 亚洲aⅴ一区二区三区 | 久久中文字幕导航 | 黄色免费网站下载 | 日韩欧美99 | 国产亚洲综合性久久久影院 | 成人全视频免费观看在线看 | 免费下载高清毛片 | 免费观看一级 | 久久综合中文色婷婷 | 亚洲 综合 国产 精品 | 久久久久久久久精 | 日韩在线免费观看视频 | 99人久久精品视频最新地址 | 国产精品va最新国产精品视频 | 久久精品91久久久久久再现 | 日韩精品91偷拍在线观看 | a精品视频 | 91麻豆精品国产 | 久久久免费精品视频 | 欧美性生活一级片 | 日韩欧在线 | 99在线国产 | 亚洲国产精品电影 | 在线免费日韩 | 99免在线观看免费视频高清 | 日韩丝袜在线观看 | 麻豆久久久久 | 999国内精品永久免费视频 | 五月激情综合婷婷 | 久久国产成人午夜av影院潦草 | 天天干 天天摸 天天操 | 日本久久久影视 | 国产免费观看高清完整版 | 国产精品一区一区三区 | 精品少妇一区二区三区在线 | 国产a级精品| 成人a视频在线观看 | 午夜av网站 | 欧亚日韩精品一区二区在线 | 最新av电影网址 | 久久视频免费观看 | 成人在线小视频 | 在线免费黄色av | 久久久久久久国产精品影院 | 久久人人插 | 精品视频在线免费观看 | 人人澡人摸人人添学生av | 97精品视频在线播放 | 99久精品视频 | 国产视频久久 | 亚洲视频免费在线观看 | 国产网站色 | 久久成人久久 | 欧美a级在线免费观看 | 国产日韩欧美网站 | 三级免费黄色 | 成人小视频在线播放 | 深爱激情五月网 | 久久97精品 | 少妇搡bbb| 最近中文国产在线视频 | 亚洲成av | 91探花系列在线播放 | 九九九电影免费看 | 精品久久久久久久久久久久久 | 精品国产乱码一区二区三区在线 | 久久久2o19精品| 六月婷婷久香在线视频 | 免费福利视频网站 | 亚洲综合在线视频 | 国产精品自在欧美一区 | 激情av在线资源 | 成人av久久| 国产成人av网址 | 深爱五月网 | 8x成人免费视频 | 91av福利视频 | 亚洲六月丁香色婷婷综合久久 | 午夜免费福利视频 | 精品视频成人 | 西西444www大胆高清图片 | 国产一区成人在线 | 国内精品久久久久久久久久 | 亚洲成年人在线播放 | 欧美成人区 | 99免费观看视频 | 国产日韩欧美在线播放 | 久久亚洲精品国产亚洲老地址 | 国产精品免费久久久久 | av黄色国产| 国产激情免费 | 亚洲午夜精品一区二区三区电影院 | 精品一区二区免费视频 | 免费观看第二部31集 | 国产美女视频免费 | 成人精品久久 | 伊人黄色网 | 日韩免费一区二区三区 | 久久免费电影 | 91精品爽啪蜜夜国产在线播放 | 国产理论一区二区三区 | 三级黄色欧美 | av高清一区二区三区 | 国产视频精品久久 | 狠狠狠色狠狠色综合 | 日韩欧美亚州 | 黄色毛片在线看 | 日本三级人妇 | 国产激情免费 | 久久亚洲成人网 | 在线观看一区二区精品 | 国产aa免费视频 | 免费能看的av | 国产在线观看免费av | 国产 在线观看 | 天天色综合久久 | 九九色网 | 久草精品国产 | 97免费视频在线 | 精品久久一区二区 | 久久久www成人免费精品张筱雨 | 亚洲精品视频在线播放 | 久久久久国产成人免费精品免费 | 国产高清视频免费观看 | 色综合久久久久综合99 | 综合在线观看色 | 欧美日韩免费观看一区=区三区 | av大片免费看 | 中文字幕超清在线免费 | 日韩成人在线一区二区 | 色综合亚洲精品激情狠狠 | 久久影视一区 | 亚洲aⅴ免费在线观看 | 中文字幕一区二区三区精华液 | 亚洲精品9 | 天天做天天爱天天综合网 | 精品久久五月天 | 久久久综合精品 | 日韩在线欧美在线 | 日韩欧美第二页 | 中文字幕在线观看你懂的 | 深爱激情开心 | 一区二区三区动漫 | 欧美ⅹxxxxxx| 天堂视频中文在线 | 国产精品视频最多的网站 | 精品国产乱码久久久久久三级人 | 日韩免费视频在线观看 | 麻豆视频一区二区 | 国产精品一区二区久久国产 | 亚洲国产精品久久 | 午夜精品久久久久久久99 | 国产精品久久精品国产 | 欧美一级视频免费 | 国产成人99av超碰超爽 | 国产 日韩 在线 亚洲 字幕 中文 | 99精品视频在线 | 国产精品成| 96精品高清视频在线观看软件特色 | 在线高清av | 在线观看中文字幕一区 | av在线播放快速免费阴 | 精品视频在线视频 | 97在线精品国自产拍中文 | 久久精品视频国产 | 色综合久久久网 | 国产美女久久久 | 色综合天天视频在线观看 | 韩国在线视频一区 | av7777777| 日韩在线 一区二区 | 婷婷国产在线 | 日韩久久一区 | 狠狠躁18三区二区一区ai明星 | 亚洲综合视频在线播放 | 超碰97国产精品人人cao | 精选久久 | 免费a视频在线 | 又污又黄的网站 | 国产青青青 | 国产免费影院 | 香蕉网在线 | 日韩av中文字幕在线 | 天天舔夜夜操 | 特级毛片在线 | 九九一级片 | 精品国产区在线 | 91网址在线 | 成人av在线看 | 全黄色一级片 | av免费观看网址 | 亚洲天堂自拍视频 | 蜜桃av观看 | 国内成人综合 | 一区二区三区电影在线播 | 国产精品v a免费视频 | 日韩av片无码一区二区不卡电影 | 夜添久久精品亚洲国产精品 | 中文字幕有码在线播放 | 97超碰人人澡人人爱学生 | 日韩视频精品在线 | av解说在线| 九九色网| 九九热在线视频免费观看 | 97在线视频观看 | 最近免费中文字幕mv在线视频3 | 在线看日韩 | 国产美腿白丝袜足在线av | 精品国产一区二区三区免费 | 国产91综合一区在线观看 | 91资源在线播放 | 91综合视频在线观看 | av7777777 | 国产精品欧美久久久久无广告 | 欧美日韩二区三区 | 97视频在线观看网址 | 国产美女视频免费观看的网站 | 99在线观看视频网站 | 成人av直播 | 精品免费视频 | 日批视频国产 | 人人澡澡人人 | 91麻豆文化传媒在线观看 | 九九99| www.黄色| 免费色网站 | 97超碰在线免费 | 久久国产精品久久w女人spa | 亚洲视屏| 亚洲视频axxx | 天天射天天干天天 | 一区二区三区在线电影 | 亚洲精品乱码久久久久久蜜桃动漫 | 精品黄色在线观看 | 精品国产自在精品国产精野外直播 | 成人影音av | 婷婷久久精品 | 日韩激情影院 | 日韩精品免费一区 | 在线不卡视频 | 中文字幕在线观看的网站 | 中文字幕 国产视频 | 国产拍揄自揄精品视频麻豆 | 中文字幕乱码亚洲精品一区 | 五月婷婷狠狠 | 欧美一级日韩三级 | 黄色三级av | 亚洲男男gⅴgay双龙 | 色偷偷88888欧美精品久久久 | 久久精品国产精品 | 久久综合影视 | 亚洲精品2区| 九九热只有这里有精品 | 天天综合网入口 | av免费网站在线观看 | 国产呻吟在线 | 久久久久www | 国内精品免费久久影院 | 亚洲91精品在线观看 | 欧美综合国产 | 国际精品久久久久 | 欧美激情另类 | 国产一级视频在线观看 | 色999视频 | 午夜av免费看 | 国产精品mv | 天天摸天天操天天爽 | 久久久精品国产免费观看一区二区 | ww视频在线观看 | 免费看十八岁美女 | 成人免费一区二区三区在线观看 | a黄色 | 国产精品综合在线 | 在线中文字幕播放 | 日韩免费观看视频 | 国产色婷婷在线 | 日韩三级免费观看 | 91精品国产91久久久久福利 | 亚洲一区免费在线 | 欧美性成人 | 一区二区三区在线观看中文字幕 | 婷婷综合视频 | 亚洲va欧美va | 91九色在线 | 91午夜精品 | 欧美一级片免费播放 | 九九视频免费观看视频精品 | 少妇bbb搡bbbb搡bbbb′ | 国产精品1000 | 天天干一干 | 日韩精品久久久久久久电影竹菊 | 日韩免费福利 | 中文字幕av免费在线观看 | 黄色成人免费电影 | 亚洲夜夜综合 | 久久嗨| 美女一二三区 | 蜜桃视频日韩 | 亚洲 在线 | 最近高清中文在线字幕在线观看 | www久久国产 | 亚洲成人资源在线 | 一区二区 不卡 | 国产成人精品一区一区一区 | 狠狠色噜噜狠狠狠合久 | 久久久久久久久综合 | www免费 | 91精选在线观看 | 久久精品五月 | 欧美日韩视频在线播放 | 四虎国产 | 国产专区第一页 | 中文字幕亚洲在线观看 | 91丨九色丨高潮丰满 | 久久久麻豆精品一区二区 | 亚洲经典视频 | 国产人成精品一区二区三 | 狠狠色丁香久久婷婷综 | www日韩在线 | 欧美性超爽 | 97国产精品免费 | 日韩天堂网 | 精品成人免费 | 99久久久久久久久久 | 欧美成人日韩 | 免费在线观看中文字幕 | 中文字幕第一页在线 | www.夜夜骑.com | 热热热热热色 | 国产一级免费观看 | 国产在线高清精品 | 国产成人福利片 | 中文字幕高清视频 | www国产亚洲精品久久麻豆 | 精品999在线| 8x8x在线观看视频 | 视频一区二区在线 | 免费h视频| 人人添人人澡人人澡人人人爽 | 国产精品久久久久久久免费观看 | 国产精品综合在线 | 96久久久| av一区在线 | 视频三区| 国产一级在线视频 | 999国内精品永久免费视频 | 久久人人97超碰国产公开结果 | 国产在线不卡 | 99久久一区 | 久久精品精品电影网 | 91人人视频在线观看 | 毛片黄色一级 | 蜜臀av.com| 日本精品中文字幕在线观看 | 97色涩 | 九九综合久久 | 在线视频 一区二区 | 日韩在线视频免费播放 | 久久久男人的天堂 | 九九精品视频在线看 | 一级做a爱片性色毛片www | 欧美日韩国产精品一区 | 日韩中出在线 | 91成人网在线观看 | 久久免费看 | 日韩在线网址 | av+在线播放在线播放 | 成人免费视频网 | 日韩中字在线 | 日韩免费高清在线 | 91伊人影院 | 天天干天天玩天天操 | 国产精品av电影 | 日日夜夜综合 | 午夜久久网站 | 91高清视频免费 | 久久久99精品免费观看乱色 | 97国产大学生情侣酒店的特点 | 91豆花在线观看 | 另类老妇性bbwbbw高清 | 人人看看人人 | 国产在线精品国自产拍影院 | 四虎影院在线观看av | 久久久免费少妇 | 亚洲精品午夜aaa久久久 | 久久久影院一区二区三区 | 国产视频亚洲精品 | 日韩精品久久中文字幕 | 亚洲综合在线播放 | 一级久久精品 | 免费精品视频在线 | 天天在线免费视频 | 亚洲欧美日韩一二三区 | 操操综合| 色综合天天射 | 99精品国产一区二区 | 国产色一区 | 亚洲女同videos | 欧美性色黄大片在线观看 | 人人爽人人 | 青青草国产免费 | 狠狠色丁香婷婷综合久小说久 | 亚洲 综合 专区 | 91精品久久久久久久久久入口 | 国产v亚洲v | 久久免费电影 | 中文字幕日韩有码 | 又粗又长又大又爽又黄少妇毛片 | 黄色在线网站噜噜噜 | jizzjizzjizz亚洲 | 亚洲精品视频第一页 | 97超级碰碰| 射射射综合网 | 国产在线视频导航 | a天堂中文在线 | 99视频精品免费观看, | 国产视频日韩视频欧美视频 | 看黄色.com | 免费在线a | 国内免费的中文字幕 | 免费观看www7722午夜电影 | 亚在线播放中文视频 | 亚洲不卡av一区二区三区 | 国产精品久久久久影院日本 | 91精品久久香蕉国产线看观看 | 一区二区三区在线看 | 亚洲区精品视频 | 美女在线观看av | 欧美日韩精品在线一区二区 | 欧美日韩视频一区二区三区 | 在线观看中文字幕网站 | 久久99久久99精品免观看软件 | 天天干.com | 婷婷 综合 色 | 欧美最新大片在线看 | 亚洲精品国产精品乱码在线观看 | 欧美成人日韩 | 国产在线中文字幕 | 久久大片| 最新三级在线 | 婷婷激情在线 | 国产精品一区免费在线观看 | 日本丶国产丶欧美色综合 | 成年人国产视频 | 伊人色**天天综合婷婷 | 精品国产人成亚洲区 | 天天干,天天干 | 亚洲另类视频在线 | 欧美另类xxxxx | 麻豆成人网 | 久久午夜羞羞影院 | 在线a视频 | 伊人影院99| 国产亚洲欧美精品久久久久久 | 精品国产一区二区三区四区在线观看 | www.五月婷 | 97视频在线免费播放 | 成人在线视频你懂的 | 久久久91精品国产一区二区三区 | 国产高清无av久久 | 一本一道久久a久久精品 | 久久福利剧场 | 午夜精品一区二区三区四区 | 在线中文字幕观看 | 狠狠久久| 国产午夜精品视频 | 91尤物国产尤物福利在线播放 | 久久久www成人免费精品 | 日韩特级毛片 | 日韩久久精品一区二区三区 | 欧美精品一区二区蜜臀亚洲 | 午夜av一区二区三区 | 国产免费视频在线 | 欧美aa在线| 99免费看片| 国产一区二区三区久久久 | 伊人五月天婷婷 | 久久成人精品电影 | 国产小视频在线观看免费 | 66av99精品福利视频在线 | 日本中文不卡 | 999在线视频 | 麻豆视频免费在线播放 | 麻豆传媒视频在线 | 丁香婷婷激情国产高清秒播 | 亚洲韩国一区二区三区 | 国产不卡在线播放 | 欧美精品资源 | av一级一片| 欧美精品网站 | 高清av免费看 | 久久99操| 少妇性aaaaaaaaa视频 | 欧美男男激情videos | 96精品高清视频在线观看软件特色 | 久久久久久久久久久网 | 国产黄色免费观看 | 亚洲精品国精品久久99热一 | 91麻豆看国产在线紧急地址 | 国产成人精品午夜在线播放 | 久久国色夜色精品国产 | 日韩专区av| 99久久99久国产黄毛片 | 亚洲一区二区三区毛片 | 欧洲成人免费 | 日韩系列在线 | 亚洲精品自拍视频在线观看 | 成人在线一区二区 | 黄色网免费 | 中国一级片视频 | 99国内精品久久久久久久 | 综合久久久久久久 | 亚洲国产欧美一区二区三区丁香婷 | 在线 影视 一区 | 黄色福利| 国产黄色免费在线观看 | 婷婷深爱激情 | 在线观看mv的中文字幕网站 | 国产淫片 | 亚洲精品永久免费视频 | 久久免费精品一区二区三区 | 亚洲成人欧美 | 国产一区二区三区久久久 | 欧美精品乱码99久久影院 | 亚洲人成人99网站 | 在线成人免费电影 | 999电影免费在线观看2020 | 在线观看视频97 | 日韩动漫免费观看高清完整版在线观看 | 欧洲亚洲精品 | 99久热在线精品视频观看 | 国产视频一区在线 | 婷婷 综合 色 | 91九色porny蝌蚪主页 | 国产精品成人免费一区久久羞羞 | 毛片一区二区 | 韩国av免费在线观看 | 国产欧美在线一区 | 国产一区二区电影在线观看 | 亚洲h视频在线 | 6699私人影院| 人人爽人人爽人人片 | 亚洲一区二区精品 | 中文在线a∨在线 | 精品国产乱码久久久久久三级人 | 亚洲国产mv | 最近日本字幕mv免费观看在线 | 成年人在线免费看视频 | 亚洲专区免费观看 | av电影免费在线看 | 91在线亚洲| 久久躁日日躁aaaaxxxx | 日韩免费中文 | 九九九九九九精品任你躁 | 天天摸夜夜操 | 日韩有码在线播放 | 久久精品国产第一区二区三区 | 国产精品久久久久久久久久久免费 | 国产精品久久久久久久免费 | 国产精品久久久久久吹潮天美传媒 | 成人av电影免费在线观看 | 天天操·夜夜操 | 人人爽人人澡人人添人人人人 | 日韩欧美观看 | 日本精品在线视频 | 手机色在线 | 亚洲精品视频二区 | 9色在线视频 | 五月天精品视频 | 欧美日本不卡高清 | 久久激情视频网 | 婷婷视频在线观看 | 免费高清在线一区 | www最近高清中文国语在线观看 | 国产区高清在线 | 五月综合婷 | 午夜精品一区二区三区免费 | 亚洲精品免费在线观看视频 | 狠狠狠综合 | 97视频在线观看播放 | 亚洲综合视频在线观看 | 色97在线 | 在线观看v片 | 在线观看免费成人 | 最近中文字幕视频网 | 精品一区二区三区电影 | 黄a网 | 国产黄色一级片 |