国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

C++實現(xiàn)編寫二維碼的示例代碼

 更新時間:2023年06月09日 08:25:51   作者:咩~~  
這篇文章主要為大家詳細(xì)介紹如何基于C++實現(xiàn)編寫二維碼的功能,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以了解一下

二維碼圖片好像違規(guī)了,直接給鏈接吧網(wǎng)址鏈接

如果你掃了這個二維碼就會得到一個網(wǎng)址,該網(wǎng)址是我寫代碼的參考,該網(wǎng)站講述了如何編寫一個二維碼,很詳細(xì),我沒有實現(xiàn)漢字的編碼,實現(xiàn)了三種模式的編碼,這個網(wǎng)址給的很詳細(xì),我也就不寫了,如果再寫就跟抄人家的沒區(qū)別了。

下面給出生成的代碼,其中有一些我自己寫的工具,我會做出說明,如果不想看人家網(wǎng)站的話,代碼中也有注釋。

1.Matrix這個模板類是我做的一個二維數(shù)組的套殼,里面用的是動態(tài)申請空間,析構(gòu)時自動釋放

2.每個靜態(tài)的值都是按照順序來的,一般我都給了對應(yīng)關(guān)系和索引如何計算

3.此類計算出來的二維碼,在版本特別高時,我用微信沒識別出來,沒特別仔細(xì)的測試,300個2能識別(用直接跳轉(zhuǎn)12306公眾號了,不知道為啥),3000個2二維碼已經(jīng)密到有點看不清了(這個用微信掃沒反應(yīng))

4.圖像是使用我寫的另外一個類來生成位圖的,沒用JPEG是因為轉(zhuǎn)換沒寫

5.寬字節(jié)編碼沒寫實現(xiàn)

6.沒有解析二維碼的實現(xiàn)

7.源代碼在此這個啥都有

環(huán)境&工具

Windows11 gcc 8.1.0 vscode cmake

QrEncode.h

#pragma once
#include <cmath>
#include <functional>
#include <stdint.h>
#include <string>
#include <vector>
#include <map>
#ifndef _QR_ENCODE_
#define _QR_ENCODE_
#include "Util.h"
#include "Matrix.h"
#include "Image.h"
NAME_SPACE_START(myUtil)
using namespace std;
// Step 1: Choose the Error Correction Level
// Step 2: Determine the Smallest Version for the Data
// Step 3: Add the Mode Indicator
// Step 4: Add the Character Count Indicator
//  The character count indicator must be placed after the mode indicator.
// Step 3: Encode Using the Selected Mode
// Step 4: Break Up into 8-bit Codewords and Add Pad Bytes if Necessary
#define VERSION_COUNT 40
#define MODE_INDICATOR_BIT_LENGTH 4
#define AMPLIFY_LEVEL 4
// #define DEBUG
//對應(yīng)第幾行
enum ErrorCorrectionLevel{
    L = 0,  // Recovers 7% of data
    M = 1,  // Recovers 15% of data
    Q = 2,  // Recovers 25% of data
    H = 3   // Recovers 30% of data
};
//對應(yīng)第幾列
enum DataType{
    NumMode=0,
    AlpNumMode,
    ByteMode,
    KanjiMode
};
// Mode Indicator	Character Count Indicator	Encoded Data
//QRCode Mode Indicator 對應(yīng)DataType, 此編碼長度為MODE_INDICATOR_BIT_LENGTH
//The encoded data must start with the appropriate mode indicator 
//that specifies the mode being used for the bits that come after it.
const static int ModeIndicator[]={
    //NumMode AlpNumMode ByteMode KanjiMode ECIMode
    1,2,4,8,7
};
// 將編碼數(shù)據(jù)的長度編譯為對應(yīng)長度的二進(jìn)制位,共有三種長度,每種長度中對應(yīng)4種DataType
// The character count indicator is a string of bits that 
// represents the number of characters that are being encoded.
const static int CharCountIndicator[3][4]{
    {10,9,8,8},     // version 1~9
    {12,11,16,10},  // version 10~26
    {14,13,16,12},  // version 27~40
};
//Character Capacities by Version, Mode, and Error Correction
const static int CharCapTable[40][4][4]={
    //L M   Q   H
    //Numeric mode,Alphanumeric mode,Byte mode,Kanji mode
    {{41,25,17,10},{34,20,14,8},{27,16,11,7},{17,10,7,4}},
    {{77,47,32,20},{63,38,26,16},{48,29,20,12},{34,20,14,8}},
    {{127,77,53,32},{101,61,42,26},{77,47,32,20},{58,35,24,15}},
    {{187,114,78,48},{149,90,62,38},{111,67,46,28},{82,50,34,21}},
    {{255,154,106,65},{202,122,84,52},{144,87,60,37},{106,64,44,27}},
    {{322,195,134,82},{255,154,106,65},{178,108,74,45},{139,84,58,36}},
    {{370,224,154,95},{293,178,122,75},{207,125,86,53},{154,93,64,39}},
    {{461,279,192,118},{365,221,152,93},{259,157,108,66},{202,122,84,52}},
    {{552,335,230,141},{432,262,180,111},{312,189,130,80},{235,143,98,60}},
    {{652,395,271,167},{513,311,213,131},{364,221,151,93},{288,174,119,74}},
    {{772,468,321,198},{604,366,251,155},{427,259,177,109},{331,200,137,85}},
    {{883,535,367,226},{691,419,287,177},{489,296,203,125},{374,227,155,96}},
    {{1022,619,425,262},{796,483,331,204},{580,352,241,149},{427,259,177,109}},
    {{1101,667,458,282},{871,528,362,223},{621,376,258,159},{468,283,194,120}},
    {{1250,758,520,320},{991,600,412,254},{703,426,292,180},{530,321,220,136}},
    {{1408,854,586,361},{1082,656,450,277},{775,470,322,198},{602,365,250,154}},
    {{1548,938,644,397},{1212,734,504,310},{876,531,364,224},{674,408,280,173}},
    {{1725,1046,718,442},{1346,816,560,345},{948,574,394,243},{746,452,310,191}},
    {{1903,1153,792,488},{1500,909,624,384},{1063,644,442,272},{813,493,338,208}},
    {{2061,1249,858,528},{1600,970,666,410},{1159,702,482,297},{919,557,382,235}},
    {{2232,1352,929,572},{1708,1035,711,438},{1224,742,509,314},{969,587,403,248}},
    {{2409,1460,1003,618},{1872,1134,779,480},{1358,823,565,348},{1056,640,439,270}},
    {{2620,1588,1091,672},{2059,1248,857,528},{1468,890,611,376},{1108,672,461,284}},
    {{2812,1704,1171,721},{2188,1326,911,561},{1588,963,661,407},{1228,744,511,315}},
    {{3057,1853,1273,784},{2395,1451,997,614},{1718,1041,715,440},{1286,779,535,330}},
    {{3283,1990,1367,842},{2544,1542,1059,652},{1804,1094,751,462},{1425,864,593,365}},
    {{3517,2132,1465,902},{2701,1637,1125,692},{1933,1172,805,496},{1501,910,625,385}},
    {{3669,2223,1528,940},{2857,1732,1190,732},{2085,1263,868,534},{1581,958,658,405}},
    {{3909,2369,1628,1002},{3035,1839,1264,778},{2181,1322,908,559},{1677,1016,698,430}},
    {{4158,2520,1732,1066},{3289,1994,1370,843},{2358,1429,982,604},{1782,1080,742,457}},
    {{4417,2677,1840,1132},{3486,2113,1452,894},{2473,1499,1030,634},{1897,1150,790,486}},
    {{4686,2840,1952,1201},{3693,2238,1538,947},{2670,1618,1112,684},{2022,1226,842,518}},
    {{4965,3009,2068,1273},{3909,2369,1628,1002},{2805,1700,1168,719},{2157,1307,898,553}},
    {{5253,3183,2188,1347},{4134,2506,1722,1060},{2949,1787,1228,756},{2301,1394,958,590}},
    {{5529,3351,2303,1417},{4343,2632,1809,1113},{3081,1867,1283,790},{2361,1431,983,605}},
    {{5836,3537,2431,1496},{4588,2780,1911,1176},{3244,1966,1351,832},{2524,1530,1051,647}},
    {{6153,3729,2563,1577},{4775,2894,1989,1224},{3417,2071,1423,876},{2625,1591,1093,673}},
    {{6479,3927,2699,1661},{5039,3054,2099,1292},{3599,2181,1499,923},{2735,1658,1139,701}},
    {{6743,4087,2809,1729},{5313,3220,2213,1362},{3791,2298,1579,972},{2927,1774,1219,750}},
    {{7089,4296,2953,1817},{5596,3391,2331,1435},{3993,2420,1663,1024},{3057,1852,1273,784}},
};
static map<uint8_t,uint8_t> AlpValMappingTable={
    {'0',0},{'1',1},{'2',2},{'3',3},{'4',4},{'5',5},{'6',6},{'7',7},{'8',8},{'9',9},
    {'A',10},{'B',11},{'C',12},{'D',13},{'E',14},{'F',15},{'G',16},{'H',17},{'I',18},
    {'J',19},{'K',20},{'L',21},{'M',22},{'N',23},{'O',24},{'P',25},{'Q',26},{'R',27},
    {'S',28},{'T',29},{'U',30},{'V',31},{'W',32},{'X',33},{'Y',34},{'Z',35},{' ',36},
    {'$',37},{'%',38},{'*',39},{'+',40},{'-',41},{'.',42},{'/',43},{':',44}
};
//value for exponent of alpha, index = EC Codewords Per Block - 7
const static int GeneratorPolynomialCoff[24][31]={
    {0,87,229,146,149,238,102,21},
    {0,175,238,208,249,215,252,196,28},
    {0,95,246,137,231,235,149,11,123,36},
    {0,251,67,46,61,118,70,64,94,32,45},
    {0,220,192,91,194,172,177,209,116,227,10,55},
    {0,102,43,98,121,187,113,198,142,131,87,157,86},
    {0,74,152,176,100,86,100,106,104,130,218,206,140,78},
    {0,199,249,155,48,190,124,218,137,216,87,207,59,22,91},
    {0,8,183,61,91,202,37,51,58,58,237,140,124,5,99,105},
    {0,120,104,107,109,102,161,76,3,91,191,147,169,182,194,225,120},
    {0,43,139,206,78,43,239,123,206,214,147,24,99,150,39,243,163,136},
    {0,215,234,158,94,184,97,118,170,79,187,152,148,252,179,5,98,96,153},
    {0,67,3,105,153,52,90,83,17,150,159,44,128,153,133,252,222,138,220,171},
    {0,17,60,79,50,61,163,26,187,202,180,221,225,83,239,156,164,212,212,188,190},
    {0,240,233,104,247,181,140,67,98,85,200,210,115,148,137,230,36,122,254,148,175,210},
    {0,210,171,247,242,93,230,14,109,221,53,200,74,8,172,98,80,219,134,160,105,165,231},
    {0,171,102,146,91,49,103,65,17,193,150,14,25,183,248,94,164,224,192,1,78,56,147,253},
    {0,229,121,135,48,211,117,251,126,159,180,169,152,192,226,228,218,111,0,117,232,87,96,227,21},
    {0,231,181,156,39,170,26,12,59,15,148,201,54,66,237,208,99,167,144,182,95,243,129,178,252,45},
    {0,173,125,158,2,103,182,118,17,145,201,111,28,165,53,161,21,245,142,13,102,48,227,153,145,218,70},
    {0,79,228,8,165,227,21,180,29,9,237,70,99,45,58,138,135,73,126,172,94,216,193,157,26,17,149,96},
    {0,168,223,200,104,224,234,108,180,110,190,195,147,205,27,232,201,21,43,245,87,42,195,212,119,242,37,9,123},
    {0,156,45,183,29,151,219,54,96,249,24,136,5,241,175,189,28,75,234,150,148,23,9,202,162,68,250,140,24,151},
    {0,41,173,145,152,216,31,179,182,50,48,110,86,239,96,222,125,42,173,226,193,224,130,156,37,251,216,238,40,192,180},
};
// index = (version-1)*4+(int)level
// Total Number of Data Codewords for this Version and EC Level
// EC Codewords Per Block
// Number of Blocks in Group 1	
// Number of Data Codewords in Each of Group 1's Blocks	
// Number of Blocks in Group 2	
// Number of Data Codewords in Each of Group 2's Blocks
const static int ErrorCurrentTable[][6]={
    {19,7,1,19,0,0},
    {16,10,1,16,0,0},
    {13,13,1,13,0,0},
    {9,17,1,9,0,0},
    {34,10,1,34,0,0},
    {28,16,1,28,0,0},
    {22,22,1,22,0,0},
    {16,28,1,16,0,0},
    {55,15,1,55,0,0},
    {44,26,1,44,0,0},
    {34,18,2,17,0,0},
    {26,22,2,13,0,0},
    {80,20,1,80,0,0},
    {64,18,2,32,0,0},
    {48,26,2,24,0,0},
    {36,16,4,9,0,0},
    {108,26,1,108,0,0},
    {86,24,2,43,0,0},
    {62,18,2,15,2,16},
    {46,22,2,11,2,12},
    {136,18,2,68,0,0},
    {108,16,4,27,0,0},
    {76,24,4,19,0,0},
    {60,28,4,15,0,0},
    {156,20,2,78,0,0},
    {124,18,4,31,0,0},
    {88,18,2,14,4,15},
    {66,26,4,13,1,14},
    {194,24,2,97,0,0},
    {154,22,2,38,2,39},
    {110,22,4,18,2,19},
    {86,26,4,14,2,15},
    {232,30,2,116,0,0},
    {182,22,3,36,2,37},
    {132,20,4,16,4,17},
    {100,24,4,12,4,13},
    {274,18,2,68,2,69},
    {216,26,4,43,1,44},
    {154,24,6,19,2,20},
    {122,28,6,15,2,16},
    {324,20,4,81,0,0},
    {254,30,1,50,4,51},
    {180,28,4,22,4,23},
    {140,24,3,12,8,13},
    {370,24,2,92,2,93},
    {290,22,6,36,2,37},
    {206,26,4,20,6,21},
    {158,28,7,14,4,15},
    {428,26,4,107,0,0},
    {334,22,8,37,1,38},
    {244,24,8,20,4,21},
    {180,22,12,11,4,12},
    {461,30,3,115,1,116},
    {365,24,4,40,5,41},
    {261,20,11,16,5,17},
    {197,24,11,12,5,13},
    {523,22,5,87,1,88},
    {415,24,5,41,5,42},
    {295,30,5,24,7,25},
    {223,24,11,12,7,13},
    {589,24,5,98,1,99},
    {453,28,7,45,3,46},
    {325,24,15,19,2,20},
    {253,30,3,15,13,16},
    {647,28,1,107,5,108},
    {507,28,10,46,1,47},
    {367,28,1,22,15,23},
    {283,28,2,14,17,15},
    {721,30,5,120,1,121},
    {563,26,9,43,4,44},
    {397,28,17,22,1,23},
    {313,28,2,14,19,15},
    {795,28,3,113,4,114},
    {627,26,3,44,11,45},
    {445,26,17,21,4,22},
    {341,26,9,13,16,14},
    {861,28,3,107,5,108},
    {669,26,3,41,13,42},
    {485,30,15,24,5,25},
    {385,28,15,15,10,16},
    {932,28,4,116,4,117},
    {714,26,17,42,0,0},
    {512,28,17,22,6,23},
    {406,30,19,16,6,17},
    {1006,28,2,111,7,112},
    {782,28,17,46,0,0},
    {568,30,7,24,16,25},
    {442,24,34,13,0,0},
    {1094,30,4,121,5,122},
    {860,28,4,47,14,48},
    {614,30,11,24,14,25},
    {464,30,16,15,14,16},
    {1174,30,6,117,4,118},
    {914,28,6,45,14,46},
    {664,30,11,24,16,25},
    {514,30,30,16,2,17},
    {1276,26,8,106,4,107},
    {1000,28,8,47,13,48},
    {718,30,7,24,22,25},
    {538,30,22,15,13,16},
    {1370,28,10,114,2,115},
    {1062,28,19,46,4,47},
    {754,28,28,22,6,23},
    {596,30,33,16,4,17},
    {1468,30,8,122,4,123},
    {1128,28,22,45,3,46},
    {808,30,8,23,26,24},
    {628,30,12,15,28,16},
    {1531,30,3,117,10,118},
    {1193,28,3,45,23,46},
    {871,30,4,24,31,25},
    {661,30,11,15,31,16},
    {1631,30,7,116,7,117},
    {1267,28,21,45,7,46},
    {911,30,1,23,37,24},
    {701,30,19,15,26,16},
    {1735,30,5,115,10,116},
    {1373,28,19,47,10,48},
    {985,30,15,24,25,25},
    {745,30,23,15,25,16},
    {1843,30,13,115,3,116},
    {1455,28,2,46,29,47},
    {1033,30,42,24,1,25},
    {793,30,23,15,28,16},
    {1955,30,17,115,0,0},
    {1541,28,10,46,23,47},
    {1115,30,10,24,35,25},
    {845,30,19,15,35,16},
    {2071,30,17,115,1,116},
    {1631,28,14,46,21,47},
    {1171,30,29,24,19,25},
    {901,30,11,15,46,16},
    {2191,30,13,115,6,116},
    {1725,28,14,46,23,47},
    {1231,30,44,24,7,25},
    {961,30,59,16,1,17},
    {2306,30,12,121,7,122},
    {1812,28,12,47,26,48},
    {1286,30,39,24,14,25},
    {986,30,22,15,41,16},
    {2434,30,6,121,14,122},
    {1914,28,6,47,34,48},
    {1354,30,46,24,10,25},
    {1054,30,2,15,64,16},
    {2566,30,17,122,4,123},
    {1992,28,29,46,14,47},
    {1426,30,49,24,10,25},
    {1096,30,24,15,46,16},
    {2702,30,4,122,18,123},
    {2102,28,13,46,32,47},
    {1502,30,48,24,14,25},
    {1142,30,42,15,32,16},
    {2812,30,20,117,4,118},
    {2216,28,40,47,7,48},
    {1582,30,43,24,22,25},
    {1222,30,10,15,67,16},
    {2956,30,19,118,6,119},
    {2334,28,18,47,31,48},
    {1666,30,34,24,34,25},
    {1276,30,20,15,61,16}
};
//index for integer
//element fro exponent of alpha
const static int AntiLogTable[256]={
    -1,0,1,25,2,50,26,198,3,223,51,238,27,104,199,75,
    4,100,224,14,52,141,239,129,28,193,105,248,200,8,
    76,113,5,138,101,47,225,36,15,33,53,147,142,218,240,
    18,130,69,29,181,194,125,106,39,249,185,201,154,9,120,
    77,228,114,166,6,191,139,98,102,221,48,253,226,152,37,
    179,16,145,34,136,54,208,148,206,143,150,219,189,241,210,
    19,92,131,56,70,64,30,66,182,163,195,72,126,110,107,58,40,84,
    250,133,186,61,202,94,155,159,10,21,121,43,78,212,229,172,115,
    243,167,87,7,112,192,247,140,128,99,13,103,74,222,237,49,197,
    254,24,227,165,153,119,38,184,180,124,17,68,146,217,35,32,137,
    46,55,63,209,91,149,188,207,205,144,135,151,178,220,252,190,97,
    242,86,211,171,20,42,93,158,132,60,57,83,71,109,65,162,31,45,67,
    216,183,123,164,118,196,23,73,236,127,12,111,246,108,161,59,82,41,
    157,85,170,251,96,134,177,187,204,62,90,203,89,95,176,156,169,160,81,11,245,22,
    235,122,117,44,215,79,174,213,233,230,231,173,232,116,214,244,234,168,80,88,175
};
//index for exponent of alpha
//element for integer
const static int LogTable[256]={
    1,2,4,8,16,32,64,128,29,58,116,232,205,135,19,38,76,
    152,45,90,180,117,234,201,143,3,6,12,24,48,96,192,157,
    39,78,156,37,74,148,53,106,212,181,119,238,193,159,35,70,
    140,5,10,20,40,80,160,93,186,105,210,185,111,222,161,95,
    190,97,194,153,47,94,188,101,202,137,15,30,60,120,240,253,
    231,211,187,107,214,177,127,254,225,223,163,91,182,113,226,217,
    175,67,134,17,34,68,136,13,26,52,104,208,189,103,206,129,
    31,62,124,248,237,199,147,59,118,236,197,151,51,102,204,133,
    23,46,92,184,109,218,169,79,158,33,66,132,21,42,84,168,
    77,154,41,82,164,85,170,73,146,57,114,228,213,183,115,230,
    209,191,99,198,145,63,126,252,229,215,179,123,246,241,255,227,
    219,171,75,150,49,98,196,149,55,110,220,165,87,174,65,130,
    25,50,100,200,141,7,14,28,56,112,224,221,167,83,166,81,
    162,89,178,121,242,249,239,195,155,43,86,172,69,138,9,18,
    36,72,144,61,122,244,245,247,243,251,235,203,139,11,22,44,
    88,176,125,250,233,207,131,27,54,108,216,173,71,142,1
};
//List of Versions and Required Remainder Bits
const static int RemainderBits[40]={
    0,7,7,7,7,7,0,0,0,0,0,0,0,3,3,3,3,3,3,3,4,4,4,4,4,4,4,3,3,3,3,3,3,3,0,0,0,0,0,0
};
//Alignment Pattern Locations Table
const static int AlignmentPatternLocal[][7]={
    {0,0,0,0,0,0,0},
    {0,0,0,0,0,0,0},
    {6,18,0,0,0,0,0},
    {6,22,0,0,0,0,0},
    {6,26,0,0,0,0,0},
    {6,30,0,0,0,0,0},
    {6,34,0,0,0,0,0},
    {6,22,38,0,0,0,0},
    {6,24,42,0,0,0,0},
    {6,26,46,0,0,0,0},
    {6,28,50,0,0,0,0},
    {6,30,54,0,0,0,0},
    {6,32,58,0,0,0,0},
    {6,34,62,0,0,0,0},
    {6,26,46,66,0,0,0},
    {6,26,48,70,0,0,0},
    {6,26,50,74,0,0,0},
    {6,30,54,78,0,0,0},
    {6,30,56,82,0,0,0},
    {6,30,58,86,0,0,0},
    {6,34,62,90,0,0,0},
    {6,28,50,72,94,0,0},
    {6,26,50,74,98,0,0},
    {6,30,54,78,102,0,0},
    {6,28,54,80,106,0,0},
    {6,32,58,84,110,0,0},
    {6,30,58,86,114,0,0},
    {6,34,62,90,118,0,0},
    {6,26,50,74,98,122,0},
    {6,30,54,78,102,126,0},
    {6,26,52,78,104,130,0},
    {6,30,56,82,108,134,0},
    {6,34,60,86,112,138,0},
    {6,30,58,86,114,142,0},
    {6,34,62,90,118,146,0},
    {6,30,54,78,102,126,150},
    {6,24,50,76,102,128,154},
    {6,28,54,80,106,132,158},
    {6,32,58,84,110,136,162},
    {6,26,54,82,110,138,166},
    {6,30,58,86,114,142,170}
};
// List of all Format Information Strings
const static string FormatInfoList[32]={
    //index=level*7+Mask Pattern index
    "111011111000100","111001011110011","111110110101010","111100010011101","110011000101111","110001100011000","110110001000001",
    "110100101110110","101010000010010","101000100100101","101111001111100","101101101001011","100010111111001","100000011001110",
    "100111110010111","100101010100000","011010101011111","011000001101000","011111100110001","011101000000110","010010010110100",
    "010000110000011","010111011011010","010101111101101","001011010001001","001001110111110","001110011100111","001100111010000",
    "000011101100010","000001001010101","000110100001100","000100000111011"
};
//Version Information Strings
const static string VersionInfoList[]={
    "000111110010010100","001000010110111100","001001101010011001","001010010011010011",
    "001011101111110110","001100011101100010","001101100001000111","001110011000001101",
    "001111100100101000","010000101101111000","010001010001011101","010010101000010111",
    "010011010100110010","010100100110100110","010101011010000011","010110100011001001",
    "010111011111101100","011000111011000100","011001000111100001","011010111110101011",
    "011011000010001110","011100110000011010","011101001100111111","011110110101110101",
    "011111001001010000","100000100111010101","100001011011110000","100010100010111010",
    "100011011110011111","100100101100001011","100101010000101110","100110101001100100",
    "100111010101000001","101000110001101001"
};
//獲取糾錯碼字
vector<int> getErrorCurrentWords(int* coefficient,int cofLen,int ErrorCurrentTableIndex);
class QREncode{
public:
    QREncode(){}
    ~QREncode(){}
    //編碼單字節(jié)
    Matrix<RGB> encoding(const string& encodeData);
    //編碼雙字節(jié)
    Matrix<RGB> encoding(const wstring& encodeWData);
    string decoding(const string& outputPath);
    int getSideLen() { return 21 + 4 * (version - 1); }
protected:
    bool init();
    string NumModeEncoding();
    string AlpNumModeEncoding();
    string ByteModeEncoding();
    string KanjiModeEncoding();
    void fillEncodeData(string& code);
    void errorCurrentEncoding(string& code);
    //得到編碼的二維矩陣
    Matrix<int> MatrixCode(const string& code);
    void FormatAndVersionInfo(Matrix<int>& matrix, int maskIndex);
private:
    string encodeData;
    wstring encodeWData;
    string _imageFilePath;
    ErrorCorrectionLevel level{L};
    DataType type{KanjiMode};
    int version{0}; //matrix sideLen: 21+4*(version-1)
    int charCount{0};
    Matrix<RGB> *imgData{nullptr};
};
NAME_SPACE_END()
#endif //!_QR_ENCODE_

QrEncode.cpp

#include "QrEncode.h"
#include "Image.h"
#include "Matrix.h"
#include "Util.h"
#include <algorithm>
#include <bitset>
#include <iostream>
#include <list>
#include <stack>
#include <cstdlib>
#include <cstring>
#include <string>
#include <vector>
NAME_SPACE_START(myUtil)
#define BACKGROUND_COLOR RGB_WHITE
void print(string& code){
    for(int i=0;i<code.size();i++){
        if(i%8==0) cout<<" ";
        cout<<code[i];
    }
    cout<<endl;
}
vector<function<bool(int,int)>> MaskFunctions={
    [](int row,int column)->int{
        return (row+column)%2==0;
    },
    [](int row,int column)->int{
        return row%2==0;
    },
    [](int row,int column)->int{
        return column%3==0;
    },
    [](int row,int column)->int{
        return (row+column)%3==0;
    },
    [](int row,int column)->int{
        return ((int)floor(row/2.0)+(int)floor(column/3.0))%2==0;
    },
    [](int row,int column)->int{
        return ((row*column)%2+(row*column)%3)==0;
    },
    [](int row,int column)->int{
        return ((row*column)%2+(row*column)%3)%2==0;
    },
    [](int row,int column)->int{
        return ((row+column)%2+(row*column)%3)%2==0;
    }
};
vector<Matrix<int>> getMaskList(const Matrix<int>& data){
    vector<Matrix<int>> res;
    res.resize(8);
    for(int i=0;i<MaskFunctions.size();i++){
        Matrix<int> temp(data);
        for(int r=0;r<temp.row;r++){
            for(int c=0;c<temp.col;c++){
                if((temp.getValue(r, c)==5||temp.getValue(r, c)==6)&&MaskFunctions[i](r,c)){
                    temp.setValue(r, c, 6-temp.getValue(r, c));
                }
                else if(temp.getValue(r, c)==5||temp.getValue(r, c)==6){
                    temp.setValue(r, c, temp.getValue(r, c)-5);
                }
            }
        }
        res[i]=temp;
    }
    return res;
}
vector<int> Next(string pattern){
	vector<int> next;
	next.push_back(0);	//next容器的首位必定為0
	for (int i = 1, j = 0; i < pattern.length(); i++)
	{
		while (j > 0 && pattern[j] != pattern[i])
		{ 
			j = next[j - 1];
		}
		if (pattern[i] == pattern[j])
		{
			j++; 
		}
		next.push_back(j);
	}
	return next;
}
int KMPCount(const string& target,const string& pattern){
    int res=0;
    auto next=Next(pattern);
    for (int i = 0, j = 0; i < target.length(); i++)
	{
		while (j > 0 && target[i] != pattern[j])
		{
			j = next[j - 1];
		}
		if (target[i] == pattern[j])
		{
			j++;
		}
		if (j == pattern.length())
		{
            res++;
			j = next[j - 1];
		}
	}
    return res;
}
// The first rule gives the QR code a penalty for each group of five or more same-colored modules in a row (or column).
int Rule1(const Matrix<int>& data){
    // row
    int sum=0;
    for(int i=0;i<data.row;i++){
        int ContinueCount=1;
        for(int j=1;j<data.col;j++){
            if(data.getValue(i, j)==data.getValue(i, j-1)) ContinueCount++;
            else if(ContinueCount>=5){
                sum+=ContinueCount-3;
                ContinueCount=1;
            }
            else{
                ContinueCount=1;
            }
        }
        if(ContinueCount>=5) sum+=ContinueCount-3;
    }
    // col
    for(int i=0;i<data.col;i++){
        int ContinueCount=1;
        for(int j=1;j<data.row;j++){
            if(data.getValue(j, i)==data.getValue(j-1, i)) ContinueCount++;
            else if(ContinueCount>=5){
                sum+=ContinueCount-3;
                ContinueCount=1;
            }
            else{
                ContinueCount=1;
            }
        }
        if(ContinueCount>=5) sum+=ContinueCount-3;
    }
    return sum;
}
// The second rule gives the QR code a penalty for each 2x2 area of same-colored modules in the matrix.
int Rule2(const Matrix<int>& data){
    int sum=0;
    for(int r=0;r<data.row-1;r++){
        for(int c=0;c<data.col-1;c++){
            if(data.getValue(r, c)==data.getValue(r, c+1)&&
               data.getValue(r, c+1)==data.getValue(r+1, c)&&
               data.getValue(r+1, c)==data.getValue(r+1, c+1)){
                sum+=3;
            }
        }
    }
    return sum;
}
// The third rule gives the QR code a large penalty if there are patterns that look similar to the finder patterns.
int Rule3(const Matrix<int>& data){
    int sum=0;
    //row
    for(int r=0;r<data.row;r++){
        string temp="";
        for(int c=0;c<data.col;c++){
            temp.append(string(1,'0'+data.getValue(r, c)));
        }
        sum+=40*KMPCount(temp, "10111010000");
        sum+=40*KMPCount(temp, "00001011101");
    }
    //col
    for(int c=0;c<data.col;c++){
        string temp="";
        for(int r=0;r<data.row;r++){
            temp.append(string(1,'0'+data.getValue(r, c)));
        }
        sum+=40*KMPCount(temp, "10111010000");
        sum+=40*KMPCount(temp, "00001011101");
    }
    return sum;
}
// The fourth rule gives the QR code a penalty if more than half of the modules are dark or light, with a larger penalty for a larger difference.
int Rule4(const Matrix<int>& data){
    int sum=0,darkCount=0,total=data.row*data.col;
    for(int r=0;r<data.row;r++){
        for(int c=0;c<data.col;c++){
            if(data.getValue(r, c)==1) darkCount++;
        }
    }
    int number=ceil((1.0*darkCount)/total);
    int bigTemp=number%10>5?(10-number%10):(5-number%10);
    int smallTemp=number%10>5?(number%10-5):number%10;
    int big=abs(number+bigTemp-50)/5,small=abs(number-smallTemp-50)/5;
    sum=min(big,small)*10;
    return sum;
}
int Evaluate(const Matrix<int>& data){
    int sum=0;
    sum+=Rule1(data);
    sum+=Rule2(data);
    sum+=Rule3(data);
    sum+=Rule4(data);
    return sum;
}
int* getErrorCurrentVersion(ErrorCorrectionLevel level,int maskIndex){
    int LevelBitSequences[]={1,0,3,2};
    int cur=LevelBitSequences[(int)level],curMaskIndex=maskIndex;
    int polynomial[11]={1,0,1,0,0,1,1,0,1,1,1};
    int maskPattern[]={1,0,1,0,1,0,0,0,0,0,1,0,0,1,0};
    int *code=new int[15];
    memset(code, 0, sizeof(int)*15);
    for(int i=1;i>=0;i--){
        code[i]=cur%2;
        cur>>=1;
    }
    for(int i=4;i>1;i--){
        code[i]=curMaskIndex%2;
        curMaskIndex>>=1;
    }
    int pos=0;
    while(pos<5){
        while(code[pos]==0) pos++;
        for(int i=pos;i<15;i++){
            int temp=polynomial[i-pos];
            if(i-pos>10) temp=0;
            code[i]=code[i]^temp;
        }
        while(code[pos]==0) pos++;
    }
    cur=LevelBitSequences[(int)level],curMaskIndex=maskIndex;
    for(int i=1;i>=0;i--){
        code[i]=cur%2;
        cur>>=1;
    }
    for(int i=4;i>1;i--){
        code[i]=curMaskIndex%2;
        curMaskIndex>>=1;
    }
    for(int i=0;i<15;i++){
        code[i]=code[i]^maskPattern[i];
    }
    return code;
}
//獲取糾錯碼字
vector<int> getErrorCurrentWords(int* coefficient,int cofLen,int ErrorCurrentTableIndex){
    int polynomialLen=ErrorCurrentTable[ErrorCurrentTableIndex][1]+1;
    int* coeff=new int[cofLen + polynomialLen - 1];
    memset(coeff, 0, sizeof(int)*(cofLen + polynomialLen - 1));
    memcpy_s(coeff, sizeof(int)*cofLen, coefficient, sizeof(int)*cofLen);
    for(int i=0;i<cofLen;i++){
        // 1.Multiply the Generator Polynomial by the Lead Term of the XOR result from the previous step
        // 2.XOR the result with the result from step 14b
        int exponent=AntiLogTable[coeff[i]];
        for(int j=0;j<max(cofLen-i,polynomialLen);j++){
            int cof=LogTable[(exponent+GeneratorPolynomialCoff[polynomialLen-8][j])%255];
            if(j>=polynomialLen) cof=0;
            coeff[i+j] = coeff[i+j] ^ cof;
        }
    }
    vector<int> res(polynomialLen-1,0);
    for(int i=0;i<polynomialLen-1;i++) res[i]=coeff[cofLen+i];
    delete [] coeff;
    return res;
}
Matrix<RGB> QREncode::encoding(const string &encodeData){
    this->encodeData=encodeData;
    if(!init()) return Matrix<RGB>();
    imgData=new Matrix<RGB>(getSideLen(),getSideLen(),BACKGROUND_COLOR);
    // char encoding
    string code=bitset<MODE_INDICATOR_BIT_LENGTH>(ModeIndicator[(int)type]).to_string();
    code.append(bitset<16>(encodeData.size()).to_string().substr(16-charCount));
    if(type==DataType::NumMode) code.append(NumModeEncoding());
    else if(type==DataType::AlpNumMode) code.append(AlpNumModeEncoding());
    else if(type==DataType::ByteMode) code.append(ByteModeEncoding());
    else if(type==DataType::KanjiMode) code.append(KanjiModeEncoding());
    fillEncodeData(code);
    // print(code);
    errorCurrentEncoding(code);
    // cout<<code<<endl;
    // print(code);
    Matrix<int> source = MatrixCode(code);
    imgData->setValByArray(source, vector<RGB>{RGB_BLACK}, 0, 0);
    return imgData==nullptr?Matrix<RGB>():*imgData;
}
Matrix<RGB> QREncode::encoding(const wstring& encodeWData){
    this->encodeWData=encodeWData;
    if(!init()) return Matrix<RGB>();
    imgData=new Matrix<RGB>(getSideLen(),getSideLen(),RGB_WHITE);
    return imgData==nullptr?Matrix<RGB>():*imgData;
}
//默認(rèn)找最小的版本
bool QREncode::init(){
    int NumMode=0,AlpNumMode=0,ByteMode=0;
    for_each(encodeData.begin(), encodeData.end(), [&](char ch){
        if(ch<='9'&&ch>='0') NumMode++;
        else if((ch<='z'&&ch>='a')) ByteMode++;
        else if(ch<='Z'&&ch>='A') AlpNumMode++;
    });
    if(ByteMode!=0) type=DataType::ByteMode;
    else if(AlpNumMode!=0) type=DataType::AlpNumMode;
    else if(NumMode!=0) type=DataType::NumMode;
    else type=DataType::KanjiMode;
    int len=encodeData.size();
    if (len > 7089 && type == DataType::NumMode ||
        len > 4296 && type == DataType::AlpNumMode ||
        len > 2953 && type == DataType::ByteMode ||
        len > 1817 && type == DataType::KanjiMode)
        return false;
    for(int i=0;i<VERSION_COUNT;i++){
        for(int j=3;j>=0;j--){
            if(CharCapTable[i][j][(int)type]>len){
                version=i+1;
                level=(ErrorCorrectionLevel)j;
                if(version>=1&&version<=9) 
                    charCount=CharCountIndicator[0][(int)type];
                else if(version>=10&&version<=26)
                    charCount=CharCountIndicator[1][(int)type];
                else if(version>=27&&version<=40)
                    charCount=CharCountIndicator[2][(int)type];
                return true;
            }
        }
    }
    return false;
}
string QREncode::NumModeEncoding(){
    string res="";
    //分為3個一組,最后會出現(xiàn)2個一組或者一個一組的
    //都轉(zhuǎn)為10進(jìn)制,然后3位的轉(zhuǎn)為10位二進(jìn)制,兩位轉(zhuǎn)為7位,一位轉(zhuǎn)為4位
    for (int i = 0; i < encodeData.size(); i += 3) {
        int t=0, bitCount=4;
        if (i < encodeData.size()) t += encodeData[i] - '0';
        if (i + 1 < encodeData.size()){
            t = t * 10 + encodeData[i + 1] - '0';
            bitCount=7;
        }
        if (i + 2 < encodeData.size()){
            t = t * 10 + encodeData[i + 2] - '0';
            bitCount=10;
        }
        if(bitCount==4) res.append(bitset<4>(t).to_string());
        else if(bitCount==7) res.append(bitset<7>(t).to_string());
        else if(bitCount==10) res.append(bitset<10>(t).to_string());
    }
    return res;
}
string QREncode::AlpNumModeEncoding(){
    string res="";
    //兩位轉(zhuǎn)11位二進(jìn)制 一位轉(zhuǎn)6位二進(jìn)制
    for(int i=0;i<encodeData.size();i+=2){
        int t=0, bitCount=6;
        if(i<encodeData.size()) 
            t = AlpValMappingTable[encodeData[i]];
        if(i+1<encodeData.size()){
            t = t*45 + AlpValMappingTable[encodeData[i+1]];
            bitCount=11;
        }
        if(bitCount==6) res.append(bitset<6>(t).to_string());
        else if(bitCount==11) res.append(bitset<11>(t).to_string());
    }
    return res;
}
string QREncode::ByteModeEncoding(){
    // 1.Convert to ISO 8859-1 or UTF-8
    // 2.Split the String into 8-bit Bytes
    // 3.Convert Each Byte into Binary
    // 4.Next: Finish the Data Encoding Step
    string res="";
    for(int i=0;i<encodeData.size();i++){
        res.append(bitset<8>(encodeData[i]).to_string());
    }
    return res;
}
string QREncode::KanjiModeEncoding(){
    // 1.Only for Double-Byte Shift JIS Characters
    // 2.Convert to Bytes
    // 3.Encode the Bytes with Kanji Mode
    //     For characters whose bytes are in the range 0x8140 to 0x9FFC
    //      for example: 0x89D7 
    //     1. 0x89D7 - 0x8140 = 0x0897
    //     2. (0x08 * 0xC0) + 0x97 = (0x600) + 0x97 = 0x697
    //     3. 0x697 -> binary(13bit)
    //     For characters whose bytes are in the range 0xE040 to 0xEBBF
    //      for example: 0xE4AA 
    //     1. 0xE4AA - 0xC140 = 0x236A
    //     2. (0x23 * 0xC0) + 0x6A = (0x1A40) + 0x6A = 0x1AAA
    //     3. 0x1AAA -> binary(13bit)
    // 4.Put the 13-bit Binary Numbers Together
    // 5.Next: Finish the Data Encoding Step
    string res="";
    for(int i=0;i<encodeWData.size();i++){
    }
    return res;
}
void QREncode::fillEncodeData(string& code){
    // 1. Determine the Required Number of Bits for this QR Code
    // 2. Add a Terminator of 0s if Necessary
    // 3. Add More 0s to Make the Length a Multiple of 8
    // 4. Add Pad Bytes if the String is Still too Short
    //  11101100 00010001//兩字節(jié)循環(huán)填入
    // code string bit length
    int maxLen=ErrorCurrentTable[(version-1)*4+(int)level][0]*8;
    int diff=maxLen-code.size();
    if(diff<0) return;
    // Add a Terminator
    if(diff>4) code.append("0000");
    else if(diff<=4) code.append(string(diff,'0'));
    // Add More 0s to Make the Length a Multiple of 8
    int eightDiff = 8-code.size()%8;
    code.append(string(eightDiff,'0'));
    // Add Pad Bytes
    if(maxLen-code.size()<8) return;
    int n=(maxLen-code.size())/8;
    for(int i=0;i<n;i++){
        if(i%2==0) code.append("11101100");
        else code.append("00010001");
    }
}
void QREncode::errorCurrentEncoding(string& code){
    // Step 1: Break Data Codewords into Blocks if Necessary
    // Step 2: Understand Polynomial Long Division
    // Step 3: Understand The Galois Field
    // Step 4: Understand Galois Field Arithmetic
    // Step 5: Generate Powers of 2 using Byte-Wise Modulo 100011101
    // Step 6: Understand Multiplication with Logs and Antilogs
    // Step 7: Understanding The Generator Polynomial
    // Step 8: Generating Error Correction Codewords
    // Step 9: Divide the Message Polynomial by the Generator Polynomial
    int row=(version-1)*4+(int)level,codePos=0;
    int groupCount = ErrorCurrentTable[row][4]==0?1:2;
    int*** group=new int**[groupCount];
    vector<vector<int>> currentWords;
    int maxCodeWordsLen=0,maxCurrentCodeWordsLen=0;
    for(int i=0;i<groupCount;i++){
        int blockCol=2,codeWordsCol=3;
        if(i==1){
            blockCol=4;
            codeWordsCol=5;
        }
        group[i]=new int*[ErrorCurrentTable[row][blockCol]];
        for(int blockOfGroup=0;blockOfGroup<ErrorCurrentTable[row][blockCol];blockOfGroup++){
            group[i][blockOfGroup]=new int[ErrorCurrentTable[row][codeWordsCol]];
            maxCodeWordsLen=max(maxCodeWordsLen,ErrorCurrentTable[row][codeWordsCol]);
            for(int blocks=0;blocks<ErrorCurrentTable[row][codeWordsCol]&&codePos<=code.size();blocks++){
                int t=0;
                for(int k=0;k<8;k++){
                    t<<=1;
                    t+=code[codePos+k]-'0';
                }
                group[i][blockOfGroup][blocks]=t;
                codePos+=8;
                // cout<<t<<" ";
            }
            // cout<<endl;
            vector<int> CurrentCodeWords = getErrorCurrentWords(group[i][blockOfGroup], ErrorCurrentTable[row][codeWordsCol],row);
            currentWords.push_back(CurrentCodeWords);
            maxCurrentCodeWordsLen=max(maxCurrentCodeWordsLen,(int)CurrentCodeWords.size());
        }
    }
    // cout<<endl;
    // for(auto items : currentWords){
    //     for(int item : items){
    //         cout<<item<<" ";
    //     }
    //     cout<<endl;
    // }
    // cout<<endl;
    //Structure Final Message
    code = "";
    //Interleave the Blocks
    for(int i=0;i<maxCodeWordsLen;i++){
        for(int j=0;j<groupCount;j++){
            int blockCol=2,codeWordsCol=3;
            if(j==1){
                blockCol=4;
                codeWordsCol=5;
            }
            for(int k=0;k<ErrorCurrentTable[row][blockCol];k++){
                int dataLen=ErrorCurrentTable[row][codeWordsCol];
                if(i>=dataLen) continue;
                code.append(bitset<8>(group[j][k][i]).to_string());
                // cout<<group[j][k][i]<<" ";
            }
        }
    }
    // cout<<endl<<endl;
    //Interleave the Error Correction Codewords
    for(int i=0;i<maxCurrentCodeWordsLen;i++){
        for(int j=0;j<currentWords.size();j++){
            if(i>=currentWords[j].size()) continue;
            // cout<<"("<<j<<","<<i<<") ";
            code.append(bitset<8>(currentWords[j][i]).to_string());
            // cout<<currentWords[j][i]<<" ";
        }
    }
    // cout<<endl;
    //Add Remainder Bits
    code.append(string(RemainderBits[version-1],'0'));
}
vector<vector<int>> FinderPatterns={
    {1,1,1,1,1,1,1},
    {1,2,2,2,2,2,1},
    {1,2,1,1,1,2,1},
    {1,2,1,1,1,2,1},
    {1,2,1,1,1,2,1},
    {1,2,2,2,2,2,1},
    {1,1,1,1,1,1,1}
};
vector<vector<int>> AlignmentPatterns={
    {1,1,1,1,1},
    {1,2,2,2,1},
    {1,2,1,2,1},
    {1,2,2,2,1},
    {1,1,1,1,1}
};
Matrix<int> QREncode::MatrixCode(const string& code){
    Matrix<int> res(getSideLen(),getSideLen(),-1);
    Matrix<int> finder(7,7,FinderPatterns),
                alignment(5,5,AlignmentPatterns);
    vector<int> val{1,0};//默認(rèn)是白色,1為黑色
    int ReserveArea=1;
    // Step 1: Add the Finder Patterns
    res.setValByArray(finder, val, 0, 0);
    res.setValByArray(finder, val, 0, getSideLen()-7);
    res.setValByArray(finder, val, getSideLen()-7, 0);
    // Step 2: Add the Separators
    for(int i=0;i<8;i++){
        //左上
        res.setValue(7, i, 0);
        res.setValue(i, 7, 0);
        //左下
        res.setValue(getSideLen()-1-i, 7, 0);
        res.setValue(getSideLen()-8, i, 0);
        //右上
        res.setValue(7, getSideLen()-1-i, 0);
        res.setValue(i, getSideLen()-8, 0);
    }
    // Step 3: Add the Alignment Patterns
    for(int i=0;i<7&&version!=1;i++){
        for(int j=0;j<7;j++){
            if(AlignmentPatternLocal[version][i]==0||
                AlignmentPatternLocal[version][j]==0) continue;
            int row=AlignmentPatternLocal[version][i],
                col=AlignmentPatternLocal[version][j];
            //判斷是否與finder重合
            if((row-2<8&&col-2<8)||
                (row-2<8&&col+2>getSideLen()-9)||
                (row+2>getSideLen()-9&&col-2<8)) continue;
            res.setValByArray(alignment, val, row-2, col-2);
            // cout<<res<<endl;
        }
    }
    // Step 4: Add the Timing Patterns
    for(int i=8;i<getSideLen()-8;i+=2){
        if(res.getValue(i, 6)==-1) res.setValue(i, 6, 1);
        if(res.getValue(6, i)==-1) res.setValue(6, i, 1);
        if(res.getValue(i+1, 6)==-1) res.setValue(i+1, 6, 0);
        if(res.getValue(6, i+1)==-1) res.setValue(6, i+1, 0);
    }
    // Step 5: Add the Dark Module and Reserved Areas
    // Dark Module
    res.setValue(4*version+9, 8, 1);
    // Reserve the Format Information Area  set value 2
    for(int i=0;i<9;i++){
        //左上
        if(res.getValue(8, i)==-1) res.setValue(8, i, 2);
        if(res.getValue(i, 8)==-1) res.setValue(i, 8, 2);
        //左下
        if(res.getValue(getSideLen()-1-i, 8)==-1&&i<7) res.setValue(getSideLen()-1-i, 8, 2);
        //右上
        if(res.getValue(8, getSideLen()-1-i)==-1&&i<8) res.setValue(8, getSideLen()-1-i, 2);
    }
    // QR codes versions 7 and larger must contain two areas where version information bits are placed. Each of area 6×3. set value 3
    for(int i=0;i<3&&version>=7;i++){
        for(int j=0;j<6;j++){
            res.setValue(getSideLen()-9-i, j, 3);
            res.setValue(j, getSideLen()-9-i, 3);
        }
    }
    // Step 6: Place the Data Bits
    int r=getSideLen()-1,c=getSideLen()-1,codePos=0;
    bool upWard=true,right=true;
    while(r>=0&&r<getSideLen()&&c>=0&&c<getSideLen()&&codePos<code.size()){
        // cout<<"("<<r<<","<<c<<") ";
        if(res.getValue(r, c)==-1){
            res.setValue(r, c, code[codePos++]-'0'+5);//此處賦值將數(shù)據(jù)值賦值為5和6,目的是使后面mask方便
            // else
            //     res.setValue(r, c, 5);
        }
        if(upWard){
            if(right) {right=!right; c-=1;}
            else {
                right=!right;
                if (r-1<0) {c-=1;r=0;right=true; upWard=!upWard;}
                else{ c+=1; r-=1;}
            }
        }
        else{
            if(c==6) {c=5; right=true;}
            if(right) {right=!right; c-=1;}
            else {
                right=!right;
                if(r+1>=getSideLen()){c-=1;r=getSideLen()-1;right=true; upWard=!upWard;}
                else {c+=1; r+=1; }
            }
        }
    }
    int a=code.size();
    // mask evaluate
    auto dataMatrix=getMaskList(res);
    int minScore=INT_MAX, minScorePos=0;
    for(int i=0;i<dataMatrix.size();i++){
        //設(shè)置保留位
        FormatAndVersionInfo(dataMatrix[i],i);
#ifdef DEBUG
        Matrix<RGB> rgb(getSideLen()+8,getSideLen()+8,BACKGROUND_COLOR);
        rgb.setValByArray(dataMatrix[i], vector<RGB>{RGB_BLACK}, 4, 4);
        BMPData bmp(AmplifyMatrix<RGB>(rgb,AMPLIFY_LEVEL),rgb.col*AMPLIFY_LEVEL,rgb.row*AMPLIFY_LEVEL,true);
        bmp.GrayEncoder();
        bmp.saveBMP("qr"+string(1,'1'+i)+".bmp");
#endif
        // cout<<dataMatrix[i]<<endl;
        int t=Evaluate(dataMatrix[i]);
        if(t<minScore){
            minScore=t;
            minScorePos=i;
        }
        // cout<<t<<" ";
    }
    // cout<<endl;
    res=dataMatrix[minScorePos];
    return res;
}
void QREncode::FormatAndVersionInfo(Matrix<int>& matrix, int maskIndex){
    // Format String
    // int *CurrentCode=getErrorCurrentVersion(level, maskIndex);
    string CurrentCode=FormatInfoList[((int)level)*8+maskIndex];
    for(int i=0;i<7;i++){
        int t=0;
        if(i>=6) t=1;
        matrix.setValue(8, i+t, CurrentCode[i]-'0');
        // left down
        matrix.setValue(getSideLen()-1-i, 8, CurrentCode[i]-'0');
    }
    for(int i=0;i<8;i++){
        // right up
        matrix.setValue(8, getSideLen()-1-i, CurrentCode[14-i]-'0');
        int t=0;
        if(i>=6) t=1;
        matrix.setValue(i+t, 8, CurrentCode[14-i]-'0');
    }
    // Version Information
    if(version>=7){
        string CurrentInfo=VersionInfoList[version-7];
        int pos=0;
        for(int i=0;i<3;i++){
            for(int j=0;j<6;j++){
                matrix.setValue(getSideLen()-11+i, j, CurrentInfo[pos]-'0');
                matrix.setValue(j, getSideLen()-11+i, CurrentInfo[pos++]-'0');
            }
        }
    }
}
NAME_SPACE_END()

QrCode_test.cpp

#include "Image.h"
#include "QrEncode.h"
#include <cstdint>
#include <fstream>
#include <list>
#include <string>
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include "Matrix.h"
using namespace std;
using namespace myUtil;
int main(int argc,char * argv[]){
    if(argc>3){
        cout<<"param error\n";
        return 0;
    }
    if(string(argv[1])=="--help"){
        cout<<"[content] [resultName] out resultName.bmp QRcode\n\n";
        return 0;
    }
    QREncode qr;
    Matrix<RGB> rgb=qr.encoding(argv[1]);
    // Matrix<RGB> rgb=qr.encoding("01234567890123456789012345678901234567890");
    // Matrix<RGB> rgb=qr.encoding("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA");
    BMPData bmp(AmplifyMatrix<RGB>(rgb,AMPLIFY_LEVEL),rgb.col*AMPLIFY_LEVEL,rgb.row*AMPLIFY_LEVEL,true);
    bmp.GrayEncoder();
    bmp.saveBMP(string(argv[2])+".bmp");
    return 0;
}

以上就是C++實現(xiàn)編寫二維碼的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于C++編寫二維碼的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 數(shù)組中求第K大數(shù)的實現(xiàn)方法

    數(shù)組中求第K大數(shù)的實現(xiàn)方法

    本篇文章是對數(shù)組中求第K大數(shù)的實現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • c程序生成并使用共享庫的操作方法

    c程序生成并使用共享庫的操作方法

    在C語言開發(fā)中,共享庫可以減少程序體量并實現(xiàn)功能共享,本文詳細(xì)介紹了如何創(chuàng)建一個實現(xiàn)基本數(shù)學(xué)功能的共享庫,并展示了其他程序如何利用這個庫,步驟包括編寫源代碼、編譯成目標(biāo)文件、鏈接成共享庫以及如何在其他程序中使用這個庫
    2024-09-09
  • C++智能指針之shared_ptr詳解

    C++智能指針之shared_ptr詳解

    這篇文章主要為大家詳細(xì)介紹了C++智能指針之shared_ptr,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • 怎么通過C語言自動生成MAC地址

    怎么通過C語言自動生成MAC地址

    以下是對使用C語言自動生成MAC地址的實現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下
    2013-09-09
  • OpenCV獲取視頻的每一幀并保存為.jpg圖片

    OpenCV獲取視頻的每一幀并保存為.jpg圖片

    這篇文章主要為大家詳細(xì)介紹了OpenCV獲取視頻的每一幀,并保存為.jpg圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • 簡要解讀C++的動態(tài)和靜態(tài)關(guān)聯(lián)以及虛析構(gòu)函數(shù)

    簡要解讀C++的動態(tài)和靜態(tài)關(guān)聯(lián)以及虛析構(gòu)函數(shù)

    這篇文章主要介紹了簡要解讀C++的動態(tài)和靜態(tài)關(guān)聯(lián)以及虛析構(gòu)函數(shù),析構(gòu)函數(shù)在C++編程中平時并不是太常用,需要的朋友可以參考下
    2015-09-09
  • 詳解C語言數(shù)組中是以列優(yōu)先嗎

    詳解C語言數(shù)組中是以列優(yōu)先嗎

    這篇文章主要給大家介紹了關(guān)于C語言指針名稱及所指變量的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用C語言具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • C++使用curl庫的完成流程

    C++使用curl庫的完成流程

    curl 是一個利用URL語法在命令行方式下工作的文件傳輸工具,curl不但提供了一個可執(zhí)行的工具庫,還提供了供程序開發(fā)的libcurl庫,該庫使用c語言編寫,支持跨平臺,本文給大家介紹了C++使用curl庫的完成流程,需要的朋友可以參考下
    2024-09-09
  • 將CString字符串輸入轉(zhuǎn)化成整數(shù)的實現(xiàn)方法

    將CString字符串輸入轉(zhuǎn)化成整數(shù)的實現(xiàn)方法

    下面小編就為大家?guī)硪黄獙String字符串輸入轉(zhuǎn)化成整數(shù)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • windows下vscode使用cmake的方法

    windows下vscode使用cmake的方法

    這篇文章主要介紹了windows下vscode使用cmake的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評論

亚洲精品国产久久久久久| 91精品高清一区二区三区| 91国产资源在线视频| 欧美成人精品欧美一级黄色| 天天射夜夜操综合网| 中文字幕av熟女人妻| 欧美成人综合视频一区二区 | 亚洲精品一区二区三区老狼| 婷婷激情四射在线观看视频| 日韩美女综合中文字幕pp| 夜色福利视频在线观看| 国产在线观看黄色视频| 久久久久91精品推荐99| 国产黄色片蝌蚪九色91| 欧美偷拍自拍色图片| 日本又色又爽又黄又粗| brazzers欧熟精品系列| 精品老妇女久久9g国产| 成人18禁网站在线播放| 亚洲 欧美 精品 激情 偷拍| 老司机在线精品福利视频| 强行扒开双腿猛烈进入免费版| 国产日韩精品电影7777| 日韩写真福利视频在线观看| 少妇深喉口爆吞精韩国| 亚洲国产欧美国产综合在线| 超碰97人人做人人爱| 午夜的视频在线观看| 91啪国自产中文字幕在线| 中文字幕亚洲中文字幕| 激情啪啪啪啪一区二区三区| 国产综合精品久久久久蜜臀| 女生被男生插的视频网站| 100%美女蜜桃视频| 国产黄网站在线观看播放| 亚洲欧美另类自拍偷拍色图| 粉嫩小穴流水视频在线观看| 2017亚洲男人天堂| 这里有精品成人国产99| 人妻最新视频在线免费观看| 日本少妇在线视频大香蕉在线观看| 老司机在线精品福利视频| 天天干天天日天天干天天操| 狠狠嗨日韩综合久久| 午夜精品福利一区二区三区p| 国产日韩欧美视频在线导航 | 2022国产综合在线干| 免费在线观看视频啪啪| 欧美老妇精品另类不卡片| 黄片色呦呦视频免费看| 欧美va亚洲va天堂va| 91av中文视频在线| 日韩美女福利视频网| 在线观看成人国产电影| 天天做天天爽夜夜做少妇| 美日韩在线视频免费看| 亚洲熟妇x久久av久久| 2025年人妻中文字幕乱码在线 | 啊啊啊想要被插进去视频| 自拍偷区二区三区麻豆| av视屏免费在线播放| 91精品国产麻豆国产| 一区二区三区蜜臀在线| 久久这里有免费精品| 啊用力插好舒服视频| 久草电影免费在线观看| 韩国男女黄色在线观看| 日本后入视频在线观看| 日韩在线视频观看有码在线| 免费在线黄色观看网站| 久久久久久cao我的性感人妻| 人人爱人人妻人人澡39| 1769国产精品视频免费观看| 久久尻中国美女视频| 天天日天天日天天射天天干 | 成年人该看的视频黄免费| 欧美成人猛片aaaaaaa| 亚洲福利精品视频在线免费观看| 熟妇一区二区三区高清版| 亚洲伊人久久精品影院一美女洗澡 | 欧美女同性恋免费a| 丝袜美腿视频诱惑亚洲无| 欧美成人猛片aaaaaaa| 狠狠躁夜夜躁人人爽天天久天啪| 人妻久久久精品69系列| 亚洲欧美日韩视频免费观看| 中文字幕一区二区三区蜜月| av在线播放国产不卡| 青青在线视频性感少妇和隔壁黑丝 | 青青青视频手机在线观看| jiuse91九色视频| 日本午夜爽爽爽爽爽视频在线观看 | 天天日天天干天天插舔舔| 亚洲另类综合一区小说| 国产在线观看黄色视频| 国内自拍第一页在线观看| 天天躁日日躁狠狠躁av麻豆| 成年午夜影片国产片| 亚国产成人精品久久久| 国产精品黄片免费在线观看| 男人插女人视频网站| 日韩av大胆在线观看| 51国产成人精品视频| 成年美女黄网站18禁久久| 精品一区二区三区午夜| 黄色男人的天堂视频| 亚洲人妻30pwc| 国产欧美日韩第三页| 伊人综合免费在线视频| 人人爽亚洲av人人爽av| 中文字幕最新久久久| 蜜桃久久久久久久人妻| 亚洲熟色妇av日韩熟色妇在线| 亚洲免费福利一区二区三区| 2022中文字幕在线| 国产日本精品久久久久久久| 久久久久五月天丁香社区| 青青草人人妻人人妻| 91亚洲精品干熟女蜜桃频道| 日日操综合成人av| www日韩毛片av| 亚洲国产40页第21页| 在线免费视频 自拍| av男人天堂狠狠干| 日韩激情文学在线视频| 国产精品三级三级三级| 国产视频一区二区午夜| 极品性荡少妇一区二区色欲| 中英文字幕av一区| 日韩剧情片电影在线收看| 91自产国产精品视频| 在线免费观看靠比视频的网站| 日韩美女福利视频网| 91成人精品亚洲国产| 国产欧美日韩第三页| 晚上一个人看操B片| 快插进小逼里大鸡吧视频| av破解版在线观看| 深田咏美亚洲一区二区| 在线观看av亚洲情色| 久久免看30视频口爆视频| 肏插流水妹子在线乐播下载| 国产亚洲国产av网站在线| 日韩特级黄片高清在线看| 999九九久久久精品| 欧美偷拍亚洲一区二区| 国产实拍勾搭女技师av在线| 999九九久久久精品| 国产一区自拍黄视频免费观看| 无码精品一区二区三区人| 国产美女午夜福利久久| 亚洲av自拍天堂网| 宅男噜噜噜666免费观看| 自拍 日韩 欧美激情| 亚洲欧美一区二区三区爱爱动图| 在线观看日韩激情视频| 亚洲午夜福利中文乱码字幕| 国产视频一区在线观看| 成人精品在线观看视频| 玖玖一区二区在线观看| 一区二区三区四区中文| 扒开让我视频在线观看| 97色视频在线观看| 老司机深夜免费福利视频在线观看| 在线免费观看国产精品黄色| 91大神福利视频网| 日本韩国免费一区二区三区视频 | 亚洲1卡2卡三卡4卡在线观看| 国产美女精品福利在线| 538精品在线观看视频| av老司机精品在线观看| 男人的天堂av日韩亚洲| 国产亚洲精品视频合集| 99一区二区在线观看| 亚洲欧美综合在线探花| 9色精品视频在线观看| 黄色男人的天堂视频| 色花堂在线av中文字幕九九| 超级av免费观看一区二区三区| 少妇被强干到高潮视频在线观看 | 天天摸天天日天天操| 男大肉棒猛烈插女免费视频| 韩国AV无码不卡在线播放| 中文字幕AV在线免费看 | 亚洲少妇人妻无码精品| 大鸡吧插逼逼视频免费看| 欧美精品激情在线最新观看视频| 成人性爱在线看四区| 人妻凌辱欧美丰满熟妇| 欧美精品国产综合久久| 中文字幕国产专区欧美激情| 午夜在线精品偷拍一区二| 国产亚洲成人免费在线观看| 性感美女福利视频网站| 97精品视频在线观看| 亚洲欧美成人综合在线观看| 国产精品黄大片在线播放| 欧美成人一二三在线网| 日本熟妇一区二区x x| 亚洲激情唯美亚洲激情图片| 青青青青青手机视频| 美女少妇亚洲精选av| 免费看国产又粗又猛又爽又黄视频 | 欧美麻豆av在线播放| 97少妇精品在线观看| 午夜精彩视频免费一区| 亚洲第17页国产精品| 边摸边做超爽毛片18禁色戒| 国产高清在线观看1区2区| 在线观看免费视频色97| 日韩美av高清在线| 久久久人妻一区二区| 大鸡巴后入爆操大屁股美女 | 黄色录像鸡巴插进去| 国产九色91在线观看精品| 人妻自拍视频中国大陆| 阴茎插到阴道里面的视频| 中国把吊插入阴蒂的视频| 国产在线91观看免费观看| 97青青青手机在线视频| 欧美成人一二三在线网| 成人动漫大肉棒插进去视频| 国产不卡av在线免费| 国际av大片在线免费观看| 偷拍自拍福利视频在线观看| 天天插天天狠天天操| 日本一二三中文字幕| aiss午夜免费视频| 中文字幕免费在线免费| 大鸡八强奸视频在线观看| 涩爱综合久久五月蜜臀| 桃色视频在线观看一区二区 | 国产第一美女一区二区三区四区| 亚洲av无女神免非久久| 黄色无码鸡吧操逼视频| 国产自拍在线观看成人| 国产精品视频资源在线播放| 国产黄色大片在线免费播放 | 最新中文字幕免费视频| 丝袜亚洲另类欧美变态| av网址国产在线观看| 亚洲午夜伦理视频在线| 香蕉91一区二区三区| 天天操天天干天天插| 日本女大学生的黄色小视频| 午夜免费体验区在线观看| 亚洲另类图片蜜臀av| 久久机热/这里只有| 中文字幕奴隷色的舞台50| 国产麻豆剧果冻传媒app| 国产 在线 免费 精品| 国产精品一区二区久久久av| 成人综合亚洲欧美一区| 色秀欧美视频第一页| 喷水视频在线观看这里只有精品| 中国产一级黄片免费视频播放| 青青青青爽手机在线| 午夜福利资源综合激情午夜福利资| 丰满少妇翘臀后进式| 综合国产成人在线观看| 中文字幕免费在线免费| av森泽佳奈在线观看| 亚洲av日韩精品久久久久久hd| av亚洲中文天堂字幕网| 成人亚洲精品国产精品| 久久精品36亚洲精品束缚| 日本熟女50视频免费| 国产亚洲精品品视频在线| 成人av免费不卡在线观看| www日韩毛片av| 2020国产在线不卡视频| 在线亚洲天堂色播av电影| 亚洲在线一区二区欧美| 亚洲精品久久综合久| 黄色三级网站免费下载| 毛片一级完整版免费| 欧美久久久久久三级网| 亚洲精品高清自拍av| 日本少妇人妻xxxxxhd| 中英文字幕av一区| 欧美精产国品一二三产品价格| 久久久久久99国产精品| 久久久制服丝袜中文字幕| 偷拍3456eee| 88成人免费av网站| 不卡一区一区三区在线| 性感美女福利视频网站| 亚洲男人让女人爽的视频| 亚洲在线免费h观看网站| 亚洲av自拍偷拍综合| 人妻少妇亚洲精品中文字幕| 国产精品女邻居小骚货| 日本一道二三区视频久久| 美女小视频网站在线| 天天日天天玩天天摸| 人妻少妇av在线观看| 日韩近亲视频在线观看| 日本熟女精品一区二区三区| 在线成人日韩av电影| 38av一区二区三区| 欧美一区二区中文字幕电影 | 亚洲最大黄 嗯色 操 啊| 亚洲一区二区人妻av| 四虎永久在线精品免费区二区| 性感美女福利视频网站| 日本av熟女在线视频| 黄色三级网站免费下载| 亚洲另类图片蜜臀av| 黑人乱偷人妻中文字幕| 黑人变态深video特大巨大| 中文字幕中文字幕人妻| 综合色区亚洲熟妇shxstz| 无码精品一区二区三区人 | 午夜福利人人妻人人澡人人爽| 在线免费观看靠比视频的网站| 欧美视频中文一区二区三区| 婷婷五月亚洲综合在线| 四川五十路熟女av| 青青擦在线视频国产在线| 熟女人妻在线观看视频| 国产一区二区视频观看| 韩国黄色一级二级三级| 午夜久久久久久久精品熟女| yellow在线播放av啊啊啊| 97超碰最新免费在线观看| 宅男噜噜噜666国产| 久久永久免费精品人妻专区| 蜜臀成人av在线播放| 天天操天天操天天碰| 天堂av在线最新版在线| 福利一二三在线视频观看| 精品黑人一区二区三区久久国产| 免费黄页网站4188| 免费岛国喷水视频在线观看| 中文字幕熟女人妻久久久| 亚洲av无女神免非久久| 中文字幕最新久久久| 欧美老鸡巴日小嫩逼| 黄色大片男人操女人逼| 国产不卡av在线免费| 亚洲色偷偷综合亚洲AV伊人| 99热这里只有精品中文| 丝袜美腿视频诱惑亚洲无| 农村胖女人操逼视频| 亚洲高清国产拍青青草原| 国产超码片内射在线| 亚洲av日韩av网站| 日韩精品啪啪视频一道免费| 动漫精品视频在线观看| 38av一区二区三区| 亚欧在线视频你懂的| 欧美精品中文字幕久久二区| 亚洲精品亚洲人成在线导航| 天天射夜夜操综合网| 国产男女视频在线播放| 亚洲人成精品久久久久久久| gogo国模私拍视频| 国产不卡av在线免费| 亚洲卡1卡2卡三卡四老狼| 最新日韩av传媒在线| 福利国产视频在线观看| 男生舔女生逼逼的视频| 开心 色 六月 婷婷| 亚洲成人国产av在线| 成人蜜桃美臀九一一区二区三区| 97欧洲一区二区精品免费| 亚洲中文字幕校园春色| 100%美女蜜桃视频| 免费黄页网站4188| 日韩欧美亚洲熟女人妻| 亚洲熟女女同志女同| 免费在线黄色观看网站| 精品国产午夜视频一区二区| 直接观看免费黄网站| 亚洲人妻视频在线网| 成人区人妻精品一区二视频| 久精品人妻一区二区三区| 欧美精品资源在线观看| 中文字母永久播放1区2区3区 | av天堂中文字幕最新| 日本女人一级免费片| 最新黄色av网站在线观看| 熟女人妻一区二区精品视频| 精品av久久久久久久| 日本美女成人在线视频| 性色蜜臀av一区二区三区| av日韩在线观看大全| 激情伦理欧美日韩中文字幕| 午夜精品在线视频一区| h国产小视频福利在线观看| 偷拍自拍亚洲视频在线观看| 香港一级特黄大片在线播放| av亚洲中文天堂字幕网| 亚洲av在线观看尤物| 中字幕人妻熟女人妻a62v网| 欧美亚洲免费视频观看| 一区二区熟女人妻视频| 婷婷六月天中文字幕| 动漫美女的小穴视频| 超碰97人人做人人爱| 激情五月婷婷免费视频| 大胸性感美女羞爽操逼毛片| 黑人乱偷人妻中文字幕| 国产午夜亚洲精品麻豆| 黄片大全在线观看观看| 91福利在线视频免费观看| 亚洲精品无码久久久久不卡 | 93人妻人人揉人人澡人人| 偷拍3456eee| 日韩北条麻妃一区在线| 久久这里有免费精品| 天天干夜夜操天天舔| 青青青青青手机视频| 亚洲一区久久免费视频| 五月天久久激情视频| 中文字幕第1页av一天堂网| weyvv5国产成人精品的视频| 无码国产精品一区二区高潮久久4| 91极品大一女神正在播放| 国产福利小视频大全| 人妻久久无码中文成人| av中文字幕电影在线看| 伊人成人综合开心网| 老司机你懂得福利视频| 懂色av之国产精品| 欧美日本国产自视大全| 91传媒一区二区三区| 一区二区三区四区视频| 国产成人一区二区三区电影网站| 国产午夜男女爽爽爽爽爽视频| 一级黄片大鸡巴插入美女 | 91香蕉成人app下载| 亚洲 欧美 精品 激情 偷拍| 国产精品人妻66p| 任你操视频免费在线观看| 亚洲最大黄 嗯色 操 啊| 青青青青草手机在线视频免费看| 1024久久国产精品| 国产九色91在线视频| 第一福利视频在线观看| 美女小视频网站在线| 男人在床上插女人视频| 欧美成人综合色在线噜噜| 欧美乱妇无乱码一区二区| www日韩毛片av| 欧美交性又色又爽又黄麻豆| 亚洲中文字字幕乱码| 毛茸茸的大外阴中国视频| 91天堂精品一区二区| www骚国产精品视频| 欧美80老妇人性视频| 91av精品视频在线| 欧美亚洲自偷自拍 在线| 99精品国产免费久久| 国产亚洲精品品视频在线| 中文字幕av第1页中文字幕| 清纯美女在线观看国产| chinese国产盗摄一区二区| 久久香蕉国产免费天天| 2022天天干天天操| 亚洲2021av天堂| 偷拍3456eee| 日韩av大胆在线观看| 日本熟妇丰满厨房55| 天天操天天干天天插| 经典av尤物一区二区| 91p0rny九色露脸熟女| 欧美亚洲免费视频观看| 国产日韩精品一二三区久久久| 午夜美女少妇福利视频| 国产精品国色综合久久| 丰满的子国产在线观看| 韩国黄色一级二级三级| 超污视频在线观看污污污| 亚洲图库另类图片区| 中文 成人 在线 视频| 2022国产综合在线干| 亚洲国产成人在线一区| 欧美精品久久久久久影院| 夜色撩人久久7777| 日韩成人性色生活片| 久久久噜噜噜久久熟女av| 91一区精品在线观看| 欧美日本aⅴ免费视频| 天天操天天干天天艹| 成人18禁网站在线播放| 欧美偷拍亚洲一区二区| 久草视频在线看免费| 97国产福利小视频合集| 精品视频一区二区三区四区五区| 亚洲护士一区二区三区| 中文字幕第一页国产在线| 99re6热在线精品| 搞黄色在线免费观看| 日本熟妇色熟妇在线观看| 精品国产午夜视频一区二区| 色秀欧美视频第一页| 亚洲综合另类精品小说| 色在线观看视频免费的| 亚洲 欧美 自拍 偷拍 在线| 精品亚洲中文字幕av| 午夜激情精品福利视频| 18禁网站一区二区三区四区 | 国产一区二区神马久久| 亚洲天堂成人在线观看视频网站| 成年人免费看在线视频| 人人爱人人妻人人澡39| 亚洲国产精品久久久久蜜桃| 成人免费公开视频无毒| 精品久久久久久久久久久99| 成人sm视频在线观看| 久久99久久99精品影院| 天天干天天操天天爽天天摸| 2012中文字幕在线高清| 中文字幕在线乱码一区二区 | 男人天堂av天天操| 中文字幕人妻三级在线观看| 国产视频在线视频播放| 亚洲美女自偷自拍11页| 熟妇一区二区三区高清版| 中文字幕人妻熟女在线电影| 青草久久视频在线观看| 亚洲欧美激情人妻偷拍| 亚欧在线视频你懂的| 亚洲国产精品免费在线观看| 天天想要天天操天天干| 中文字幕一区二区三区蜜月| 又色又爽又黄的美女裸体| 爱爱免费在线观看视频| 日韩激情文学在线视频| 国产又粗又硬又大视频| 国际av大片在线免费观看| 熟女在线视频一区二区三区| 麻豆性色视频在线观看| 成人色综合中文字幕| 黑人巨大精品欧美视频| 国产大鸡巴大鸡巴操小骚逼小骚逼 | 男生用鸡操女生视频动漫 | 色爱av一区二区三区| 天天干天天日天天谢综合156 | 成人乱码一区二区三区av| 夜夜嗨av一区二区三区中文字幕| 9国产精品久久久久老师 | 欧美精品一二三视频| 亚洲精品国品乱码久久久久 | 欧美视频一区免费在线| 亚洲成人黄色一区二区三区| 久久热这里这里只有精品| 日视频免费在线观看| 国产精品视频欧美一区二区| 中国老熟女偷拍第一页| 美日韩在线视频免费看| 任你操任你干精品在线视频| 日韩激情文学在线视频| 人人爱人人妻人人澡39| 成年人该看的视频黄免费| 久草视频在线一区二区三区资源站 | 欧美精品一区二区三区xxxx| 天天干天天插天天谢| 91免费福利网91麻豆国产精品| 欧美成人猛片aaaaaaa| 大肉大捧一进一出好爽在线视频| 香港三日本三韩国三欧美三级| 66久久久久久久久久久| av在线免费中文字幕| av俺也去在线播放| 亚洲嫩模一区二区三区| 自拍偷拍亚洲精品第2页| 亚洲 欧美 自拍 偷拍 在线| 青青青青青青草国产| 成年午夜免费无码区| 午夜久久久久久久精品熟女| 搡老熟女一区二区在线观看| 亚洲va国产va欧美va在线| 国产男女视频在线播放| 青青草原网站在线观看| 欧美日韩激情啪啪啪| 日本韩国免费福利精品| 中文字幕午夜免费福利视频| 精品美女久久久久久| 国产+亚洲+欧美+另类| 亚洲最大免费在线观看| 日韩成人性色生活片| 久久久久久97三级| 五十路熟女av天堂| 男女啪啪视频免费在线观看| 天天日天天操天天摸天天舔| 久久久久五月天丁香社区| 91麻豆精品传媒国产黄色片| 国产视频一区二区午夜| 一区二区三区视频,福利一区二区| 国产a级毛久久久久精品| 福利在线视频网址导航| 蜜桃精品久久久一区二区| 人妻无码中文字幕专区| 视频一区二区综合精品| 一级黄片大鸡巴插入美女| 日本脱亚入欧是指什么| 亚洲护士一区二区三区| 端庄人妻堕落挣扎沉沦| 五月天色婷婷在线观看视频免费| 国产三级精品三级在线不卡| 97小视频人妻一区二区| 水蜜桃一区二区三区在线观看视频| 大鸡巴操b视频在线| 亚洲av自拍偷拍综合| 精品91自产拍在线观看一区| 成人国产小视频在线观看| 插小穴高清无码中文字幕| 偷拍自拍亚洲视频在线观看| 99国内精品永久免费视频| 中文字幕乱码人妻电影| 亚洲另类伦春色综合小| 操操网操操伊剧情片中文字幕网| 国产精品国产精品一区二区| 午夜精品一区二区三区福利视频| 天天操天天插天天色| 中文字幕免费福利视频6| 少妇ww搡性bbb91| 91色秘乱一区二区三区| 香港三日本三韩国三欧美三级| 任你操视频免费在线观看| 宅男噜噜噜666国产| 亚洲精品乱码久久久久久密桃明 | 在线观看视频网站麻豆| 一区二区三区综合视频| 韩国AV无码不卡在线播放| 男大肉棒猛烈插女免费视频| 亚洲精品国产综合久久久久久久久| 老司机免费视频网站在线看| 视频啪啪啪免费观看| av成人在线观看一区| 2020国产在线不卡视频| 中文字幕一区二区亚洲一区| 人妻最新视频在线免费观看| 大香蕉日本伊人中文在线| 成人福利视频免费在线| 亚洲免费福利一区二区三区| 中文人妻AV久久人妻水| 中文字幕在线一区精品| 午夜精品久久久久久99热| 国产亚洲欧美视频网站| 亚洲av午夜免费观看| 91香蕉成人app下载| 视频一区二区综合精品| 午夜91一区二区三区| 在线免费观看欧美小视频| 亚洲av无乱一区二区三区性色| 欧美日韩情色在线观看| 午夜大尺度无码福利视频| 粉嫩欧美美人妻小视频| 性感美女高潮视频久久久 | 在线免费观看国产精品黄色| 天天日夜夜操天天摸| 亚洲成人黄色一区二区三区| 综合激情网激情五月天| 97国产在线av精品| 人妻少妇av在线观看| 成人30分钟免费视频| 75国产综合在线视频| 日韩三级电影华丽的外出| 国内自拍第一页在线观看| 亚洲av无码成人精品区辽| 国产精品亚洲在线观看| 日韩中文字幕福利av| 日韩中文字幕精品淫| 78色精品一区二区三区| 最新的中文字幕 亚洲| 欧美成一区二区三区四区| 亚洲综合在线观看免费| 国产日本精品久久久久久久| 国产精品一区二区久久久av| 国产精品国产精品一区二区| yellow在线播放av啊啊啊| 东游记中文字幕版哪里可以看到| 日韩亚国产欧美三级涩爱| 国产午夜福利av导航| 亚洲激情,偷拍视频| 亚洲精品亚洲人成在线导航| 美女av色播在线播放| 不卡一不卡二不卡三| 最新黄色av网站在线观看| 93视频一区二区三区| 亚洲综合在线观看免费| 天天操夜夜操天天操天天操| 在线可以看的视频你懂的 | 国产成人自拍视频播放| 91在线免费观看成人| 99久久99久国产黄毛片| 深田咏美亚洲一区二区| 久久这里只有精品热视频| 欧美日本在线观看一区二区| aⅴ五十路av熟女中出| 亚洲伊人av天堂有码在线| 精品国产午夜视频一区二区| 国产精品伦理片一区二区| 精品高潮呻吟久久av| 日本少妇精品免费视频| 欧美精品久久久久久影院| 成年人的在线免费视频| aiss午夜免费视频| 99热99这里精品6国产| 91欧美在线免费观看| 91国产在线视频免费观看| 久久热久久视频在线观看| av手机在线观播放网站| 日韩欧美亚洲熟女人妻| 瑟瑟视频在线观看免费视频| 亚洲推理片免费看网站| tube69日本少妇| 欧美在线一二三视频| 视频一区二区综合精品| 欧美香蕉人妻精品一区二区| 大白屁股精品视频国产| 午夜久久香蕉电影网| 狠狠操狠狠操免费视频| 欧美天堂av无线av欧美| 五月天久久激情视频| 在线观看911精品国产| 国产综合高清在线观看| av天堂资源最新版在线看| 久久热这里这里只有精品| 一区二区三区日本伦理| 日韩三级黄色片网站| 淫秽激情视频免费观看| 经典av尤物一区二区| 2021天天色天天干| 2020韩国午夜女主播在线| 亚洲熟妇无码一区二区三区| 扒开腿挺进肉嫩小18禁视频| 日本av在线一区二区三区| 欧美黄色录像免费看的| 国产自拍在线观看成人| 色噜噜噜噜18禁止观看| 国产麻豆国语对白露脸剧情| 国产高潮无码喷水AV片在线观看| 一区二区三区四区视频在线播放| 91九色porny蝌蚪国产成人| 久久尻中国美女视频| 蜜桃视频在线欧美一区| 97国产福利小视频合集| 黑人大几巴狂插日本少妇| 免费在线播放a级片| 国产成人精品一区在线观看 | 年轻的人妻被夫上司侵犯| 好了av中文字幕在线| 激情国产小视频在线| 久草视频中文字幕在线观看| 久久久久91精品推荐99| 人妻另类专区欧美制服| 人妻熟女在线一区二区| 国产精品福利小视频a| 色呦呦视频在线观看视频| 亚洲 欧美 自拍 偷拍 在线| 国产janese在线播放| asmr福利视频在线观看| 97人人妻人人澡人人爽人人精品| 国产极品美女久久久久久| 午夜精品亚洲精品五月色| 国产日本精品久久久久久久| 久久三久久三久久三久久| 亚洲变态另类色图天堂网| 香港三日本三韩国三欧美三级| 丰满少妇人妻xxxxx| 我想看操逼黄色大片| 午夜福利资源综合激情午夜福利资| 天天操天天爽天天干| 亚洲视频在线视频看视频在线| 亚洲一区二区三区久久午夜 | 传媒在线播放国产精品一区| 国产精品久久久黄网站| 夜夜骑夜夜操夜夜奸| 噜噜色噜噜噜久色超碰| 福利国产视频在线观看| 91超碰青青中文字幕| 精产国品久久一二三产区区别| 韩国三级aaaaa高清视频| 熟女国产一区亚洲中文字幕| 国产精品一区二区久久久av| 青青操免费日综合视频观看| 99国内精品永久免费视频| av完全免费在线观看av| 91精品啪在线免费| 午夜激情久久不卡一区二区 | 岛国一区二区三区视频在线| 少妇一区二区三区久久久| 一区二区视频在线观看视频在线| 国产品国产三级国产普通话三级| 亚洲1区2区3区精华液| 国产女人被做到高潮免费视频| 深夜男人福利在线观看| 92福利视频午夜1000看| 扒开腿挺进肉嫩小18禁视频| 午夜激情久久不卡一区二区| 超pen在线观看视频公开97| 亚洲粉嫩av一区二区三区| 色哟哟国产精品入口| 中文字幕高清在线免费播放| 国产精品久久久久久久女人18| 亚洲精品午夜aaa久久| 最后99天全集在线观看| 中文字幕一区二 区二三区四区| 亚洲天天干 夜夜操| 国产精品视频资源在线播放| 亚洲成人线上免费视频观看| 91中文字幕免费在线观看| 天天日天天日天天射天天干 | 大香蕉玖玖一区2区| 青青草原色片网站在线观看 | 天天操天天射天天操天天天| 高清成人av一区三区| 中文字幕免费福利视频6| 黄色片年轻人在线观看| 久久久久国产成人精品亚洲午夜| 日日夜夜大香蕉伊人| 久草视频 久草视频2| 欧美特级特黄a大片免费| 在线新三级黄伊人网| 91精品国产91久久自产久强| 91av精品视频在线| 在线免费91激情四射 | 久久久久久九九99精品| 日本三极片中文字幕| 婷婷午夜国产精品久久久| 一区二区视频在线观看免费观看| 免费大片在线观看视频网站| 国产福利小视频二区| 国产亚洲成人免费在线观看| 日本真人性生活视频免费看| 成人国产激情自拍三区| 2018最新中文字幕在线观看| 超碰97人人做人人爱| 中文字幕欧美日韩射射一| 免费观看理论片完整版| 男人的天堂一区二区在线观看| 国产精品伦理片一区二区| 久久精品亚洲国产av香蕉| 99热久久这里只有精品| 91www一区二区三区| 亚洲成人国产综合一区| 在线成人日韩av电影| 高清一区二区欧美系列 | 日韩av大胆在线观看| 午夜精品亚洲精品五月色| 欧美中国日韩久久精品| 亚洲成人免费看电影| 性色av一区二区三区久久久| 午夜精品九一唐人麻豆嫩草成人| 强行扒开双腿猛烈进入免费版| 粉嫩小穴流水视频在线观看| 精品久久婷婷免费视频| 久草视频在线看免费| www骚国产精品视频| 成人网18免费视频版国产| 少妇ww搡性bbb91| 色花堂在线av中文字幕九九| 偷拍自拍亚洲美腿丝袜| 国产真实乱子伦a视频| 欧亚日韩一区二区三区观看视频| 亚洲中文字幕人妻一区| 五十路熟女人妻一区二| 91 亚洲视频在线观看| 国产精品国产三级国产精东| 9色在线视频免费观看| 水蜜桃国产一区二区三区| 91精品国产观看免费| 日本免费午夜视频网站| 欧美成人一二三在线网| 1区2区3区不卡视频| 狠狠嗨日韩综合久久| 国产刺激激情美女网站| 大陆胖女人与丈夫操b国语高清| 日韩欧美中文国产在线| 免费观看成年人视频在线观看| 青青操免费日综合视频观看| 少妇露脸深喉口爆吞精| 激情人妻校园春色亚洲欧美| 18禁免费av网站| 午夜精品福利一区二区三区p | 国产麻豆精品人妻av| 又粗又硬又猛又爽又黄的| 狍和女人的王色毛片| 亚洲国产在线精品国偷产拍| 青青青国产免费视频| 国产麻豆国语对白露脸剧情 | 激情色图一区二区三区| 欧美亚洲中文字幕一区二区三区| 国产极品美女久久久久久| 3344免费偷拍视频| 99视频精品全部15| 国产精品视频一区在线播放| 青青青视频自偷自拍38碰| 欧美亚洲免费视频观看| 亚洲 色图 偷拍 欧美| 九九热99视频在线观看97| 99亚洲美女一区二区三区| 91精品一区二区三区站长推荐| 同居了嫂子在线播高清中文| av在线资源中文字幕| 国产在线观看免费人成短视频| 91‖亚洲‖国产熟女| 午夜精品一区二区三区更新| 天天操夜夜操天天操天天操| 阴茎插到阴道里面的视频| 99国内精品永久免费视频| aaa久久久久久久久| 91国内视频在线观看| 天天干天天操天天玩天天射 | 丝袜肉丝一区二区三区四区在线| 欧美中国日韩久久精品| 色婷婷六月亚洲综合香蕉| 国产黄色a级三级三级三级| 最新中文字幕乱码在线| av破解版在线观看| 国产在线观看免费人成短视频| xxx日本hd高清| 熟女少妇激情五十路| 天天干天天操天天玩天天射| 日日夜夜大香蕉伊人| 日本熟妇一区二区x x| 国产久久久精品毛片| 成人精品视频99第一页| 久久这里只有精彩视频免费| 亚洲免费成人a v| 被大鸡吧操的好舒服视频免费| weyvv5国产成人精品的视频| av手机在线观播放网站| 婷婷六月天中文字幕| 日本高清在线不卡一区二区| 国产精品国色综合久久| 啊慢点鸡巴太大了啊舒服视频| 国产视频网站一区二区三区 | 成人国产小视频在线观看| 97精品成人一区二区三区| 婷婷激情四射在线观看视频| 38av一区二区三区| 欧洲黄页网免费观看| 亚洲第一黄色在线观看| 免费在线观看视频啪啪| 成人乱码一区二区三区av| 国产精品国产三级国产精东| 亚洲成人av在线一区二区| 美女张开腿让男生操在线看| 国产片免费观看在线观看| 亚洲国产最大av综合| 久久久精品精品视频视频| 免费看美女脱光衣服的视频| 中文字幕日韩精品就在这里| 日日摸夜夜添夜夜添毛片性色av| 四川乱子伦视频国产vip| 天天干夜夜操啊啊啊| 97资源人妻免费在线视频| 熟女人妻在线观看视频| 老司机在线精品福利视频| 中文字幕日韩精品日本| okirakuhuhu在线观看| 青青青国产片免费观看视频| 亚洲综合色在线免费观看| 狠狠地躁夜夜躁日日躁| 天天夜天天日天天日| 精品高跟鞋丝袜一区二区| 男人的天堂在线黄色| 福利视频网久久91| 国产又粗又猛又爽又黄的视频美国| 国产高清在线在线视频| 337p日本大胆欧美人| 91麻豆精品久久久久| 啊啊啊想要被插进去视频| 丝袜美腿欧美另类 中文字幕| 欧美一区二区三区高清不卡tv | 传媒在线播放国产精品一区 | 91久久人澡人人添人人爽乱| 777奇米久久精品一区| 久久久久久久精品成人热| 欧美viboss性丰满| 91久久精品色伊人6882| 亚洲最大黄了色网站| 日本人妻少妇18—xx| 国产九色91在线观看精品| 熟女国产一区亚洲中文字幕| 国产日韩欧美视频在线导航| 国产精品精品精品999| 中文字幕av熟女人妻| 亚洲精品国偷自产在线观看蜜桃| av一本二本在线观看| 亚洲免费福利一区二区三区| 精品一区二区三区三区色爱| 午夜在线精品偷拍一区二| 1000部国产精品成人观看视频 | 亚洲狠狠婷婷综合久久app| 一区二区三区日本伦理| 国产熟妇一区二区三区av| 日韩在线视频观看有码在线| 夜色福利视频在线观看| 国产成人精品午夜福利训2021| 国产精品三级三级三级| 早川濑里奈av黑人番号| 久久丁香花五月天色婷婷| 日本一道二三区视频久久| 天天艹天天干天天操| 美女张开两腿让男人桶av| 成人av亚洲一区二区| 欧美一区二区中文字幕电影| 亚洲欧美激情中文字幕| 亚洲蜜臀av一区二区三区九色| 免费在线看的黄片视频| 97超碰人人搞人人| 国产福利小视频大全| 欧美va不卡视频在线观看| 国产又粗又硬又猛的毛片视频| 一区二区三区美女毛片| 女生被男生插的视频网站| 鸡巴操逼一级黄色气| 国产精品自拍在线视频| 最新激情中文字幕视频| 熟女视频一区,二区,三区| 欧美精产国品一二三区| 久精品人妻一区二区三区| avjpm亚洲伊人久久| 大白屁股精品视频国产| 人妻3p真实偷拍一二区| 高清成人av一区三区| free性日本少妇| 成人福利视频免费在线| 亚洲精品国产久久久久久| 国产在线自在拍91国语自产精品| 久草视频首页在线观看| 久久久久久久久久一区二区三区 | jiujiure精品视频在线| 日韩中文字幕精品淫| 岛国av高清在线成人在线| 亚洲午夜电影之麻豆| 超碰公开大香蕉97| 成人亚洲国产综合精品| 日本一二三区不卡无| 亚洲欧美综合另类13p| 少妇深喉口爆吞精韩国| 老司机在线精品福利视频| 日美女屁股黄邑视频| 2021久久免费视频| 可以在线观看的av中文字幕| 青青青青青操视频在线观看| 一二三区在线观看视频| 在线观看免费岛国av| 午夜在线观看岛国av,com| 国产精品亚洲在线观看| 在线免费观看日本片| 揄拍成人国产精品免费看视频| 亚洲精品av在线观看| 日本成人不卡一区二区| 这里有精品成人国产99| 午夜激情精品福利视频| 伊人精品福利综合导航| 亚洲 清纯 国产com| 午夜精品久久久久麻豆影视| 视频在线亚洲一区二区| 婷婷色国产黑丝少妇勾搭AV| 欧美精品国产综合久久| 欧美在线偷拍视频免费看| 亚洲图片偷拍自拍区| 少妇一区二区三区久久久| 美女少妇亚洲精选av| 宅男噜噜噜666国产| 91社福利《在线观看| sspd152中文字幕在线| 中文 成人 在线 视频| 亚洲人人妻一区二区三区| 888亚洲欧美国产va在线播放| 天天综合天天综合天天网| 男人天堂最新地址av| 久久精品国产亚洲精品166m| 人人妻人人人操人人人爽| 天天操天天污天天射| 日韩中文字幕福利av| 一区二区三区久久中文字幕| 老司机深夜免费福利视频在线观看| 少妇人妻二三区视频| 成人在线欧美日韩国产| 国产不卡av在线免费| 青青草人人妻人人妻| 国产黄色大片在线免费播放| 中文字幕第三十八页久久| 亚洲精品乱码久久久久久密桃明| 国产日韩欧美视频在线导航| 欧美精品 日韩国产| 在线免费观看靠比视频的网站| 狠狠操操操操操操操操操| 国产精品亚洲在线观看| 久久久久久久精品成人热| 日本性感美女三级视频| 国产在线观看免费人成短视频| 最新中文字幕乱码在线| 色偷偷伊人大杳蕉综合网| 欧美日本在线观看一区二区| chinese国产盗摄一区二区| 又色又爽又黄的美女裸体| 亚洲卡1卡2卡三卡四老狼| 美女骚逼日出水来了| 91九色porny国产在线| 天天操天天爽天天干| 宅男噜噜噜666国产| 青青色国产视频在线| 亚洲国产在线精品国偷产拍| 又粗又长 明星操逼小视频| 成人午夜电影在线观看 久久| 宅男噜噜噜666免费观看| 亚洲av日韩av网站| 日本韩国亚洲综合日韩欧美国产| 天天日天天日天天射天天干| 日本熟妇一区二区x x| 97超碰国语国产97超碰| 亚洲综合自拍视频一区| 91九色porny国产蝌蚪视频| 欧美日韩国产一区二区三区三州| 国产精品一区二区av国| 美女大bxxxx内射| 亚洲精品国品乱码久久久久| 天美传媒mv视频在线观看| 熟女人妻三十路四十路人妻斩| 国产精品国产三级国产精东 | 夏目彩春在线中文字幕| av网址国产在线观看| 精品高跟鞋丝袜一区二区| 激情啪啪啪啪一区二区三区| 老司机福利精品免费视频一区二区| 国产又粗又猛又爽又黄的视频在线 | 亚洲粉嫩av一区二区三区| 欧美国产亚洲中英文字幕| 国产麻豆91在线视频| 激情啪啪啪啪一区二区三区| 亚洲天堂av最新网址| 日噜噜噜夜夜噜噜噜天天噜噜噜| 欧美精产国品一二三区| 午夜频道成人在线91| 少妇人妻真实精品视频| 国产亚洲欧美视频网站| 男人操女人的逼免费视频| 激情综合治理六月婷婷| 国产美女精品福利在线| 欧美专区日韩专区国产专区| 天天色天天操天天舔| 粗大的内捧猛烈进出爽大牛汉子| 3D动漫精品啪啪一区二区下载 | 日本少妇的秘密免费视频| 国产精品视频男人的天堂| 国产精品人妻熟女毛片av久| 好吊操视频这里只有精品| 欧美成人黄片一区二区三区| 91自产国产精品视频| 在线视频免费观看网| 动漫av网站18禁| 久久久久久久久久久久久97| 亚洲精品一线二线在线观看| 黄色三级网站免费下载| 又黄又刺激的午夜小视频| 日韩熟女av天堂系列| 欧美一区二区三区四区性视频| 大屁股熟女一区二区三区| 抽查舔水白紧大视频| 视频 国产 精品 熟女 | 快点插进来操我逼啊视频| 91自产国产精品视频| 亚洲精品欧美日韩在线播放 | 国产又大又黄免费观看| 国产精品三级三级三级| 成人精品视频99第一页| 国产九色91在线视频| 骚货自慰被发现爆操| 狠狠操操操操操操操操操| 亚洲狠狠婷婷综合久久app | 亚洲欧美激情中文字幕| 99久久激情婷婷综合五月天| 国产剧情演绎系列丝袜高跟| 中国熟女@视频91| 亚洲狠狠婷婷综合久久app| 97国产在线av精品| 成人av电影免费版| 日本一本午夜在线播放| 在线免费观看99视频| 亚洲特黄aaaa片| 丝袜美腿欧美另类 中文字幕| av森泽佳奈在线观看| 亚洲免费福利一区二区三区| 一二三区在线观看视频| 成人动漫大肉棒插进去视频| 欧美精品国产综合久久| 在线免费观看亚洲精品电影| 国产精品福利小视频a| 日韩亚国产欧美三级涩爱| 日本五十路熟新垣里子| 青青青青爽手机在线| 色婷婷久久久久swag精品| 女生被男生插的视频网站| ka0ri在线视频| 大白屁股精品视频国产| 97少妇精品在线观看| 国产午夜亚洲精品不卡在线观看 | 国产一级精品综合av| 欧美黄片精彩在线免费观看| 91国内精品自线在拍白富美| 天天日天天干天天干天天日| 涩涩的视频在线观看视频| 国产精品自偷自拍啪啪啪| 欧美偷拍自拍色图片| 夜色撩人久久7777| 在线视频自拍第三页| 骚货自慰被发现爆操| 91精品国产高清自在线看香蕉网| 2012中文字幕在线高清| 超黄超污网站在线观看| 黄色男人的天堂视频| 国产激情av网站在线观看| 日本三极片中文字幕| 日本中文字幕一二区视频| 中文字幕在线第一页成人| 亚洲熟女综合色一区二区三区四区| 国产麻豆乱子伦午夜视频观看| 美女被肏内射视频网站| 国产精品精品精品999| 黄色中文字幕在线播放| 天天操夜夜操天天操天天操 | 白嫩白嫩美女极品国产在线观看 | 亚洲激情av一区二区| 黑人巨大的吊bdsm| 亚洲av香蕉一区区二区三区犇| 88成人免费av网站| 91国产在线视频免费观看| weyvv5国产成人精品的视频| 欧美韩国日本国产亚洲| 人妻丝袜av在线播放网址| 黄工厂精品视频在线观看| 三级黄色亚洲成人av| 午夜免费观看精品视频| 香蕉aⅴ一区二区三区| av新中文天堂在线网址| 婷婷五月亚洲综合在线| 视频 一区二区在线观看| av天堂加勒比在线| 狠狠躁夜夜躁人人爽天天久天啪| 一区二区熟女人妻视频| 红杏久久av人妻一区| 青青青aaaa免费| 中文字幕在线永久免费播放| 欧美一区二区中文字幕电影| 亚洲欧美一卡二卡三卡| 中文字幕午夜免费福利视频| 男人的天堂一区二区在线观看| 欧美第一页在线免费观看视频| 男人的天堂av日韩亚洲| 2021国产一区二区| 国产精品sm调教视频| 综合精品久久久久97| 一级a看免费观看网站| 青青青青青操视频在线观看| 人人爱人人妻人人澡39| 91天堂天天日天天操| 4个黑人操素人视频网站精品91| 男人天堂最新地址av| 久久h视频在线观看| 男人和女人激情视频| 中文字幕人妻av在线观看| 九色视频在线观看免费| av视屏免费在线播放| 一区二区视频在线观看视频在线| 91精品资源免费观看| 欧美一区二区三区高清不卡tv| 一二三中文乱码亚洲乱码one| 久久久久久久久久一区二区三区| 中文字幕一区二 区二三区四区| 涩涩的视频在线观看视频| 黑人性生活视频免费看| 黄色无码鸡吧操逼视频| 大尺度激情四射网站| 日本www中文字幕| 国产在线观看黄色视频| 综合精品久久久久97| 91人妻精品一区二区在线看| gav成人免费播放| 2020国产在线不卡视频| 天天日天天干天天搡| 888欧美视频在线| 亚洲国产精品美女在线观看| AV天堂一区二区免费试看| 国产精品污污污久久| 国产日韩欧美视频在线导航| 亚洲av日韩精品久久久| 美女吃鸡巴操逼高潮视频| 久久久久久九九99精品| 麻豆精品成人免费视频| 黄工厂精品视频在线观看| 欧美精品免费aaaaaa| 亚洲欧美综合在线探花| 水蜜桃国产一区二区三区| 又粗又硬又猛又爽又黄的| 男人和女人激情视频| 一区二区三区四区五区性感视频 | 亚洲公开视频在线观看| 性感美女诱惑福利视频| 亚洲熟妇无码一区二区三区| 日韩近亲视频在线观看| 色狠狠av线不卡香蕉一区二区| 国产精品视频男人的天堂| 瑟瑟视频在线观看免费视频| av大全在线播放免费| 和邻居少妇愉情中文字幕| 偷青青国产精品青青在线观看| 国产欧美精品不卡在线| 我想看操逼黄色大片| 日本在线不卡免费视频| 视频一区二区在线免费播放| 伊人综合免费在线视频| 中文字幕乱码av资源| 自拍 日韩 欧美激情| 中文乱理伦片在线观看| 丰满的子国产在线观看| 国产精品视频欧美一区二区| 国产黄色大片在线免费播放| av日韩在线免费播放| www日韩毛片av| 99热99这里精品6国产| 中文字幕在线观看国产片| 欧美成人综合色在线噜噜| 欧美区一区二区三视频| 一区二区久久成人网| 2022天天干天天操| 天天射,天天操,天天说| 一区二区熟女人妻视频| 国产精品一区二区三区蜜臀av| 中文字母永久播放1区2区3区| 欧美一区二区三区激情啪啪啪| 午夜的视频在线观看| 中国产一级黄片免费视频播放| 午夜免费观看精品视频| 曰本无码人妻丰满熟妇啪啪| 亚洲欧美福利在线观看| 一色桃子久久精品亚洲| 日本av在线一区二区三区| 精品美女在线观看视频在线观看| 国产成人自拍视频在线免费观看| 夜女神免费福利视频| 色狠狠av线不卡香蕉一区二区| 被大鸡吧操的好舒服视频免费| 天天日夜夜干天天操| 啊用力插好舒服视频| 日曰摸日日碰夜夜爽歪歪 | 国产97视频在线精品| 偷拍自拍国产在线视频| 日韩三级黄色片网站| 在线视频这里只有精品自拍| 国产a级毛久久久久精品| 色综合色综合色综合色| 日韩欧美制服诱惑一区在线| 水蜜桃国产一区二区三区| 天天综合天天综合天天网| 在线观看免费岛国av| av手机在线观播放网站| 免费男阳茎伸入女阳道视频| 午夜场射精嗯嗯啊啊视频| 亚洲一区二区三区五区 | 色花堂在线av中文字幕九九| 成人亚洲精品国产精品| 成人精品视频99第一页| 中英文字幕av一区| 亚洲图片欧美校园春色| 99人妻视频免费在线| 国产剧情演绎系列丝袜高跟| 91国语爽死我了不卡| 亚洲女人的天堂av| 成人高潮aa毛片免费| 天天日天天日天天射天天干| 国产一区二区视频观看| 国产大学生援交正在播放| 99热99这里精品6国产| 大陆av手机在线观看| 中文字幕乱码人妻电影| 色婷婷综合激情五月免费观看| 婷婷综合亚洲爱久久| 国产普通话插插视频| 成人高清在线观看视频| 国产一区二区三免费视频 | 青青草原色片网站在线观看| 91人妻精品一区二区在线看| 人妻丰满熟妇综合网| 夜夜骑夜夜操夜夜奸| 揄拍成人国产精品免费看视频| 国产福利小视频免费观看| 在线观看免费视频网| 国产91久久精品一区二区字幕| 91精品国产高清自在线看香蕉网| 一二三中文乱码亚洲乱码one| 岛国免费大片在线观看| 91麻豆精品传媒国产黄色片| 97国产福利小视频合集| 2022中文字幕在线| 五十路息与子猛烈交尾视频| 一区二区三区精品日本| 色秀欧美视频第一页| 大胆亚洲av日韩av| 97人人模人人爽人人喊| 人人妻人人爽人人添夜| 亚洲av琪琪男人的天堂| 色综合久久无码中文字幕波多| 91中文字幕免费在线观看| 1769国产精品视频免费观看| av俺也去在线播放| 日本丰满熟妇BBXBBXHD| 福利午夜视频在线观看| 国产视频在线视频播放| 中文字幕+中文字幕| 少妇人妻久久久久视频黄片| 三级等保密码要求条款| 欧美精品国产综合久久| 在线观看视频网站麻豆| 午夜在线精品偷拍一区二| 亚洲国产在线精品国偷产拍| 国产亚洲天堂天天一区| 国产成人精品午夜福利训2021| 91九色porny蝌蚪国产成人| 国内精品在线播放第一页| 天天干天天搞天天摸| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 青青青aaaa免费| eeuss鲁片一区二区三区| 欧美地区一二三专区| 亚洲一区二区久久久人妻| 亚洲丝袜老师诱惑在线观看| 天天日天天干天天要| 国产变态另类在线观看| 亚洲激情av一区二区| 欧美另类一区二区视频| 欧美亚洲少妇福利视频| 一区二区三区 自拍偷拍| 亚洲日本一区二区三区| 日韩欧美一级精品在线观看| 亚洲精品国品乱码久久久久| 97a片免费在线观看| 91九色国产porny蝌蚪| 男人天堂av天天操| 91福利视频免费在线观看| 中文字幕第1页av一天堂网| 天天日天天添天天爽| 亚洲自拍偷拍综合色| 久久久久久九九99精品| 日本少妇人妻xxxxxhd| 狠狠地躁夜夜躁日日躁| 天天日天天操天天摸天天舔| 人妻丝袜诱惑我操她视频| 亚洲一区二区三区五区| 中文字幕 码 在线视频| avjpm亚洲伊人久久| 超级av免费观看一区二区三区| aaa久久久久久久久| 午夜精品在线视频一区| 久久美欧人妻少妇一区二区三区| 国产精品女邻居小骚货| 欧美日韩激情啪啪啪| 欧美日本在线视频一区| 日韩欧美中文国产在线| 国产精品自拍视频大全| 亚洲精品久久视频婷婷| 人妻最新视频在线免费观看| 91she九色精品国产| 日本xx片在线观看| 精品久久久久久久久久久久人妻| 极品丝袜一区二区三区| 日韩精品中文字幕福利| 亚洲av男人天堂久久| 自拍偷拍日韩欧美亚洲| 精品一区二区三区三区88| 日本中文字幕一二区视频| 欧美亚洲少妇福利视频| 99人妻视频免费在线| 国产伦精品一区二区三区竹菊| 青青青青操在线观看免费| 国产精品手机在线看片| 57pao国产一区二区| 黄色黄色黄片78在线| 日本韩国亚洲综合日韩欧美国产| aaa久久久久久久久| 51国产偷自视频在线播放| jiujiure精品视频在线| 人人妻人人澡人人爽人人dvl| 丝袜国产专区在线观看| 亚洲美女高潮喷浆视频| 大鸡巴操b视频在线| 亚洲乱码中文字幕在线| 少妇人妻100系列| 国产精品国产三级麻豆| 人妻无码中文字幕专区| 99热99re在线播放| 日本一本午夜在线播放| 强行扒开双腿猛烈进入免费版| 日本免费一级黄色录像 | 香港三日本三韩国三欧美三级| 精品久久久久久高潮| 无码日韩人妻精品久久| 日韩a级黄色小视频| 中文字幕在线观看极品视频| 91免费放福利在线观看| 日本男女操逼视频免费看| 国产欧美日韩在线观看不卡| 天堂av在线官网中文| 日本美女成人在线视频| 2018最新中文字幕在线观看| 国产精品自拍偷拍a| 国产高清在线观看1区2区| 大鸡巴操娇小玲珑的女孩逼| 亚洲国产中文字幕啊啊啊不行了 | 51国产偷自视频在线播放| 丰满少妇人妻xxxxx| 亚洲天天干 夜夜操| 亚洲福利精品视频在线免费观看| 18禁免费av网站| 亚洲熟女女同志女同| 日本人竟这样玩学生妹| 少妇人妻真实精品视频| 欧美va不卡视频在线观看| 999热精品视频在线| 国产午夜福利av导航| 毛片一级完整版免费| 绝顶痉挛大潮喷高潮无码| 久久丁香花五月天色婷婷| 国产高清在线观看1区2区| 亚洲公开视频在线观看| yy6080国产在线视频| 福利午夜视频在线合集| 在线观看日韩激情视频| 午夜美女少妇福利视频| 黑人解禁人妻叶爱071| 大鸡巴操b视频在线| japanese五十路熟女熟妇| 91片黄在线观看喷潮| 久久丁香花五月天色婷婷| 日本一二三区不卡无| 大香蕉大香蕉大香蕉大香蕉大香蕉| 亚洲综合自拍视频一区| 亚洲精品久久综合久| 97人妻夜夜爽二区欧美极品| 天天综合天天综合天天网| 午夜的视频在线观看| 中文字幕人妻熟女在线电影| 国产欧美精品一区二区高清 | 精品人人人妻人人玩日产欧| av中文字幕电影在线看| 亚洲欧美综合在线探花| 日本女人一级免费片| 一区二区在线观看少妇| 91老熟女连续高潮对白| 国产使劲操在线播放| 久久久久久性虐视频| 性感美女高潮视频久久久| 91精品国产观看免费| 国产一区二区火爆视频| 精品久久久久久久久久久a√国产| 夫妻在线观看视频91| 懂色av蜜桃a v| 懂色av之国产精品| 久久久久久9999久久久久| 青娱乐极品视频青青草| 精品老妇女久久9g国产| 欧美视频中文一区二区三区| 五十路熟女av天堂| 视频二区在线视频观看| 久久精品国产999| 久碰精品少妇中文字幕av| 在线视频这里只有精品自拍| 99av国产精品欲麻豆| 丝袜国产专区在线观看| 91精品国产观看免费| 日本福利午夜电影在线观看| 可以免费看的www视频你懂的| 19一区二区三区在线播放| 少妇高潮无套内谢麻豆| 黑人巨大精品欧美视频| 中文字幕一区二区三区蜜月| chinese国产盗摄一区二区 | 亚洲免费国产在线日韩| 天天摸天天亲天天舔天天操天天爽| 狠狠躁夜夜躁人人爽天天久天啪| 国产精品久久9999| 天天日天天添天天爽| 中文字幕免费福利视频6| 午夜精品福利91av| 熟女视频一区,二区,三区| 含骚鸡巴玩逼逼视频| 丝袜长腿第一页在线| av完全免费在线观看av| 亚洲色偷偷综合亚洲AV伊人| 91免费福利网91麻豆国产精品| h国产小视频福利在线观看| 午夜精品一区二区三区更新| 一区二区三区麻豆福利视频| 国产麻豆乱子伦午夜视频观看| 伊人成人综合开心网| 欧美黄色录像免费看的| 日曰摸日日碰夜夜爽歪歪| 极品性荡少妇一区二区色欲| 天天日天天鲁天天操| 97黄网站在线观看| 在线免费观看黄页视频| 国产日本欧美亚洲精品视| 国产在线观看免费人成短视频| 亚洲日本一区二区久久久精品| 亚洲狠狠婷婷综合久久app| 亚洲伊人久久精品影院一美女洗澡 | 亚洲在线一区二区欧美| 99精品免费观看视频| 国产又粗又猛又爽又黄的视频美国| 开心 色 六月 婷婷| 日韩美女综合中文字幕pp| 久草电影免费在线观看| 伊人综合aⅴ在线网| 久久久久久久一区二区三| 国产熟妇一区二区三区av| 日本乱人一区二区三区| 一区二区在线视频中文字幕| 亚洲激情偷拍一区二区| 老司机欧美视频在线看| 亚洲激情,偷拍视频| 一区二区视频在线观看视频在线 | 午夜精彩视频免费一区| 亚洲av无乱一区二区三区性色| 亚洲欧美清纯唯美另类| 美女张开腿让男生操在线看| 亚洲高清国产拍青青草原| 国产精品人久久久久久| 日本熟女精品一区二区三区| 日本性感美女三级视频| av老司机精品在线观看| 99婷婷在线观看视频| 综合色区亚洲熟妇shxstz| 久久精品在线观看一区二区| aaa久久久久久久久| 日本五十路熟新垣里子| 中文亚洲欧美日韩无线码| 国产精品一区二区三区蜜臀av| 99热国产精品666| 99婷婷在线观看视频| 五十路老熟女码av| 欧美精品一二三视频| 一个色综合男人天堂| 97超碰国语国产97超碰| 综合色区亚洲熟妇shxstz| 又大又湿又爽又紧A视频| 97欧洲一区二区精品免费| 少妇露脸深喉口爆吞精| 欧美黄色录像免费看的| caoporn蜜桃视频| 日韩二区视频一线天婷婷五| av手机在线免费观看日韩av| 国产成人精品一区在线观看| 国产午夜无码福利在线看| 2021天天色天天干| 一区二区三区四区中文| 中文字幕AV在线免费看 | 日韩激情文学在线视频| 毛片一级完整版免费| 国产麻豆剧果冻传媒app| 成人福利视频免费在线| 97a片免费在线观看| 午夜精品一区二区三区4| av欧美网站在线观看| 91一区精品在线观看| 在线观看日韩激情视频| 久久永久免费精品人妻专区 | 亚洲日本一区二区久久久精品| 成人av在线资源网站| 超鹏97历史在线观看| 风流唐伯虎电视剧在线观看| 这里有精品成人国产99| 热思思国产99re| 五十路丰满人妻熟妇| 在线可以看的视频你懂的| 欧美爆乳肉感大码在线观看 | 久久www免费人成一看片| 日本丰满熟妇BBXBBXHD| 久久免看30视频口爆视频| 日比视频老公慢点好舒服啊| 91精品国产黑色丝袜| 97色视频在线观看| 五月天久久激情视频| 国产精品三级三级三级| 国产在线自在拍91国语自产精品| 中英文字幕av一区| 天天操夜夜操天天操天天操| 日韩美女精品视频在线观看网站| 成年人该看的视频黄免费| 国产亚洲视频在线二区| 亚洲 国产 成人 在线| 欧美一级片免费在线成人观看| 在线不卡成人黄色精品| 超碰97人人做人人爱| 9国产精品久久久久老师 | 黑人巨大精品欧美视频| 日本免费一级黄色录像| 初美沙希中文字幕在线| 爱爱免费在线观看视频| 国产麻豆乱子伦午夜视频观看| 女同性ⅹxx女同hd| 日本精品一区二区三区在线视频。| 91免费放福利在线观看| 亚洲超碰97人人做人人爱| 久草电影免费在线观看| 91免费福利网91麻豆国产精品| 亚洲成人三级在线播放| 青青青青青青青在线播放视频| 青草亚洲视频在线观看| 在线观看av2025| 91麻豆精品秘密入口在线观看| 国产九色91在线观看精品| 超碰公开大香蕉97| 国产黄色a级三级三级三级| 亚洲国产美女一区二区三区软件 | 老司机你懂得福利视频| 午夜国产免费福利av| 亚洲中文字幕综合小综合| 在线观看av观看av| 亚洲av自拍天堂网| 在线播放 日韩 av| 丰满的继坶3中文在线观看| xxx日本hd高清| 亚洲av成人网在线观看| 男人的天堂在线黄色| 国产视频网站一区二区三区 | 扒开腿挺进肉嫩小18禁视频| 国产日韩精品电影7777| 亚洲精品亚洲人成在线导航| 日韩在线中文字幕色| 美女av色播在线播放| 天天日天天玩天天摸| 99久久99久国产黄毛片| 少妇与子乱在线观看| 国产九色91在线观看精品| 国产精品欧美日韩区二区| 熟女人妻三十路四十路人妻斩| 天天操天天干天天插| 国产视频网站一区二区三区| 激情人妻校园春色亚洲欧美 | 中文字幕人妻三级在线观看| 亚洲精品国产久久久久久| 久久免看30视频口爆视频| 中国熟女一区二区性xx| 成年人啪啪视频在线观看| 姐姐的朋友2在线观看中文字幕| 久久久久久99国产精品| av在线观看网址av| 红杏久久av人妻一区| 精品人妻一二三区久久| 亚洲一级 片内射视正片| 综合页自拍视频在线播放| 免费国产性生活视频| 亚洲免费av在线视频| 特一级特级黄色网片| 午夜大尺度无码福利视频| 一二三区在线观看视频| 国产三级精品三级在线不卡| 亚洲第一黄色在线观看| 青青草视频手机免费在线观看| 自拍偷拍 国产资源| 亚洲成人线上免费视频观看| 精品亚洲中文字幕av| 一区二区三区日韩久久| 亚洲精品ww久久久久久| 久久这里只有精品热视频| 成人激情文学网人妻| 日本欧美视频在线观看三区| 国产日韩欧美视频在线导航| 伊人综合免费在线视频| 国产精品视频一区在线播放| 亚洲 国产 成人 在线| 亚洲一区二区激情在线| 狍和女人的王色毛片| 日韩写真福利视频在线观看| 不卡精品视频在线观看| 福利在线视频网址导航| 精品国产亚洲av一淫| 色综合久久无码中文字幕波多| 日本欧美视频在线观看三区| 天天操天天干天天艹| 欧美视频中文一区二区三区| 久草福利电影在线观看| 不戴胸罩引我诱的隔壁的人妻| 亚洲欧美综合另类13p| 欧美香蕉人妻精品一区二区| 大鸡巴操娇小玲珑的女孩逼| 亚洲精品一区二区三区老狼| 成熟丰满熟妇高潮xx×xx| 阴茎插到阴道里面的视频| 国产夫妻视频在线观看免费| 精品人妻一二三区久久| 精品亚洲在线免费观看| 欧美中文字幕一区最新网址| av亚洲中文天堂字幕网| 狠狠嗨日韩综合久久| 姐姐的朋友2在线观看中文字幕 | 绝色少妇高潮3在线观看| 亚洲精品亚洲人成在线导航| 日韩精品中文字幕在线| av天堂中文免费在线| 边摸边做超爽毛片18禁色戒| 久久久制服丝袜中文字幕| 天天日夜夜操天天摸| 久久久久久九九99精品| 动漫美女的小穴视频| 大肉大捧一进一出好爽在线视频 | 18禁精品网站久久| 中文字幕高清资源站| 无码日韩人妻精品久久| 91中文字幕免费在线观看| 成人av天堂丝袜在线观看| 98视频精品在线观看| 日韩中文字幕精品淫| 在线国产日韩欧美视频| 日本乱人一区二区三区| 中文字幕乱码人妻电影| 天堂av在线播放免费| 青青青青草手机在线视频免费看| 亚洲少妇高潮免费观看| 亚洲特黄aaaa片| 特一级特级黄色网片| 99精品亚洲av无码国产另类| 香蕉片在线观看av| 免费观看丰满少妇做受| 久久久久国产成人精品亚洲午夜| av老司机亚洲一区二区| 五十路人妻熟女av一区二区| 午夜精品一区二区三区更新| 哥哥姐姐综合激情小说| 美洲精品一二三产区区别| 亚洲欧美自拍另类图片| 青青青青爽手机在线| 亚洲欧美成人综合在线观看| 五十路丰满人妻熟妇| chinese国产盗摄一区二区| www骚国产精品视频| 国产九色91在线观看精品| 欧美地区一二三专区| 午夜精品一区二区三区更新| 天天综合天天综合天天网| 亚洲一级av无码一级久久精品 | 国产一区二区视频观看| 天天日天天日天天射天天干| 欧美伊人久久大香线蕉综合| 日韩av有码中文字幕| av男人天堂狠狠干| 天天干夜夜操啊啊啊| 午夜福利人人妻人人澡人人爽| 2022中文字幕在线| 91精品高清一区二区三区| 亚洲精品国产在线电影| 伊拉克及约旦宣布关闭领空| 91社福利《在线观看| 日韩在线中文字幕色| 免费观看国产综合视频| 欧美色婷婷综合在线| 色婷婷久久久久swag精品| 好男人视频在线免费观看网站| 亚洲在线免费h观看网站| 国产女人叫床高潮大片视频| 黄色在线观看免费观看在线| 3344免费偷拍视频| 日本后入视频在线观看| 亚洲综合一区成人在线| 精品黑人巨大在线一区| 在线视频免费观看网| 亚洲欧美日韩视频免费观看| 亚洲欧美色一区二区| 亚洲欧美综合在线探花| 国产janese在线播放| 日韩特级黄片高清在线看| 在线观看一区二区三级| 婷婷久久久久深爱网| 日韩美av高清在线| 午夜毛片不卡免费观看视频| 1769国产精品视频免费观看| 亚洲色偷偷综合亚洲AV伊人| 丰满少妇翘臀后进式| 日本黄色三级高清视频| 少妇人妻真实精品视频| 青青青青操在线观看免费| 蜜桃久久久久久久人妻| 人妻素人精油按摩中出| 成人性爱在线看四区| 综合色区亚洲熟妇shxstz| 97小视频人妻一区二区| 亚洲男人在线天堂网| asmr福利视频在线观看| okirakuhuhu在线观看| 欧洲亚洲欧美日韩综合| 懂色av之国产精品| 黑人解禁人妻叶爱071| 美女视频福利免费看| 日本美女成人在线视频| 蝴蝶伊人久久中文娱乐网| 十八禁在线观看地址免费| 国产a级毛久久久久精品| av大全在线播放免费| 国产高潮无码喷水AV片在线观看| 婷婷久久久久深爱网| 免费观看污视频网站| 婷婷午夜国产精品久久久| 91在线免费观看成人| 日本高清成人一区二区三区| 岳太深了紧紧的中文字幕| 午夜美女福利小视频| 日本一本午夜在线播放| av俺也去在线播放| 91亚洲精品干熟女蜜桃频道| 欧美va亚洲va天堂va| 中文字幕在线欧美精品| 国产三级精品三级在线不卡| 老有所依在线观看完整版| 五十路在线观看完整版| 亚洲免费福利一区二区三区| 精品国产亚洲av一淫| 青青热久免费精品视频在线观看 | av俺也去在线播放| 国产精品久久9999| 黄色的网站在线免费看| 国产成人精品久久二区91| 免费费一级特黄真人片| 一色桃子人妻一区二区三区| 人妻在线精品录音叫床| 亚洲成人av一区在线| 男人的天堂av日韩亚洲| 热99re69精品8在线播放| 桃色视频在线观看一区二区| 日比视频老公慢点好舒服啊| 视频 一区二区在线观看| 婷婷激情四射在线观看视频| 免费观看国产综合视频| 青青尤物在线观看视频网站| 国产亚洲精品品视频在线| 男人天堂色男人av| 日韩精品一区二区三区在线播放| 亚洲综合图片20p| 亚洲激情av一区二区| caoporm超碰国产| 亚洲精品欧美日韩在线播放| 韩国三级aaaaa高清视频| gay gay男男瑟瑟在线网站| 大香蕉伊人中文字幕| 狠狠地躁夜夜躁日日躁| 老熟妇xxxhd老熟女| 天天干夜夜操天天舔| 一区二区三区日本伦理| 亚洲免费福利一区二区三区| 热思思国产99re| 亚洲精品午夜aaa久久| 亚洲av自拍偷拍综合| 91久久综合男人天堂| AV无码一区二区三区不卡| 天天日夜夜操天天摸| 天天插天天狠天天操| 精品少妇一二三视频在线| 久久久久久97三级| 蜜臀成人av在线播放| 日日摸夜夜添夜夜添毛片性色av| 一区二区视频视频视频| 青青热久免费精品视频在线观看| 快点插进来操我逼啊视频| 日日夜夜大香蕉伊人| 中文字幕av第1页中文字幕| 中文字母永久播放1区2区3区 | 97人妻总资源视频| 99热久久这里只有精品8| 国产一区成人在线观看视频| 这里有精品成人国产99| 日本午夜福利免费视频| 偷青青国产精品青青在线观看 | 78色精品一区二区三区| 密臀av一区在线观看| 特大黑人巨大xxxx| 精品久久久久久久久久久99| 97年大学生大白天操逼| 大香蕉伊人中文字幕| 久久久久91精品推荐99| 国产九色91在线观看精品| 亚洲免费在线视频网站| 开心 色 六月 婷婷| 97人妻人人澡爽人人精品| 午夜久久久久久久精品熟女| av在线资源中文字幕| 国产女人露脸高潮对白视频| 中文字幕无码一区二区免费| 精品一区二区三四区| 三级等保密码要求条款| 中文字幕日韩精品日本| 超级碰碰在线视频免费观看| 18禁美女黄网站色大片下载| 岛国青草视频在线观看| 欧美另类z0z变态| 亚洲av成人免费网站| 婷婷激情四射在线观看视频| 99亚洲美女一区二区三区| 亚洲一区制服丝袜美腿| 大鸡巴插入美女黑黑的阴毛| 日韩精品激情在线观看| 成年人免费看在线视频| 国产女人露脸高潮对白视频| 青青青视频自偷自拍38碰| 亚洲av人人澡人人爽人人爱| 日美女屁股黄邑视频| 嫩草aⅴ一区二区三区| 大香蕉伊人中文字幕| 91人妻精品一区二区久久| 亚洲免费在线视频网站| 国产一区二区火爆视频| 亚洲 中文 自拍 另类 欧美| 丰满少妇翘臀后进式| 国产黄色大片在线免费播放| 人妻爱爱 中文字幕| 亚洲1卡2卡三卡4卡在线观看| av中文字幕在线观看第三页| 一级黄片大鸡巴插入美女| 亚洲欧美精品综合图片小说| 日韩精品激情在线观看| 一区二区三区麻豆福利视频| 麻豆精品成人免费视频| 狍和女人的王色毛片| 欧美精品欧美极品欧美视频| 涩爱综合久久五月蜜臀| 日本女人一级免费片| 二区中出在线观看老师| 亚洲图片偷拍自拍区| 午夜青青草原网在线观看| 精品人人人妻人人玩日产欧| 最新91精品视频在线 | 欧美日韩精品永久免费网址| 任你操视频免费在线观看| 日比视频老公慢点好舒服啊| 一区二区三区综合视频| 日比视频老公慢点好舒服啊| 男女啪啪视频免费在线观看| 抽查舔水白紧大视频| 亚洲成人熟妇一区二区三区| 亚洲欧美另类自拍偷拍色图| 国产真实乱子伦a视频| 人妻熟女中文字幕aⅴ在线| 色偷偷伊人大杳蕉综合网| 免费岛国喷水视频在线观看 | 国产精品一区二区av国| av网址国产在线观看| av中文字幕国产在线观看| 搞黄色在线免费观看| av在线资源中文字幕| 亚洲美女美妇久久字幕组| 欧美日韩在线精品一区二区三| av中文字幕国产在线观看| 日本又色又爽又黄又粗| 国产黄色片在线收看| 免费在线看的黄网站| 国产变态另类在线观看| 亚洲精品国产在线电影| 在线免费观看日本片| 成人资源在线观看免费官网| 好吊视频—区二区三区| 韩国黄色一级二级三级| 精品91高清在线观看| yellow在线播放av啊啊啊| 经典亚洲伊人第一页| 亚洲熟色妇av日韩熟色妇在线| 日本高清在线不卡一区二区| 伊人情人综合成人久久网小说| 777奇米久久精品一区| 99国产精品窥熟女精品| 老司机免费福利视频网| 2020国产在线不卡视频| 日本在线一区二区不卡视频| 在线免费观看日本伦理| 成熟丰满熟妇高潮xx×xx| 国产精选一区在线播放| 青青青视频手机在线观看| 一区二区三区久久中文字幕| 日韩欧美高清免费在线| 粉嫩欧美美人妻小视频| 亚洲在线观看中文字幕av| 超pen在线观看视频公开97| 丝袜美腿视频诱惑亚洲无| rct470中文字幕在线| 国产性色生活片毛片春晓精品 | 日日操综合成人av| 欧亚乱色一区二区三区| 9国产精品久久久久老师| 久久这里只有精品热视频| 欧美麻豆av在线播放| 中文字幕在线观看国产片| 岛国免费大片在线观看| 人妻最新视频在线免费观看| 3337p日本欧洲大胆色噜噜| 十八禁在线观看地址免费| 漂亮 人妻被中出中文| 国产第一美女一区二区三区四区| 天天躁日日躁狠狠躁av麻豆| 偷拍自拍 中文字幕| 人妻熟女中文字幕aⅴ在线| 女同久久精品秋霞网| 熟妇一区二区三区高清版| 沙月文乃人妻侵犯中文字幕在线| 人妻少妇精品久久久久久| 亚洲免费在线视频网站| 日本18禁久久久久久| 二区中出在线观看老师| 亚洲国产欧美一区二区三区久久| 欧美国产亚洲中英文字幕| av破解版在线观看| 久久永久免费精品人妻专区| 天天射夜夜操狠狠干| 欧美成人综合色在线噜噜| 在线免费观看国产精品黄色| 亚欧在线视频你懂的| 国产精品黄页网站视频| 国产高清女主播在线| 综合一区二区三区蜜臀| 亚洲激情av一区二区| 偷拍自拍亚洲视频在线观看| 91天堂天天日天天操| 啊啊啊想要被插进去视频| 亚洲综合自拍视频一区| 日本韩国在线观看一区二区| 国产精品一区二区三区蜜臀av| 午夜美女少妇福利视频| 宅男噜噜噜666国产| 青娱乐最新视频在线| 精彩视频99免费在线| 久久精品视频一区二区三区四区 | 国产日韩一区二区在线看| 顶级尤物粉嫩小尤物网站| 激情伦理欧美日韩中文字幕| 欧美视频综合第一页| gay gay男男瑟瑟在线网站| 黑人3p华裔熟女普通话| 少妇露脸深喉口爆吞精| 天天操天天污天天射| 国产白嫩美女一区二区| 福利视频广场一区二区| 人妻丝袜诱惑我操她视频| 亚洲熟妇久久无码精品| 亚洲欧美在线视频第一页| 早川濑里奈av黑人番号| 日本午夜久久女同精女女| 亚洲丝袜老师诱惑在线观看| 日美女屁股黄邑视频| 日美女屁股黄邑视频| 国产视频网站国产视频| 在线观看免费av网址大全| 天天色天天爱天天爽| 国产超码片内射在线| 天天干天天操天天爽天天摸| 日本美女成人在线视频| 日韩中文字幕福利av| 又大又湿又爽又紧A视频| 精品久久久久久久久久久99| 人人妻人人爱人人草| 91色网站免费在线观看| 国产欧美日韩第三页| 午夜婷婷在线观看视频| 精品日产卡一卡二卡国色天香| 偷拍3456eee| 日韩近亲视频在线观看| 成人影片高清在线观看| 在线播放一区二区三区Av无码| 国产成人精品av网站| 天天日天天操天天摸天天舔| 欧美国品一二三产区区别| 青青青国产片免费观看视频| 天天干天天操天天摸天天射| 欧美性受xx黑人性猛交| 美女 午夜 在线视频| 免费观看成年人视频在线观看| 欧美精品 日韩国产| 国产欧美日韩第三页| 一区二区三区四区视频| 老司机免费福利视频网| 欧美一级片免费在线成人观看| 日本成人一区二区不卡免费在线| 欧美男人大鸡吧插女人视频| 蜜桃视频入口久久久| av大全在线播放免费| 99re国产在线精品| 在线观看免费av网址大全| 老司机深夜免费福利视频在线观看| 视频 国产 精品 熟女 | 大胸性感美女羞爽操逼毛片| 亚洲国际青青操综合网站| 日日操综合成人av| 精品久久久久久久久久久a√国产| 青青青视频自偷自拍38碰| 天天做天天干天天操天天射| 日韩在线中文字幕色| 成人免费毛片aaaa| 亚洲区美熟妇久久久久| 久久久噜噜噜久久熟女av| 亚洲欧美自拍另类图片| 久久久久五月天丁香社区| 亚洲天天干 夜夜操| 黑人变态深video特大巨大| 美女骚逼日出水来了| 亚洲麻豆一区二区三区| 免费看国产av网站| 伊拉克及约旦宣布关闭领空| 2018在线福利视频| 97国产福利小视频合集| 日韩精品中文字幕播放| 欧美黄片精彩在线免费观看| 中文字幕在线观看国产片| 日本女大学生的黄色小视频| 精品亚洲在线免费观看| 把腿张开让我插进去视频| 国产日韩精品一二三区久久久| 91国产资源在线视频| 国产亚洲精品视频合集| 日本av高清免费网站| 青青青青青青青在线播放视频| 欧美中国日韩久久精品| 亚洲成人黄色一区二区三区| 亚洲精品乱码久久久本| 亚洲在线一区二区欧美| 精品久久久久久久久久久久人妻| 国产精品久久久久网| 亚洲国产成人在线一区| 一区二区三区在线视频福利| 欧美80老妇人性视频| 亚洲av日韩高清hd| 五十路在线观看完整版| av在线播放国产不卡| 亚洲日本一区二区三区 | 麻豆性色视频在线观看| 超鹏97历史在线观看| 狠狠鲁狠狠操天天晚上干干| ka0ri在线视频| 日日摸夜夜添夜夜添毛片性色av| 色综合天天综合网国产成人| 国产白袜脚足J棉袜在线观看| 国产精品自拍视频大全| 国产高清精品一区二区三区| 国产男女视频在线播放| 巨乳人妻日下部加奈被邻居中出 | 国产精品亚洲а∨天堂免| 在线免费观看日本片| 超碰97人人澡人人| 青青擦在线视频国产在线| 日韩熟女av天堂系列| 少妇人妻100系列| 日本又色又爽又黄又粗| 成年人黄色片免费网站| 东游记中文字幕版哪里可以看到| 天天干天天啪天天舔| 精品国产乱码一区二区三区乱| 国产午夜无码福利在线看| 亚洲精品国产综合久久久久久久久 | 亚洲av极品精品在线观看| 免费在线看的黄片视频| 91免费观看国产免费| 大屁股熟女一区二区三区| 亚洲精品亚洲人成在线导航| 一区二区久久成人网| 人妻爱爱 中文字幕| 激情人妻校园春色亚洲欧美 | 亚洲无线观看国产高清在线| 插小穴高清无码中文字幕| 精品成人啪啪18免费蜜臀| 成人伊人精品色xxxx视频| 日韩av有码一区二区三区4| 国产精品亚洲在线观看| 欧美精品久久久久久影院| 自拍偷拍亚洲另类色图| 男人的天堂av日韩亚洲| 欧美精品免费aaaaaa| 大香蕉伊人中文字幕| 大香蕉伊人国产在线| 91麻豆精品传媒国产黄色片| 色伦色伦777国产精品| 久久久久国产成人精品亚洲午夜| 老司机午夜精品视频资源| 精品黑人一区二区三区久久国产| 天天日天天干天天搡| 亚洲国产在线精品国偷产拍| 国产精品久久9999| 亚洲成人国产av在线| 国产剧情演绎系列丝袜高跟| 日韩熟女av天堂系列| 免费在线观看视频啪啪| 人妻久久久精品69系列| 一区二区麻豆传媒黄片| 国产自拍在线观看成人| 中文字幕+中文字幕| 天天干天天操天天玩天天射| 青青青青视频在线播放| 男大肉棒猛烈插女免费视频| 欧美亚洲一二三区蜜臀| 国产普通话插插视频| 国产1区,2区,3区| 日本黄色三级高清视频| 国产乱弄免费视频观看| 国产自拍黄片在线观看| 青青草视频手机免费在线观看| 日韩a级精品一区二区| 黑人乱偷人妻中文字幕| 亚洲精品一区二区三区老狼| 99热这里只有国产精品6| 97国产福利小视频合集| 欧美在线一二三视频| 大骚逼91抽插出水视频| 天天夜天天日天天日| 色在线观看视频免费的| 亚洲高清视频在线不卡| 密臀av一区在线观看| 精品一区二区亚洲欧美| 日本裸体熟妇区二区欧美| 成人在线欧美日韩国产| 大香蕉日本伊人中文在线| 男人的天堂在线黄色| 亚洲伊人av天堂有码在线| 521精品视频在线观看| 熟女人妻在线观看视频| mm131美女午夜爽爽爽| 92福利视频午夜1000看| 亚洲高清国产拍青青草原| av日韩在线观看大全| 国产使劲操在线播放| 亚洲欧美清纯唯美另类| 日韩精品中文字幕福利| 99热99re在线播放| 日本少妇人妻xxxxxhd| 亚洲最大黄 嗯色 操 啊| 蜜臀成人av在线播放| 97a片免费在线观看| 91精品免费久久久久久| brazzers欧熟精品系列| 92福利视频午夜1000看| 狠狠操操操操操操操操操| 乱亲女秽乱长久久久| 色婷婷六月亚洲综合香蕉| 中文字幕一区二区自拍| 97超碰国语国产97超碰| 亚洲免费av在线视频| 日本熟妇丰满厨房55| 国产精品三级三级三级| 少妇人妻真实精品视频| 天天干天天爱天天色| 又色又爽又黄的美女裸体| 午夜国产福利在线观看| 欧美另类z0z变态| 久久免费看少妇高潮完整版| 午夜久久香蕉电影网| 日韩二区视频一线天婷婷五| 黄色的网站在线免费看| 国产欧美精品不卡在线| 鸡巴操逼一级黄色气| 91亚洲国产成人精品性色| 青青青青青青青青青青草青青 | 国产一线二线三线的区别在哪| 成人乱码一区二区三区av| 国产亚洲欧美45p| 热思思国产99re| 中文字幕最新久久久| 岛国毛片视频免费在线观看| 91久久人澡人人添人人爽乱| 亚洲av日韩精品久久久| 日本少妇高清视频xxxxx| 少妇被强干到高潮视频在线观看| jiujiure精品视频在线| 人妻少妇性色欲欧美日韩| 2017亚洲男人天堂| 一区二区三区激情在线| 欧美亚洲免费视频观看| 久草视频在线免播放| 国产在线免费观看成人| 午夜青青草原网在线观看| 国产一区av澳门在线观看| 色秀欧美视频第一页| 日本午夜久久女同精女女| 福利视频网久久91| 2021天天色天天干| av手机在线免费观看日韩av| 99国产精品窥熟女精品| 欧美一级视频一区二区| 在线不卡成人黄色精品| 大肉大捧一进一出好爽在线视频 | 精品亚洲在线免费观看| 欧洲黄页网免费观看| 日韩av免费观看一区| 激情人妻校园春色亚洲欧美| 亚洲精品色在线观看视频| 黄色片年轻人在线观看| 中字幕人妻熟女人妻a62v网| 制服丝袜在线人妻中文字幕| 日日夜夜大香蕉伊人| 人人超碰国字幕观看97| 亚洲av日韩av第一区二区三区| 日本一区美女福利视频| av在线免费中文字幕| 久青青草视频手机在线免费观看 | 国产精品三级三级三级| 99人妻视频免费在线| 男人插女人视频网站| 欧美成人综合色在线噜噜| 国产又粗又猛又爽又黄的视频在线 | 亚洲无码一区在线影院| 51国产成人精品视频| 宅男噜噜噜666免费观看| 中文字幕 码 在线视频| 91www一区二区三区| 久久精品美女免费视频| 97小视频人妻一区二区| 日韩av大胆在线观看| 粉嫩欧美美人妻小视频| 欧美熟妇一区二区三区仙踪林| 日韩亚洲高清在线观看| 国产自拍在线观看成人| 伊人情人综合成人久久网小说| 91久久国产成人免费网站| 在线免费观看av日韩| 鸡巴操逼一级黄色气| 中文字幕成人日韩欧美| 硬鸡巴动态操女人逼视频| 91麻豆精品久久久久| 午夜毛片不卡在线看| 国产污污污污网站在线| aⅴ精产国品一二三产品| 黄页网视频在线免费观看| 亚洲男人在线天堂网| 一级黄片大鸡巴插入美女| 伊人综合免费在线视频| 久久久久久久精品成人热| 亚洲一级特黄特黄黄色录像片| 91大神福利视频网| 天天干天天操天天摸天天射|