国产无遮挡裸体免费直播视频,久久精品国产蜜臀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亚洲手机在线视频播放| 国产之丝袜脚在线一区二区三区 | 亚洲激情偷拍一区二区| 久久久久五月天丁香社区| 精品视频中文字幕在线播放| 早川濑里奈av黑人番号| 视频在线亚洲一区二区| 亚洲欧美一区二区三区爱爱动图 | 在线观看的黄色免费网站| 色吉吉影音天天干天天操| 国产又粗又猛又爽又黄的视频美国| 91福利视频免费在线观看| 欧美日韩亚洲国产无线码| 亚洲免费国产在线日韩| 超鹏97历史在线观看| 欧美日韩高清午夜蜜桃大香蕉| 做爰视频毛片下载蜜桃视频1| 丰满的子国产在线观看| 国产精品一区二区av国| 亚洲午夜福利中文乱码字幕| 精品av国产一区二区三区四区 | av在线播放国产不卡| 五色婷婷综合狠狠爱| 国产日韩一区二区在线看| 久久久久久久一区二区三| 天天干天天日天天谢综合156| 国产又粗又猛又爽又黄的视频美国| 亚洲一级特黄特黄黄色录像片| 中文字幕在线观看极品视频| 人妻熟女中文字幕aⅴ在线| 国产亚洲欧美45p| 老有所依在线观看完整版| 国产视频一区二区午夜| 久久精品国产23696| 亚洲高清国产拍青青草原| 不戴胸罩引我诱的隔壁的人妻| 超污视频在线观看污污污| 日日夜夜大香蕉伊人| 中文字幕人妻被公上司喝醉在线| 91大神福利视频网| 日韩三级电影华丽的外出 | 熟女91pooyn熟女| 激情五月婷婷免费视频| 亚洲av一妻不如妾| 久久久人妻一区二区| 91色秘乱一区二区三区| 美女 午夜 在线视频| 欧美色呦呦最新网址| 综合精品久久久久97| 老熟妇xxxhd老熟女| 青娱乐最新视频在线| 女同性ⅹxx女同h偷拍| 2020久久躁狠狠躁夜夜躁| 99国内精品永久免费视频| 久久久久91精品推荐99| 国产精品系列在线观看一区二区 | 换爱交换乱高清大片| 天天通天天透天天插| 久草极品美女视频在线观看| 精品日产卡一卡二卡国色天香 | 美女被肏内射视频网站| 老司机99精品视频在线观看 | 亚洲一级av大片免费观看| 三级等保密码要求条款| 色97视频在线播放| 夜夜嗨av蜜臀av| 人人妻人人爽人人澡人人精品| 日韩av有码中文字幕| 视频一区 视频二区 视频| 国产精品手机在线看片| 老司机99精品视频在线观看| 老师啊太大了啊啊啊尻视频| 欧美亚洲免费视频观看| 少妇ww搡性bbb91| 沙月文乃人妻侵犯中文字幕在线| 一区二区三区四区视频| 亚洲一区久久免费视频| 国产三级影院在线观看| 亚洲av黄色在线网站| 久久久久只精品国产三级| 91九色porny蝌蚪国产成人| 91在线视频在线精品3| 亚洲日产av一区二区在线| 亚洲天堂有码中文字幕视频| 特级欧美插插插插插bbbbb| 亚洲欧美日韩视频免费观看| 精品高跟鞋丝袜一区二区| 人妻久久久精品69系列| 日韩影片一区二区三区不卡免费| 人妻少妇亚洲精品中文字幕| 在线免费观看亚洲精品电影| 黄片大全在线观看观看| 午夜精品福利91av| 日本av熟女在线视频| 青青青青操在线观看免费| 色婷婷六月亚洲综合香蕉| 国产露脸对白在线观看| 国产女人叫床高潮大片视频| 国产精品黄片免费在线观看| 999九九久久久精品| 国产一区自拍黄视频免费观看| 欧美精产国品一二三产品价格| 黑人大几巴狂插日本少妇| 国产精选一区在线播放| 97小视频人妻一区二区| 亚洲蜜臀av一区二区三区九色 | av中文在线天堂精品| 99热久久这里只有精品8| 夜女神免费福利视频| 男人的天堂在线黄色| av老司机亚洲一区二区| 天天日天天爽天天爽| 东京热男人的av天堂| 91亚洲精品干熟女蜜桃频道| 亚洲欧美国产综合777| 2022精品久久久久久中文字幕| 新婚人妻聚会被中出| 亚洲av成人网在线观看| 欧美精品一区二区三区xxxx| 99国内精品永久免费视频| 视频一区二区在线免费播放| 午夜毛片不卡在线看| www日韩a级s片av| 国产成人综合一区2区| 日韩二区视频一线天婷婷五| 精品国产午夜视频一区二区| 天天插天天色天天日| 亚洲最大黄了色网站| 狍和女人的王色毛片| 午夜精品在线视频一区| 早川濑里奈av黑人番号| 国产黄网站在线观看播放| 人妻3p真实偷拍一二区| 晚上一个人看操B片| 激情国产小视频在线| 黄色中文字幕在线播放| 国产av一区2区3区| 亚洲av黄色在线网站| 中文字幕人妻熟女在线电影| 欧洲日韩亚洲一区二区三区| 国产精品久久久久久美女校花| 人人妻人人爱人人草| 亚洲精品乱码久久久久久密桃明| 大香蕉大香蕉大香蕉大香蕉大香蕉| 五十路熟女av天堂| 亚洲精品国产综合久久久久久久久 | 中文字幕无码日韩专区免费| 女人精品内射国产99| 99热碰碰热精品a中文| 日本18禁久久久久久| 在线免费观看黄页视频| 日韩人妻在线视频免费| 2021久久免费视频| 激情伦理欧美日韩中文字幕| 揄拍成人国产精品免费看视频| yellow在线播放av啊啊啊| 色婷婷精品大在线观看| 国产露脸对白在线观看| 深田咏美亚洲一区二区| 99精品国产aⅴ在线观看| 成年人啪啪视频在线观看| 在线观看免费视频网| 国产白袜脚足J棉袜在线观看| 久久久久久97三级| av在线免费中文字幕| 亚洲一区二区三区五区| 真实国模和老外性视频| 日韩午夜福利精品试看| 丝袜亚洲另类欧美变态| 白嫩白嫩美女极品国产在线观看| 中文字幕 人妻精品| 岛国青草视频在线观看| 无套猛戳丰满少妇人妻| 夜夜操,天天操,狠狠操| 国产chinesehd精品麻豆| 大陆av手机在线观看| 亚洲人一区二区中文字幕| 国产成人综合一区2区| av天堂中文字幕最新| 欧美精品久久久久久影院| av一区二区三区人妻| av久久精品北条麻妃av观看| 国产亚洲欧美45p| 啪啪啪18禁一区二区三区| 国产自拍黄片在线观看| 91免费观看国产免费| 欧美男人大鸡吧插女人视频| 中文字幕第一页国产在线| 好吊操视频这里只有精品| 91国产在线视频免费观看| 中文字幕在线第一页成人| 精品区一区二区三区四区人妻| 欧美日韩在线精品一区二区三| 国产亚洲精品品视频在线| 欧美成人小视频在线免费看| 亚洲欧美精品综合图片小说| 亚洲欧美综合另类13p| 2018在线福利视频| 国产又粗又猛又爽又黄的视频在线| 丝袜肉丝一区二区三区四区在线| 最新国产精品网址在线观看| 最新激情中文字幕视频| 国产露脸对白在线观看| 男人的天堂在线黄色| 人人爽亚洲av人人爽av| 又粗又长 明星操逼小视频| 色婷婷综合激情五月免费观看| 欧美一区二区三区高清不卡tv| 天天躁日日躁狠狠躁躁欧美av| japanese五十路熟女熟妇| 婷婷久久一区二区字幕网址你懂得| 日本a级视频老女人| 伊拉克及约旦宣布关闭领空| 少妇人妻久久久久视频黄片| jiujiure精品视频在线| 午夜久久香蕉电影网| 久久麻豆亚洲精品av| 国产精品久久久久久久女人18| 亚洲欧美一区二区三区爱爱动图| 欧美在线精品一区二区三区视频 | 中文字幕日韩无敌亚洲精品| av在线免费观看亚洲天堂| 动漫黑丝美女的鸡巴| av线天堂在线观看| 日本成人不卡一区二区| 欧美视频中文一区二区三区| 久久免费看少妇高潮完整版| 精品欧美一区二区vr在线观看| 午夜在线观看一区视频| 亚洲欧美日韩视频免费观看| 亚洲推理片免费看网站| 国产伊人免费在线播放| 中文字幕在线观看国产片| 国产亚洲欧美另类在线观看| 秋霞午夜av福利经典影视| 十八禁在线观看地址免费| 人妻av无码专区久久绿巨人| 国产成人自拍视频播放 | www,久久久,com| 青青热久免费精品视频在线观看| 自拍偷区二区三区麻豆| 偷拍自拍福利视频在线观看| 无码日韩人妻精品久久| 午夜美女福利小视频| 在线不卡日韩视频播放| 岳太深了紧紧的中文字幕| 久久精品亚洲国产av香蕉| 久久久精品精品视频视频| 成人av天堂丝袜在线观看| 适合午夜一个人看的视频| 97色视频在线观看| 精品久久久久久久久久久a√国产| 丰满少妇人妻xxxxx| 最新91精品视频在线| 初美沙希中文字幕在线 | 亚洲午夜精品小视频| 视频一区 二区 三区 综合| 久草福利电影在线观看| 国产综合高清在线观看| 3344免费偷拍视频| 免费观看成年人视频在线观看| 极品性荡少妇一区二区色欲| 午夜精品九一唐人麻豆嫩草成人| 91精品免费久久久久久| 日本熟妇色熟妇在线观看| 在线可以看的视频你懂的| 色伦色伦777国产精品| 新婚人妻聚会被中出| 丝袜美腿欧美另类 中文字幕| 2022中文字幕在线| 日韩二区视频一线天婷婷五| 国产乱子伦精品视频潮优女| 中文字幕日韩精品就在这里| 一区二区三区综合视频| 在线观看欧美黄片一区二区三区| 色花堂在线av中文字幕九九| 青青伊人一精品视频| av中文在线天堂精品| 2021最新热播中文字幕| 插逼视频双插洞国产操逼插洞| 欧美色婷婷综合在线| 中文字幕一区二区三区人妻大片 | 老鸭窝在线观看一区| 亚洲激情唯美亚洲激情图片| 国产精品视频一区在线播放| av欧美网站在线观看| 日本脱亚入欧是指什么| 亚洲最大黄了色网站| japanese日本熟妇另类| 亚洲伊人久久精品影院一美女洗澡 | av视屏免费在线播放| 欧美va亚洲va天堂va| 亚洲成人免费看电影| 亚洲国产精品久久久久蜜桃| jiujiure精品视频在线| 成人高潮aa毛片免费| 亚洲国产成人在线一区| 黄色片年轻人在线观看| 在线国产中文字幕视频| 色婷婷久久久久swag精品| 1区2区3区4区视频在线观看| 久久精品视频一区二区三区四区| 日本av高清免费网站| 中文字幕最新久久久| 国产精品入口麻豆啊啊啊| 18禁美女黄网站色大片下载| 福利片区一区二体验区| 欧美视频综合第一页| 99热国产精品666| 婷婷五月亚洲综合在线| 2o22av在线视频| 专门看国产熟妇的网站| 久久热这里这里只有精品| 人妻熟女在线一区二区| 午夜精品福利一区二区三区p| 4个黑人操素人视频网站精品91| 天天射夜夜操狠狠干| 国产美女午夜福利久久| 伊人情人综合成人久久网小说| av乱码一区二区三区| 国产亚洲欧美视频网站| 国产亚洲国产av网站在线| 五色婷婷综合狠狠爱| nagger可以指黑人吗| 国产一区二区欧美三区| 动漫精品视频在线观看| 色婷婷精品大在线观看| 久久久久久性虐视频| 在线观看成人国产电影| 视频一区二区三区高清在线| 人妻熟女中文字幕aⅴ在线| 久久永久免费精品人妻专区| av在线免费资源站| 亚洲欧美国产麻豆综合| 自拍偷拍一区二区三区图片| 日韩北条麻妃一区在线| 天天干狠狠干天天操| 欧美一区二区三区在线资源| 日韩国产乱码中文字幕| 狠狠躁夜夜躁人人爽天天久天啪| 中文字幕日韩无敌亚洲精品| 国产精品三级三级三级| 91超碰青青中文字幕| 同居了嫂子在线播高清中文| 一区二区三区另类在线| 国产第一美女一区二区三区四区 | 一区二区麻豆传媒黄片| 人妻3p真实偷拍一二区| 国产免费高清视频视频| 欧美成人综合视频一区二区 | 欧美亚洲一二三区蜜臀| 日本熟妇丰满厨房55| 天天色天天操天天透| 偷青青国产精品青青在线观看| 大香蕉伊人国产在线| 黄色片黄色片wyaa| 国产极品精品免费视频 | 天天干天天操天天爽天天摸| 亚洲中文字幕国产日韩| 亚洲一区二区激情在线| 亚洲在线观看中文字幕av| 亚洲黄色av网站免费播放| 亚洲伊人av天堂有码在线| 黑人借宿ntr人妻的沦陷2| 亚洲成人三级在线播放| 青青青青青免费视频| 亚洲欧美一卡二卡三卡| 精产国品久久一二三产区区别 | 天天操天天插天天色| av一本二本在线观看| 国产福利在线视频一区| 亚洲1卡2卡三卡4卡在线观看 | 亚洲国产第一页在线观看| 国产福利在线视频一区| 孕妇奶水仑乱A级毛片免费看| 精品国产乱码一区二区三区乱| 久久国产精品精品美女| 91试看福利一分钟| 国产乱子伦精品视频潮优女| 中国产一级黄片免费视频播放| 婷婷综合亚洲爱久久| 青青青艹视频在线观看| 日本www中文字幕| av手机在线免费观看日韩av| 最新国产亚洲精品中文在线| 中文字幕无码日韩专区免费| 国产精品成人xxxx| 快点插进来操我逼啊视频| 亚洲av色香蕉一区二区三区| 啪啪啪啪啪啪啪啪啪啪黄色| 成人av在线资源网站| 91麻豆精品91久久久久同性| 97精品成人一区二区三区| 日本女人一级免费片| 美女被肏内射视频网站| 亚洲精品午夜久久久久| 在线免费观看日本片| 在线观看欧美黄片一区二区三区 | 极品粉嫩小泬白浆20p主播| 91人妻精品一区二区在线看| 成人H精品动漫在线无码播放| 中文字幕成人日韩欧美| 国产一区二区久久久裸臀| 欧美精品一区二区三区xxxx| 美女日逼视频免费观看| 亚洲精品国产综合久久久久久久久 | 免费无码人妻日韩精品一区二区| 日韩美在线观看视频黄| 国产午夜福利av导航| 天天爽夜夜爽人人爽QC| 五十路在线观看完整版| 福利一二三在线视频观看| 97瑟瑟超碰在线香蕉| 欧美国品一二三产区区别 | 天天做天天干天天操天天射| 日本韩国在线观看一区二区| 日韩人妻xxxxx| 一二三中文乱码亚洲乱码one| 国产成人自拍视频播放| 欧美男人大鸡吧插女人视频| 亚洲精品精品国产综合| 中国黄片视频一区91| 国产不卡av在线免费| 欧美地区一二三专区| jiuse91九色视频| 不卡一区一区三区在线| 国产成人小视频在线观看无遮挡| 亚洲熟妇无码一区二区三区| av森泽佳奈在线观看| 88成人免费av网站| 日韩av熟妇在线观看| 2020久久躁狠狠躁夜夜躁| 日日日日日日日日夜夜夜夜夜夜| 大胸性感美女羞爽操逼毛片| 精品suv一区二区69| 80电影天堂网官网| 精品国产污污免费网站入口自 | 亚洲一级美女啪啪啪| 日本乱人一区二区三区| 91国产资源在线视频| 国产精品久久久久久久精品视频 | 一色桃子久久精品亚洲| 美女大bxxxx内射| 2021国产一区二区| 欧美中国日韩久久精品| 日本女人一级免费片| 国产变态另类在线观看| 日本午夜久久女同精女女| 大白屁股精品视频国产| 天天日夜夜操天天摸| 19一区二区三区在线播放| 瑟瑟视频在线观看免费视频| 欧美日韩高清午夜蜜桃大香蕉| 91超碰青青中文字幕| 日韩中文字幕精品淫| 亚洲伊人久久精品影院一美女洗澡| 中文字幕高清免费在线人妻| 欧美精品免费aaaaaa| 亚洲午夜精品小视频| 亚洲一区自拍高清免费视频| 97瑟瑟超碰在线香蕉| 天天干夜夜操啊啊啊| 人妻无码中文字幕专区| 少妇系列一区二区三区视频| 免费观看国产综合视频| 女人精品内射国产99| 九九视频在线精品播放| 国产真实灌醉下药美女av福利| 欧美一区二区三区四区性视频| 久久这里只有精品热视频| 2022中文字幕在线| 成人亚洲国产综合精品| 亚洲熟色妇av日韩熟色妇在线| 亚洲天堂精品福利成人av| 91国偷自产一区二区三区精品| 性欧美激情久久久久久久| 天天做天天爽夜夜做少妇| 亚洲欧美激情中文字幕| 日韩美在线观看视频黄| 国产又粗又硬又猛的毛片视频| 国产精品福利小视频a| 亚洲中文精品人人免费| 天天日天天做天天日天天做| 爱有来生高清在线中文字幕| 最新国产亚洲精品中文在线| 人人爽亚洲av人人爽av| 51国产偷自视频在线播放| 青青青青青青青青青青草青青| 国产女孩喷水在线观看| 国产精品女邻居小骚货| 四川五十路熟女av| 日韩精品啪啪视频一道免费| 久久久久久久久久性潮| 天天摸天天日天天操| 美日韩在线视频免费看| 中文字幕人妻三级在线观看| 亚洲 人妻 激情 中文| 黑人借宿ntr人妻的沦陷2| 女同性ⅹxx女同hd| 天天操天天爽天天干| 久久亚洲天堂中文对白| 熟女人妻三十路四十路人妻斩| 亚洲av在线观看尤物| 亚洲va国产va欧美va在线| 欧洲黄页网免费观看| 黄色大片免费观看网站| 夜夜嗨av蜜臀av| 亚洲人人妻一区二区三区 | 天天干夜夜操天天舔| 蜜臀成人av在线播放| 亚洲欧美激情中文字幕| 国产欧美精品免费观看视频| 天天操天天干天天插| 中国熟女@视频91| 中文字幕一区二 区二三区四区| 久久精品36亚洲精品束缚| 啊啊啊视频试看人妻| 国产老熟女伦老熟妇ⅹ| 欧美视频不卡一区四区| 久草视频在线免播放| 亚洲成人av一区在线| 成人性黑人一级av| 欧美日韩中文字幕欧美| 久久人人做人人妻人人玩精品vr| 超碰在线观看免费在线观看| 国产实拍勾搭女技师av在线| 91精品国产麻豆国产| 国产精品国产三级麻豆| 欧美3p在线观看一区二区三区| 91天堂天天日天天操| gav成人免费播放| 午夜蜜桃一区二区三区| 国产高清精品极品美女| 人妻3p真实偷拍一二区| 人妻久久无码中文成人| 在线观看视频网站麻豆| 传媒在线播放国产精品一区| 久久免看30视频口爆视频| 国产+亚洲+欧美+另类| 天天夜天天日天天日| 天堂av中文在线最新版| 亚洲综合一区成人在线| 在线观看的黄色免费网站| 成年人啪啪视频在线观看| 日本女人一级免费片| 久久www免费人成一看片| 一区二区三区久久久91| 亚洲激情,偷拍视频| 久草视频福利在线首页| 日韩美av高清在线| 亚洲欧美福利在线观看| 98视频精品在线观看| 亚洲中文精品字幕在线观看| 天天操天天干天天艹| 男女之间激情网午夜在线| 传媒在线播放国产精品一区| 色花堂在线av中文字幕九九| 久久久久久久精品成人热| 中文字幕—97超碰网| 欧美老鸡巴日小嫩逼| 国产揄拍高清国内精品对白| 丝袜长腿第一页在线| 国产精品视频资源在线播放| 日韩人妻xxxxx| 天天操天天爽天天干| 日韩人妻在线视频免费| 午夜久久香蕉电影网| 女人精品内射国产99| 国产精品人妻66p| 亚洲欧美在线视频第一页| 国产成人无码精品久久久电影| 一区二区在线视频中文字幕| 男生用鸡操女生视频动漫| 在线观看av亚洲情色| 欧美黑人与人妻精品| 制服丝袜在线人妻中文字幕| 岳太深了紧紧的中文字幕| 免费观看污视频网站| 内射久久久久综合网| 天天操,天天干,天天射| 日韩成人免费电影二区| lutube在线成人免费看| 自拍偷区二区三区麻豆| 宅男噜噜噜666国产| 超碰在线中文字幕一区二区| 999久久久久999| 在线可以看的视频你懂的| 夜鲁夜鲁狠鲁天天在线| 亚洲中文精品字幕在线观看| 97国产在线av精品| 日韩a级黄色小视频| 亚洲欧美日韩视频免费观看| 免费无毒热热热热热热久| av手机免费在线观看高潮| 99国内小视频在现欢看| 视频久久久久久久人妻| 福利国产视频在线观看| 亚洲一区二区三区久久受 | 亚洲老熟妇日本老妇| 97资源人妻免费在线视频| 狠狠操狠狠操免费视频| 日本少妇在线视频大香蕉在线观看| 国产揄拍高清国内精品对白| 久久机热/这里只有| 老有所依在线观看完整版| 免费无毒热热热热热热久| 岛国青草视频在线观看| 真实国产乱子伦一区二区| 狠狠地躁夜夜躁日日躁| 亚洲综合另类精品小说| 日日爽天天干夜夜操| 偷拍自拍亚洲美腿丝袜| 偷青青国产精品青青在线观看| 国产在线拍揄自揄视频网站| 不卡日韩av在线观看| 亚洲 图片 欧美 图片| 姐姐的朋友2在线观看中文字幕| 在线不卡成人黄色精品| 精品视频一区二区三区四区五区| 在线观看免费av网址大全| 91国偷自产一区二区三区精品| 日本性感美女三级视频| caoporm超碰国产| 亚洲天堂有码中文字幕视频| 天天日夜夜干天天操| 人妻另类专区欧美制服| 污污小视频91在线观看| 亚洲1区2区3区精华液| 天码人妻一区二区三区在线看| 天天日天天鲁天天操| 欧美日韩熟女一区二区三区| 视频一区二区在线免费播放| 成人综合亚洲欧美一区| 国产 在线 免费 精品| 伊人情人综合成人久久网小说| 久草极品美女视频在线观看| 成人av中文字幕一区| 日日日日日日日日夜夜夜夜夜夜| 中文字幕人妻一区二区视频| 日韩欧美国产一区不卡| 在线免费观看国产精品黄色| 日韩激情文学在线视频| 97超碰国语国产97超碰| av网站色偷偷婷婷网男人的天堂| 亚洲综合一区二区精品久久| 中国熟女一区二区性xx| 成人福利视频免费在线| 国产一线二线三线的区别在哪| 天天夜天天日天天日| 91在线免费观看成人| 亚洲成av人无码不卡影片一| 亚洲 国产 成人 在线| 成人国产影院在线观看| 夜夜骑夜夜操夜夜奸| 亚洲伊人久久精品影院一美女洗澡| 最近的中文字幕在线mv视频| 色哟哟国产精品入口| 亚洲av成人网在线观看| 日本免费视频午夜福利视频| 黄色无码鸡吧操逼视频| 在线观看免费视频网| 色秀欧美视频第一页| 天天操天天弄天天射| 开心 色 六月 婷婷| 成人亚洲精品国产精品| 国产中文字幕四区在线观看| 日比视频老公慢点好舒服啊| 婷婷综合亚洲爱久久| 97瑟瑟超碰在线香蕉| 天天做天天干天天操天天射| 成人性黑人一级av| 999热精品视频在线| 人妻少妇亚洲一区二区| 好太好爽好想要免费| 久久综合老鸭窝色综合久久| 日韩北条麻妃一区在线| 蜜桃臀av蜜桃臀av| 青青擦在线视频国产在线| 狠狠的往里顶撞h百合| 色狠狠av线不卡香蕉一区二区| 天天操,天天干,天天射| 日本真人性生活视频免费看| 一级黄色片夫妻性生活| 农村胖女人操逼视频| 在线国产日韩欧美视频| 经典av尤物一区二区| 日韩美女综合中文字幕pp| 亚洲综合一区二区精品久久| 国产一级麻豆精品免费| 日韩av熟妇在线观看| 曰本无码人妻丰满熟妇啪啪| 亚洲自拍偷拍精品网| 在线免费观看国产精品黄色| 老熟妇xxxhd老熟女| 欧美日韩v中文在线| 免费十精品十国产网站| 欧美偷拍亚洲一区二区| 亚洲成人国产综合一区| 91精品激情五月婷婷在线| 懂色av之国产精品| 欧美3p在线观看一区二区三区| 久久久超爽一二三av| 鸡巴操逼一级黄色气| 91中文字幕免费在线观看| 大鸡巴插入美女黑黑的阴毛| 色噜噜噜噜18禁止观看| 精品区一区二区三区四区人妻| 青青青爽视频在线播放| 免费福利av在线一区二区三区| 免费看高清av的网站| 亚洲欧美清纯唯美另类| 午夜婷婷在线观看视频| 亚洲欧洲av天堂综合| 不卡精品视频在线观看| 国产一级麻豆精品免费| 亚洲欧美激情中文字幕| 91天堂精品一区二区| 国产使劲操在线播放| 中文字幕一区的人妻欧美日韩| 国产成人一区二区三区电影网站| 自拍偷拍亚洲另类色图| av视网站在线观看| 91中文字幕免费在线观看| okirakuhuhu在线观看| 最新91精品视频在线| 日本黄在免费看视频| 亚国产成人精品久久久| 色伦色伦777国产精品| 亚洲黄色av网站免费播放| 伊人开心婷婷国产av| 久久一区二区三区人妻欧美| 欧美一区二区三区四区性视频| 一区二区视频视频视频| 日本在线不卡免费视频| 免费在线黄色观看网站| 后入美女人妻高清在线| 亚洲激情偷拍一区二区| nagger可以指黑人吗| 精品黑人一区二区三区久久国产| 亚洲高清自偷揄拍自拍| 亚洲高清国产拍青青草原| 丝袜亚洲另类欧美变态| 欧美精产国品一二三区| v888av在线观看视频| 精品黑人巨大在线一区| 国产高清在线在线视频| 天天日天天操天天摸天天舔| 青青青视频自偷自拍38碰| 国产高清在线观看1区2区| 国产使劲操在线播放| 不卡日韩av在线观看| 一个色综合男人天堂| 国产乱子伦精品视频潮优女| 在线免费观看靠比视频的网站 | brazzers欧熟精品系列| 91色老99久久九九爱精品| 国产chinesehd精品麻豆| 好了av中文字幕在线| 欧美 亚洲 另类综合| 蜜桃视频在线欧美一区| 国产亚洲四十路五十路| 久久免看30视频口爆视频| 国产又粗又黄又硬又爽| 好吊视频—区二区三区| 75国产综合在线视频| 成人在线欧美日韩国产| 2021最新热播中文字幕| 一区二区三区麻豆福利视频| 大香蕉伊人中文字幕| 91精品免费久久久久久| 偷拍3456eee| 熟女在线视频一区二区三区| 亚洲av午夜免费观看| 大鸡巴操b视频在线| 成人H精品动漫在线无码播放| 人妻少妇性色欲欧美日韩| 中文字幕高清资源站| 亚洲 色图 偷拍 欧美| 91www一区二区三区| 阿v天堂2014 一区亚洲| 精品国产亚洲av一淫| 大香蕉大香蕉大香蕉大香蕉大香蕉 | 久久香蕉国产免费天天| 亚洲熟女久久久36d| 亚洲在线一区二区欧美| 日本少妇人妻xxxxxhd| 首之国产AV医生和护士小芳| 抽查舔水白紧大视频| 午夜精品九一唐人麻豆嫩草成人 | 最近中文字幕国产在线| 国产亚洲精品欧洲在线观看| 少妇人妻二三区视频| 国产又色又刺激在线视频 | 女警官打开双腿沦为性奴| 97超碰免费在线视频| 97a片免费在线观看| 伊拉克及约旦宣布关闭领空| 亚洲综合乱码一区二区| 亚洲最大黄 嗯色 操 啊| 国产美女精品福利在线| 亚洲欧美久久久久久久久| 日本av在线一区二区三区| 久久久极品久久蜜桃| 国产精品福利小视频a| 3344免费偷拍视频| 精品视频国产在线观看| h国产小视频福利在线观看| 男人插女人视频网站| 亚洲欧美人精品高清| 亚洲一级特黄特黄黄色录像片| 把腿张开让我插进去视频| 青青草在观免费国产精品| 日韩美av高清在线| 97青青青手机在线视频 | 国产真实灌醉下药美女av福利| 亚洲少妇高潮免费观看| 在线观看的黄色免费网站| 黄页网视频在线免费观看| 欧美男同性恋69视频| 天天日天天透天天操| 国产精品人妻66p| caoporm超碰国产| 国产精品熟女久久久久浪潮| 丁香花免费在线观看中文字幕| 精品高潮呻吟久久av| 日本黄色特一级视频| 中文字幕在线第一页成人 | 好男人视频在线免费观看网站| 日曰摸日日碰夜夜爽歪歪| 3337p日本欧洲大胆色噜噜| 亚洲 人妻 激情 中文| 六月婷婷激情一区二区三区| 亚洲一级美女啪啪啪| 青青社区2国产视频| 国产av国片精品一区二区| 美女av色播在线播放| 18禁污污污app下载| 天天干天天操天天扣| 久久尻中国美女视频| 极品丝袜一区二区三区| 99精品国产aⅴ在线观看| 都市家庭人妻激情自拍视频| 欧美色呦呦最新网址| 天天日天天干天天舔天天射| 中国黄色av一级片| 成人精品视频99第一页| 天天插天天狠天天操| 激情内射在线免费观看| 在线免费91激情四射| 91亚洲手机在线视频播放| 久草视频福利在线首页| 高潮喷水在线视频观看| 亚洲一区制服丝袜美腿| 扒开腿挺进肉嫩小18禁视频| 蜜桃视频入口久久久| 熟女俱乐部一二三区| 国产高清精品一区二区三区| 大鸡八强奸视频在线观看| 伊人成人在线综合网| 欧美乱妇无乱码一区二区| 特大黑人巨大xxxx| 99re6热在线精品| av天堂中文字幕最新| 大尺度激情四射网站| 免费观看国产综合视频| 中文字幕人妻av在线观看| 久久精品国产23696| 在线观看黄色成年人网站| 亚洲成人av一区久久| 日本www中文字幕| 成人国产激情自拍三区| 狠狠躁夜夜躁人人爽天天天天97| 日韩精品啪啪视频一道免费| av老司机亚洲一区二区| 中国无遮挡白丝袜二区精品| 摧残蹂躏av一二三区| 都市激情校园春色狠狠| 色呦呦视频在线观看视频| 韩国男女黄色在线观看| 青娱乐蜜桃臀av色| 国产精品一区二区av国| 国产精品久久久久久久女人18| 一区二区三区四区中文| 午夜激情精品福利视频| 2025年人妻中文字幕乱码在线| 亚洲成人熟妇一区二区三区| 青青青青操在线观看免费| 欧美成人小视频在线免费看| 亚洲中文字字幕乱码| 成人高潮aa毛片免费| 少妇ww搡性bbb91| 爱有来生高清在线中文字幕| jiujiure精品视频在线| 亚洲女人的天堂av| 免费观看成年人视频在线观看| 午夜免费观看精品视频| 91久久精品色伊人6882| 国产精品国产三级国产午| 国产欧美精品一区二区高清| 免费岛国喷水视频在线观看| 97精品综合久久在线| 亚洲乱码中文字幕在线| 亚洲的电影一区二区三区| 农村胖女人操逼视频| 欧美亚洲国产成人免费在线| 99热国产精品666| 成熟丰满熟妇高潮xx×xx| 国产品国产三级国产普通话三级| 欧美日本国产自视大全| 国产精品久久久久国产三级试频| 蜜臀av久久久久蜜臀av麻豆| 水蜜桃国产一区二区三区| 直接观看免费黄网站| 黑人解禁人妻叶爱071| 黑人性生活视频免费看| 欧美熟妇一区二区三区仙踪林| 成年人黄视频在线观看| 91成人精品亚洲国产| 亚洲美女自偷自拍11页| 久久久久久久精品老熟妇| 91国内精品久久久久精品一| 制丝袜业一区二区三区| 日本阿v视频在线免费观看| 粉嫩欧美美人妻小视频| 国产熟妇一区二区三区av| 区一区二区三国产中文字幕| 亚洲欧美激情中文字幕| 天天通天天透天天插| 久久永久免费精品人妻专区| 亚洲欧美色一区二区| 欧美天堂av无线av欧美| 国产女人露脸高潮对白视频| av高潮迭起在线观看| 国产亚洲成人免费在线观看| 大鸡吧插逼逼视频免费看 | 精品一区二区三区欧美| 男人和女人激情视频| 亚洲自拍偷拍综合色| 蜜桃视频17c在线一区二区| av中文字幕电影在线看| 色婷婷综合激情五月免费观看| 亚洲国产在线精品国偷产拍| 福利视频网久久91| 粗大的内捧猛烈进出爽大牛汉子| 国产精品污污污久久| 又大又湿又爽又紧A视频| 扒开腿挺进肉嫩小18禁视频| 亚洲av成人免费网站| 大香蕉大香蕉大香蕉大香蕉大香蕉| 午夜激情高清在线观看| 在线视频这里只有精品自拍| 99一区二区在线观看| 美味人妻2在线播放| 人妻无码中文字幕专区| 精品人妻伦一二三区久| 青青青视频手机在线观看| 91精品一区二区三区站长推荐| 亚洲在线免费h观看网站| 日韩美女搞黄视频免费| 青青草人人妻人人妻| 成人网18免费视频版国产| 宅男噜噜噜666免费观看| 91一区精品在线观看| 只有精品亚洲视频在线观看| 日韩精品电影亚洲一区| 国产三级片久久久久久久| 人妻爱爱 中文字幕| 欧美日韩精品永久免费网址| 18禁美女黄网站色大片下载| 日韩亚洲高清在线观看| 超碰97人人澡人人| 大香蕉大香蕉大香蕉大香蕉大香蕉| 色综合久久久久久久久中文| 精品美女福利在线观看| 19一区二区三区在线播放| 精品人人人妻人人玩日产欧| 三级等保密码要求条款| 一色桃子久久精品亚洲| 日曰摸日日碰夜夜爽歪歪| 偷拍美女一区二区三区| 亚洲综合色在线免费观看| 中英文字幕av一区| 亚洲日本一区二区久久久精品| 国产精彩对白一区二区三区| 免费国产性生活视频| 自拍偷区二区三区麻豆| 黄色片黄色片wyaa| 亚洲丝袜老师诱惑在线观看| 91超碰青青中文字幕| 极品性荡少妇一区二区色欲| 国产又粗又黄又硬又爽| 欧美精品 日韩国产| 国产精品污污污久久| 国产片免费观看在线观看| 大尺度激情四射网站| 亚洲美女美妇久久字幕组| 国产极品美女久久久久久| 都市家庭人妻激情自拍视频| 男人的网址你懂的亚洲欧洲av| 五十路老熟女码av| 亚洲精品 欧美日韩| 夫妻在线观看视频91| nagger可以指黑人吗| 2019av在线视频| 人人妻人人人操人人人爽| 亚洲国产欧美国产综合在线| 午夜精彩视频免费一区| 午夜蜜桃一区二区三区| 国产日韩精品电影7777| 美女av色播在线播放| 狠狠躁夜夜躁人人爽天天久天啪| 高潮视频在线快速观看国家快速| 小穴多水久久精品免费看| 国产成人精品av网站| av天堂中文免费在线| 国产又粗又猛又爽又黄的视频在线| 91精品国产91久久自产久强| 日本人妻欲求不满中文字幕| www久久久久久久久久久| av黄色成人在线观看| 亚洲 中文 自拍 另类 欧美 | 青青青青草手机在线视频免费看| 日本人妻欲求不满中文字幕| 午夜婷婷在线观看视频| 一区二区三区综合视频| 国产精品久久久久久久女人18| 亚洲成人精品女人久久久| 国产之丝袜脚在线一区二区三区| 亚洲午夜精品小视频| 色97视频在线播放| 久久99久久99精品影院| huangse网站在线观看| 美女吃鸡巴操逼高潮视频| 国产亚洲精品欧洲在线观看| 亚洲熟色妇av日韩熟色妇在线| 一本久久精品一区二区| 天堂av中文在线最新版| 天天日天天爽天天干| 色偷偷伊人大杳蕉综合网| 亚洲精品 日韩电影| 亚洲一区二区三区av网站| 精品suv一区二区69| 毛片av在线免费看| 中文字幕av第1页中文字幕| 青青青青青青青在线播放视频| 99热色原网这里只有精品| 欧美一区二区三区乱码在线播放| 高潮视频在线快速观看国家快速| 一区二区视频在线观看免费观看| 国产精品自拍在线视频| 亚洲在线观看中文字幕av| 97瑟瑟超碰在线香蕉| 免费无毒热热热热热热久| 亚洲推理片免费看网站| 日本黄在免费看视频| 欧美黄色录像免费看的| 国产黄色高清资源在线免费观看| 亚洲美女自偷自拍11页| 99精品国产aⅴ在线观看| 中文字幕人妻一区二区视频| 欧美女同性恋免费a| 中文字幕熟女人妻久久久| 国产精品久久综合久久| 综合精品久久久久97| 国产实拍勾搭女技师av在线| 青青青青青青草国产| 亚洲中文字幕国产日韩| 中文字幕+中文字幕| 精彩视频99免费在线| 天天日天天添天天爽| 日韩欧美中文国产在线| 大鸡吧插逼逼视频免费看 | 国产精品自拍偷拍a| 欧美成人综合色在线噜噜| 热思思国产99re| 一级A一级a爰片免费免会员| 日本性感美女三级视频| 亚洲伊人av天堂有码在线| 最新国产精品拍在线观看| 偷拍3456eee| 91色九色porny| 黄色片一级美女黄色片| 国产亚洲视频在线二区| 欧美一级色视频美日韩| chinese国产盗摄一区二区| 2020中文字幕在线播放| 丝袜美腿视频诱惑亚洲无| 扒开腿挺进肉嫩小18禁视频| 国产欧美精品免费观看视频| 国产在线91观看免费观看| av完全免费在线观看av| 丁香花免费在线观看中文字幕| 日韩人妻在线视频免费| av日韩在线观看大全| 精品一区二区三区午夜| 麻豆性色视频在线观看| 一区二区三区国产精选在线播放| 久久久久91精品推荐99| 国产三级片久久久久久久 | 综合激情网激情五月五月婷婷| 在线可以看的视频你懂的| 自拍偷拍亚洲欧美在线视频| 亚洲欧美精品综合图片小说| 美女av色播在线播放| 亚洲老熟妇日本老妇| av中文字幕在线导航| 欧美天堂av无线av欧美| 国产大学生援交正在播放| 激情伦理欧美日韩中文字幕| 久久精品国产999| 日韩影片一区二区三区不卡免费| 欧美久久一区二区伊人| 丝袜肉丝一区二区三区四区在线看| 久久久久久久久久久免费女人| 国产成人精品久久二区91| 一二三中文乱码亚洲乱码one| 91老熟女连续高潮对白| 2018在线福利视频| 视频一区二区综合精品| 国产97在线视频观看| 欧美一级色视频美日韩| 亚洲av天堂在线播放| 日本一道二三区视频久久| 人妻在线精品录音叫床| 亚洲天堂第一页中文字幕| 成人国产小视频在线观看| 超污视频在线观看污污污 | 久久精品美女免费视频| 伊拉克及约旦宣布关闭领空| 亚洲欧美精品综合图片小说| 亚洲区美熟妇久久久久| 日本精品视频不卡一二三| 啊啊啊视频试看人妻| 亚洲人妻国产精品综合| 一区二区三区四区中文| 五月天久久激情视频| 中英文字幕av一区| 超pen在线观看视频公开97| 欧洲精品第一页欧洲精品亚洲| 久久亚洲天堂中文对白| 人人妻人人爽人人添夜| 国产性色生活片毛片春晓精品| 青青青aaaa免费| 日韩欧美制服诱惑一区在线| 人妻丰满熟妇综合网| 最新国产精品拍在线观看| 天天日天天敢天天干| 福利视频网久久91| 97色视频在线观看| 中文字幕乱码人妻电影| 亚洲av黄色在线网站| 亚洲在线免费h观看网站| 1区2区3区不卡视频| 熟女视频一区,二区,三区| 午夜福利资源综合激情午夜福利资| 亚洲精品乱码久久久久久密桃明| 午夜dv内射一区区| 青青青青操在线观看免费| 日本又色又爽又黄又粗| 国产女孩喷水在线观看| 亚洲第一黄色在线观看| 国产精品亚洲а∨天堂免| 99久久激情婷婷综合五月天| 精品一区二区三区欧美| 国产清纯美女al在线| 夜色17s精品人妻熟女| 久久一区二区三区人妻欧美| 日本免费一级黄色录像| 天天摸天天日天天操| 亚洲 国产 成人 在线| 青青色国产视频在线| 在线可以看的视频你懂的| 精品亚洲国产中文自在线| 大陆av手机在线观看| 青青热久免费精品视频在线观看| 天天操天天干天天插| 美日韩在线视频免费看| 国产精品自拍视频大全| 成人av电影免费版| 国产女孩喷水在线观看| 日视频免费在线观看| 夜夜嗨av一区二区三区中文字幕| 日日操夜夜撸天天干| 精品欧美一区二区vr在线观看| 中英文字幕av一区| 大骚逼91抽插出水视频| 最新国产精品网址在线观看| 夫妻在线观看视频91| 黄网十四区丁香社区激情五月天| 日韩在线视频观看有码在线| 国产aⅴ一线在线观看| 视频一区 视频二区 视频| 日韩在线中文字幕色| av完全免费在线观看av| 国产又色又刺激在线视频| 少妇露脸深喉口爆吞精| 亚洲精品 欧美日韩| 日本特级片中文字幕| 播放日本一区二区三区电影| 黑人乱偷人妻中文字幕| 午夜国产福利在线观看| 国产美女一区在线观看| 成人激情文学网人妻| 黄色片年轻人在线观看| 精品一线二线三线日本| 国产一区二区久久久裸臀| 激情五月婷婷综合色啪| 男大肉棒猛烈插女免费视频| 护士特殊服务久久久久久久| 最近的中文字幕在线mv视频| 人人妻人人人操人人人爽| 青青青青草手机在线视频免费看| 传媒在线播放国产精品一区| 午夜国产福利在线观看| 噜噜色噜噜噜久色超碰| 亚洲一级av大片免费观看| xxx日本hd高清| 91精品国产观看免费| 成人在线欧美日韩国产| 亚洲免费在线视频网站| 国产综合视频在线看片| 中国黄片视频一区91| 亚洲激情偷拍一区二区| 日本在线一区二区不卡视频| 91综合久久亚洲综合| 免费av岛国天堂网站| 日本免费视频午夜福利视频| 中文字幕免费在线免费| 免费黄高清无码国产| 久久99久久99精品影院| 中文字幕日韩无敌亚洲精品| 无码精品一区二区三区人| 国产亚州色婷婷久久99精品| 岳太深了紧紧的中文字幕| 国产欧美精品一区二区高清| 人妻熟女中文字幕aⅴ在线| 麻豆精品成人免费视频| 色吉吉影音天天干天天操 | 亚洲男人的天堂a在线| 国产高清97在线观看视频| 亚洲欧美国产综合777| 最新国产精品网址在线观看| 国产美女一区在线观看| 狠狠躁狠狠爱网站视频| 国产性生活中老年人视频网站| 久草视频 久草视频2| 国产白袜脚足J棉袜在线观看| 国产一级精品综合av| 日韩欧美在线观看不卡一区二区 | 亚洲国产成人最新资源| 欧美日韩不卡一区不区二区| 一区二区三区日本伦理| 午夜精品久久久久久99热| av手机在线观播放网站| 日韩美女搞黄视频免费| 久久精品国产999| 九色视频在线观看免费| 精品黑人巨大在线一区| 日韩一个色综合导航| 日韩av有码中文字幕| 绝色少妇高潮3在线观看| 欧美精品国产综合久久| 国产精彩对白一区二区三区| 免费黄色成人午夜在线网站| 五十路人妻熟女av一区二区| 91一区精品在线观看| 无套猛戳丰满少妇人妻| 91精品国产黑色丝袜| 青青在线视频性感少妇和隔壁黑丝| 操的小逼流水的文章| av中文字幕在线观看第三页| 精品老妇女久久9g国产| 福利视频网久久91| 自拍偷拍亚洲精品第2页| 欧美精品 日韩国产| 欧洲精品第一页欧洲精品亚洲| 激情五月婷婷综合色啪| 亚洲高清视频在线不卡| 亚洲免费av在线视频| 亚洲在线免费h观看网站| 中文亚洲欧美日韩无线码| 亚洲男人在线天堂网| 91 亚洲视频在线观看| 男人天堂最新地址av| 日本少妇人妻xxxxxhd| 欧美一区二区三区久久久aaa| 99久久成人日韩欧美精品| 国内自拍第一页在线观看| 免费一级特黄特色大片在线观看| 加勒比视频在线免费观看| 欧美日韩情色在线观看| 欧亚乱色一区二区三区| 天堂av在线播放免费| 不戴胸罩引我诱的隔壁的人妻| 国产视频精品资源网站| 国产精品国产三级国产午| av天堂加勒比在线| 密臀av一区在线观看| 日韩一区二区三区三州| 91免费福利网91麻豆国产精品 | 日本一道二三区视频久久| 国产视频网站一区二区三区| 亚洲激情偷拍一区二区| 91国语爽死我了不卡| 99一区二区在线观看| 午夜精品一区二区三区福利视频| 三级av中文字幕在线观看| aⅴ五十路av熟女中出| 亚洲一区二区三区uij| 91精品国产黑色丝袜| 天天通天天透天天插| japanese日本熟妇另类| 特一级特级黄色网片| 国产内射中出在线观看| 欧洲亚洲欧美日韩综合| 51国产成人精品视频| 丝袜肉丝一区二区三区四区在线 | 日韩美在线观看视频黄| 搡老妇人老女人老熟女| 97精品人妻一区二区三区精品| 中文字幕 码 在线视频| 亚洲免费在线视频网站| 天天日天天透天天操| 中文字幕在线永久免费播放| 日本性感美女写真视频| 精品美女在线观看视频在线观看| 2020中文字幕在线播放| 骚货自慰被发现爆操| 欧美一区二区中文字幕电影| 亚洲免费成人a v| 国产内射中出在线观看| 亚洲一级美女啪啪啪| 啪啪啪操人视频在线播放| 日韩剧情片电影在线收看| 高清一区二区欧美系列| 国产成人午夜精品福利| www日韩a级s片av| 人人爽亚洲av人人爽av| 91九色porny国产蝌蚪视频| 亚洲精品高清自拍av| 可以免费看的www视频你懂的 | 欧美日本aⅴ免费视频| 久久精品在线观看一区二区| 2018最新中文字幕在线观看| 欧美视频中文一区二区三区| 日日爽天天干夜夜操| 亚洲特黄aaaa片| 精品久久久久久久久久久99| 性色av一区二区三区久久久| 一级黄片久久久久久久久| 孕妇奶水仑乱A级毛片免费看| 亚洲天堂第一页中文字幕| 偷拍自拍国产在线视频| 自拍偷拍,中文字幕| 老熟妇凹凸淫老妇女av在线观看| 男人的天堂在线黄色| 人妻丝袜榨强中文字幕| 日韩美在线观看视频黄| 免费一级特黄特色大片在线观看 | 男大肉棒猛烈插女免费视频| 97人妻无码AV碰碰视频| 亚洲欧美成人综合视频| 日韩精品电影亚洲一区| 97黄网站在线观看| 中文字幕一区二区三区蜜月| 欧美女同性恋免费a| 在线观看av观看av| 亚洲天堂成人在线观看视频网站| 大香蕉玖玖一区2区| 色噜噜噜噜18禁止观看| 亚洲中文精品人人免费| 11久久久久久久久久久| 端庄人妻堕落挣扎沉沦| 国产乱子伦一二三区| 好吊视频—区二区三区| 夏目彩春在线中文字幕| 蜜桃视频17c在线一区二区| 男人操女人的逼免费视频| 中文字幕人妻一区二区视频| 欧美亚洲国产成人免费在线| 亚洲成人情色电影在线观看| 亚洲精品午夜aaa久久| 中文字幕日韩91人妻在线| 亚洲成人av在线一区二区| 久久久极品久久蜜桃| 一区二区视频在线观看免费观看| 国产亚洲精品品视频在线| 国产无遮挡裸体免费直播视频| 特黄老太婆aa毛毛片| 日本一道二三区视频久久| 91国内精品自线在拍白富美| 日本丰满熟妇大屁股久久| 黑人变态深video特大巨大| 日本少妇人妻xxxxxhd| 少妇高潮无套内谢麻豆| 同居了嫂子在线播高清中文| 91社福利《在线观看| 国产欧美日韩在线观看不卡| 夜夜骑夜夜操夜夜奸| 国产内射中出在线观看| 青娱乐极品视频青青草| 2025年人妻中文字幕乱码在线| 男人插女人视频网站| 天天日夜夜操天天摸| 国产成人自拍视频播放 | av日韩在线观看大全| 不卡一区一区三区在线| 二区中出在线观看老师| 久久丁香花五月天色婷婷| 欧美亚洲中文字幕一区二区三区| 福利视频广场一区二区| 免费成人av中文字幕| aⅴ精产国品一二三产品| 5528327男人天堂| 18禁免费av网站| 精品日产卡一卡二卡国色天香| 久久久精品欧洲亚洲av| av在线观看网址av| 国产又色又刺激在线视频| 国产熟妇人妻ⅹxxxx麻豆| 精品久久久久久久久久久久人妻| 一级黄片久久久久久久久| 黄色av网站免费在线| 色哟哟国产精品入口| 成人综合亚洲欧美一区| av亚洲中文天堂字幕网| av在线免费资源站| 啪啪啪啪啪啪啪啪啪啪黄色| 久久久久只精品国产三级| 密臀av一区在线观看| 国产97在线视频观看| 欧美日韩不卡一区不区二区| 精品亚洲国产中文自在线| 美女福利视频网址导航| 国产1区,2区,3区| 大骚逼91抽插出水视频| 91精品国产观看免费| 啪啪啪啪啪啪啪免费视频| 中文字幕免费福利视频6| 天天干天天日天天谢综合156| 99国产精品窥熟女精品| 亚洲一级av大片免费观看| 一区二区三区蜜臀在线| 亚洲变态另类色图天堂网| 免费看高清av的网站| 欧美80老妇人性视频| 日本特级片中文字幕| 无码中文字幕波多野不卡| 女同久久精品秋霞网| 天天摸天天亲天天舔天天操天天爽| 国产亚州色婷婷久久99精品| 久久机热/这里只有| 首之国产AV医生和护士小芳| 在线观看av2025| 日韩伦理短片在线观看| 中文字幕高清免费在线人妻| 国产成人精品福利短视频| 中英文字幕av一区| 亚洲一区二区久久久人妻| 天天摸天天亲天天舔天天操天天爽| 日韩精品啪啪视频一道免费| japanese五十路熟女熟妇| 夜女神免费福利视频| 欧美精产国品一二三产品价格 | 国产视频一区二区午夜| 欧美成人黄片一区二区三区 | yellow在线播放av啊啊啊| 97黄网站在线观看| 天天日天天摸天天爱| 青青青aaaa免费| 青青青青青青青青青青草青青| 国产日韩精品电影7777| 综合精品久久久久97| av中文字幕在线观看第三页| 亚洲偷自拍高清视频| 黄片三级三级三级在线观看| 亚洲精品午夜aaa久久| 日本精品美女在线观看| jiuse91九色视频| 成人国产激情自拍三区| 国产丰满熟女成人视频| 国产av国片精品一区二区| 国产日韩欧美视频在线导航| 人妻少妇中文有码精品| 天天日天天添天天爽| 亚洲最大免费在线观看| 婷婷午夜国产精品久久久| 激情人妻校园春色亚洲欧美 | 啪啪啪啪啪啪啪啪啪啪黄色| 青青青艹视频在线观看| 午夜频道成人在线91| 沈阳熟妇28厘米大战黑人| 丝袜肉丝一区二区三区四区在线| 午夜婷婷在线观看视频| 国产精品国产三级麻豆| 欧洲精品第一页欧洲精品亚洲| 韩国爱爱视频中文字幕| 成人蜜桃美臀九一一区二区三区| 久久热久久视频在线观看| 偷拍自拍亚洲美腿丝袜| 亚洲成人国产av在线| 青青青青爽手机在线| 亚洲第一黄色在线观看| 亚洲精品国产久久久久久| 欧美日韩在线精品一区二区三| av一区二区三区人妻| 天天干天天操天天插天天日| 亚洲欧美日韩视频免费观看| 精品黑人一区二区三区久久国产| 福利午夜视频在线合集| 日韩美女综合中文字幕pp| 真实国模和老外性视频| 午夜大尺度无码福利视频| 久碰精品少妇中文字幕av| 亚洲变态另类色图天堂网| 亚洲av日韩av第一区二区三区| 97黄网站在线观看| 日美女屁股黄邑视频| 青青草国内在线视频精选| 66久久久久久久久久久| 黄色成年网站午夜在线观看 | 2012中文字幕在线高清| 97瑟瑟超碰在线香蕉| 亚洲伊人av天堂有码在线| 亚洲欧美综合在线探花| 中文字幕一区二区人妻电影冢本 | av天堂加勒比在线| 青青在线视频性感少妇和隔壁黑丝| 开心 色 六月 婷婷| 午夜毛片不卡在线看| 天天操天天污天天射| 日本裸体熟妇区二区欧美| 2022国产精品视频| 亚洲高清视频在线不卡| 不卡一区一区三区在线| 日韩欧美制服诱惑一区在线| 性欧美日本大妈母与子| 欧洲精品第一页欧洲精品亚洲| 欧美日韩精品永久免费网址| 天天干天天日天天谢综合156| 特黄老太婆aa毛毛片| 亚洲护士一区二区三区| 天天干夜夜操天天舔| 一区二区麻豆传媒黄片| 亚洲另类图片蜜臀av| 欧美黑人与人妻精品| 成人久久精品一区二区三区| 涩涩的视频在线观看视频| 综合精品久久久久97| 亚洲av第国产精品| 麻豆精品成人免费视频| 大鸡八强奸视频在线观看| 国产亚州色婷婷久久99精品| 亚洲乱码中文字幕在线| 在线观看911精品国产| 精品久久婷婷免费视频| 玖玖一区二区在线观看| 91老师蜜桃臀大屁股| 欧美久久久久久三级网| 亚洲欧美久久久久久久久| 偷青青国产精品青青在线观看| 日本欧美视频在线观看三区| 欧美交性又色又爽又黄麻豆| 国产麻豆国语对白露脸剧情| 久久精品亚洲国产av香蕉| 少妇一区二区三区久久久| 香蕉av影视在线观看| 国产精品视频欧美一区二区| 欧美亚洲少妇福利视频| 欲乱人妻少妇在线视频裸| 天天干夜夜操啊啊啊| 国产精品人妻66p| 经典国语激情内射视频| mm131美女午夜爽爽爽| 不卡一不卡二不卡三| 日美女屁股黄邑视频| 中文字母永久播放1区2区3区| 少妇高潮无套内谢麻豆| 福利片区一区二体验区| 久久精品36亚洲精品束缚| 偷拍自拍亚洲视频在线观看| 亚洲成人国产av在线| 日韩中文字幕在线播放第二页| 韩国AV无码不卡在线播放| 久久艹在线观看视频| 精品高潮呻吟久久av| 色伦色伦777国产精品| 国产真实乱子伦a视频| 在线免费观看欧美小视频| 岛国黄色大片在线观看| 亚洲 欧美 精品 激情 偷拍 | 国产日韩欧美美利坚蜜臀懂色| 成人24小时免费视频| 97精品视频在线观看| 欧美久久久久久三级网| 免费费一级特黄真人片 | 人妻熟女中文字幕aⅴ在线| 欧美精品欧美极品欧美视频 | 青青色国产视频在线| 97色视频在线观看| 日韩在线中文字幕色| 开心 色 六月 婷婷| 青青青青视频在线播放| 成人动漫大肉棒插进去视频| 涩爱综合久久五月蜜臀| 午夜极品美女福利视频| 成年人黄色片免费网站| 欧美老妇精品另类不卡片| 日本在线一区二区不卡视频| 久久机热/这里只有| 五月色婷婷综合开心网4438| 美女被肏内射视频网站| 99一区二区在线观看| 亚洲日产av一区二区在线 | ka0ri在线视频| 国产九色91在线视频| 国产日韩欧美视频在线导航 | 亚洲青青操骚货在线视频| 国产日韩精品一二三区久久久| 超碰97人人澡人人| 青青色国产视频在线| 无忧传媒在线观看视频| av欧美网站在线观看| 哥哥姐姐综合激情小说 | 男人的天堂一区二区在线观看| 男人天堂色男人av| 亚洲公开视频在线观看| 欧美伊人久久大香线蕉综合| 国产精品探花熟女在线观看 | 91香蕉成人app下载| 少妇人妻100系列| 社区自拍揄拍尻屁你懂的| 亚洲国产中文字幕啊啊啊不行了 | 精品人妻一二三区久久| 亚洲av色香蕉一区二区三区| 91精品啪在线免费| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 亚洲综合自拍视频一区| 大香蕉伊人国产在线| 38av一区二区三区| 亚洲熟女久久久36d| 日韩欧美一级aa大片| 成人av电影免费版| 熟女91pooyn熟女| 亚洲另类综合一区小说| 日本美女性生活一级片| 成人动漫大肉棒插进去视频| 亚洲一区二区三区uij| 小泽玛利亚视频在线观看| 国产视频网站一区二区三区| 日本三极片中文字幕| 欧美一区二区三区啪啪同性| 天天插天天狠天天操| 91国内精品自线在拍白富美| 亚洲免费视频欧洲免费视频| 黄色成年网站午夜在线观看| 午夜在线精品偷拍一区二| 亚洲综合图片20p| 在线视频国产欧美日韩| 黑人巨大精品欧美视频| 成人av电影免费版| 青青青激情在线观看视频| 在线免费观看欧美小视频| 99精品免费久久久久久久久a| 国产精品久久9999| 亚洲精品国产久久久久久| 天天操天天爽天天干| 亚洲一区二区三区精品视频在线| 日韩午夜福利精品试看| 亚洲欧美清纯唯美另类 | 很黄很污很色的午夜网站在线观看 | 在线新三级黄伊人网| 动漫精品视频在线观看| 国产黄色大片在线免费播放| 国产一区二区欧美三区| 中文字幕成人日韩欧美| 日本少妇人妻xxxxx18| 久久这里只有精彩视频免费| 亚洲精品高清自拍av| 福利视频网久久91| 97精品成人一区二区三区| 玖玖一区二区在线观看| 天堂资源网av中文字幕| 蜜桃臀av蜜桃臀av| 直接能看的国产av| 美味人妻2在线播放| 亚洲国产香蕉视频在线播放| 中文字幕,亚洲人妻| 99av国产精品欲麻豆| 精品久久久久久久久久久久人妻| 亚洲嫩模一区二区三区| 精彩视频99免费在线| av日韩在线观看大全| 亚洲精品三级av在线免费观看| 99精品视频之69精品视频| 亚洲av日韩精品久久久| av乱码一区二区三区| 天天干夜夜操啊啊啊| 在线观看黄色成年人网站| 国产真实灌醉下药美女av福利| 极品性荡少妇一区二区色欲| 久久美欧人妻少妇一区二区三区| 欧美亚洲国产成人免费在线 | 青青在线视频性感少妇和隔壁黑丝 | 一区二区三区四区视频| 免费在线观看污污视频网站| 999久久久久999| 午夜精品亚洲精品五月色| 好男人视频在线免费观看网站| 亚洲成人三级在线播放| 自拍偷拍亚洲精品第2页| 只有精品亚洲视频在线观看| 93精品视频在线观看| 久久久久久cao我的性感人妻 | 国产女孩喷水在线观看| 人人妻人人澡欧美91精品| 5528327男人天堂| 热思思国产99re| 国产麻豆剧传媒精品国产av蜜桃| 亚洲高清视频在线不卡| 自拍偷拍vs一区二区三区| 新婚人妻聚会被中出| 男人操女人逼逼视频网站| 99精品国产aⅴ在线观看| 男大肉棒猛烈插女免费视频| 操操网操操伊剧情片中文字幕网| 97人人模人人爽人人喊| 欧美视频不卡一区四区| huangse网站在线观看| 91精品国产观看免费| 狠狠躁夜夜躁人人爽天天久天啪| 亚洲中文精品人人免费| 九九视频在线精品播放| 大鸡吧插逼逼视频免费看| 日视频免费在线观看| 欧美一区二区三区在线资源| 日本熟妇丰满厨房55| 在线视频国产欧美日韩| 亚洲人人妻一区二区三区| 国产污污污污网站在线| 综合色区亚洲熟妇shxstz| 特级无码毛片免费视频播放| av成人在线观看一区| 国产男女视频在线播放| 在线观看免费av网址大全| 少妇人妻二三区视频| 美女张开两腿让男人桶av| 国产 在线 免费 精品| 精品一区二区三区欧美| 成人福利视频免费在线| 无码中文字幕波多野不卡| 成人乱码一区二区三区av| 沈阳熟妇28厘米大战黑人| 大鸡巴操娇小玲珑的女孩逼| 夜夜操,天天操,狠狠操| 一区二区三区蜜臀在线| 99人妻视频免费在线| 亚洲欧美一区二区三区电影| 人人妻人人爽人人澡人人精品| 天堂资源网av中文字幕| 中文字幕免费在线免费| 精品黑人一区二区三区久久国产 | 91啪国自产中文字幕在线| 久久久久五月天丁香社区| 久久久久久久99精品| 亚洲另类综合一区小说| 偷拍自拍亚洲视频在线观看| 国产日本精品久久久久久久| 淫秽激情视频免费观看| 青青操免费日综合视频观看| 日韩近亲视频在线观看| 中文字幕在线视频一区二区三区| 久久久久91精品推荐99| 久久久人妻一区二区| 中英文字幕av一区| 大陆胖女人与丈夫操b国语高清| 亚洲免费国产在线日韩| 中文字幕欧美日韩射射一| 天天操天天干天天日狠狠插| 538精品在线观看视频| 色哟哟在线网站入口| 特级无码毛片免费视频播放| 黑人3p华裔熟女普通话| 国产成人自拍视频播放| 久草视频在线一区二区三区资源站| av日韩在线观看大全| 欲满人妻中文字幕在线| 免费av岛国天堂网站| 91色秘乱一区二区三区| 丰满少妇人妻xxxxx| 亚洲国产精品中文字幕网站| 3344免费偷拍视频| 人人妻人人爱人人草| 亚洲综合一区二区精品久久| 成人影片高清在线观看| 午夜毛片不卡免费观看视频| 欧美色呦呦最新网址| 色偷偷伊人大杳蕉综合网| 亚洲国产精品中文字幕网站| av在线免费中文字幕| av破解版在线观看| 色呦呦视频在线观看视频| 女警官打开双腿沦为性奴| 天天干天天日天天干天天操| 国产成人一区二区三区电影网站| 亚洲公开视频在线观看| 亚洲图库另类图片区| 五十路人妻熟女av一区二区| av中文字幕在线导航| 亚洲中文字幕综合小综合| 又粗又长 明星操逼小视频| 视频 国产 精品 熟女 | 亚洲午夜电影之麻豆| 一区二区麻豆传媒黄片| 美女少妇亚洲精选av| 欧美日本aⅴ免费视频| 欧美色呦呦最新网址| 日韩欧美制服诱惑一区在线| 成人动漫大肉棒插进去视频| 人妻激情图片视频小说| 日韩美女福利视频网| nagger可以指黑人吗| 欧美国产亚洲中英文字幕| 国产高清女主播在线| 亚洲精品在线资源站| 欧美viboss性丰满| 黄色无码鸡吧操逼视频| 蜜桃臀av蜜桃臀av| 亚洲第一伊人天堂网| 日本又色又爽又黄又粗| 神马午夜在线观看视频| 中文字幕之无码色多多| 亚洲无码一区在线影院| 欧美精品免费aaaaaa| 亚洲av香蕉一区区二区三区犇| 午夜精品一区二区三区更新| 午夜激情高清在线观看| 亚洲精品麻豆免费在线观看 | 在线观看一区二区三级| 18禁美女无遮挡免费| 操操网操操伊剧情片中文字幕网| 久久久久久九九99精品| 国产片免费观看在线观看| 亚洲欧美综合在线探花| 亚洲伊人久久精品影院一美女洗澡 | av手机免费在线观看高潮| 青青在线视频性感少妇和隔壁黑丝| 做爰视频毛片下载蜜桃视频1| 中国老熟女偷拍第一页| 在线免费观看99视频| 在线观看视频污一区| 色婷婷久久久久swag精品| 91破解版永久免费| 精品久久久久久久久久久a√国产| 播放日本一区二区三区电影| 福利视频网久久91| 亚洲成人熟妇一区二区三区| 欧美熟妇一区二区三区仙踪林| 国产成人自拍视频在线免费观看| 班长撕开乳罩揉我胸好爽| 熟女少妇激情五十路| 国产免费av一区二区凹凸四季| 日本女人一级免费片| 青草青永久在线视频18| 少妇人妻100系列| 美女操逼免费短视频下载链接| 黄色成人在线中文字幕| 在线观看国产网站资源| 亚洲激情唯美亚洲激情图片| 国产福利小视频大全| 成人区人妻精品一区二视频| 精品一区二区三区三区色爱| 一区国内二区日韩三区欧美| 国产精品国产三级国产午| 日韩精品中文字幕福利| 东京热男人的av天堂| 一个人免费在线观看ww视频| 中文字幕之无码色多多| 蜜桃色婷婷久久久福利在线| 伊拉克及约旦宣布关闭领空| 精品美女在线观看视频在线观看| av手机在线观播放网站| 亚洲蜜臀av一区二区三区九色| 国内自拍第一页在线观看| 欧美男人大鸡吧插女人视频| 国产熟妇一区二区三区av | 888亚洲欧美国产va在线播放| 性欧美日本大妈母与子| 美女 午夜 在线视频| 国产欧美精品不卡在线| 日本性感美女三级视频| 日韩欧美国产一区不卡| av中文字幕电影在线看| 欧美一区二区三区乱码在线播放| 欧美另类一区二区视频| 中文字幕一区二区三区人妻大片| 国产性色生活片毛片春晓精品| av破解版在线观看| 青青在线视频性感少妇和隔壁黑丝| 日本啪啪啪啪啪啪啪| 2020久久躁狠狠躁夜夜躁| 欧美成人黄片一区二区三区 | 97国产精品97久久| 中文字幕+中文字幕| 亚洲国产免费av一区二区三区| 狠狠操狠狠操免费视频| 成年人免费看在线视频| 国产美女一区在线观看| 国产自拍在线观看成人| 午夜精品久久久久麻豆影视| 欧美激情精品在线观看| 亚洲精品 日韩电影| 搡老熟女一区二区在线观看| 天堂v男人视频在线观看| 亚洲国产精品美女在线观看| 中文字幕在线乱码一区二区| 国产精品视频资源在线播放| 亚洲熟色妇av日韩熟色妇在线 | 肏插流水妹子在线乐播下载| 午夜精品一区二区三区福利视频| 99热99re在线播放| 黑人巨大的吊bdsm| 97人人模人人爽人人喊 | 亚洲自拍偷拍综合色| 黄网十四区丁香社区激情五月天| 日韩欧美在线观看不卡一区二区| 国产成人精品一区在线观看 | 91亚洲国产成人精品性色| 国产刺激激情美女网站| 操人妻嗷嗷叫视频一区二区| av老司机精品在线观看| 在线国产精品一区二区三区| 风流唐伯虎电视剧在线观看| 日韩人妻丝袜中文字幕| 国产在线观看免费人成短视频| 五月天色婷婷在线观看视频免费| 538精品在线观看视频| 亚洲综合在线观看免费| 亚洲高清视频在线不卡| 久久这里只有精彩视频免费| 欧美3p在线观看一区二区三区| 少妇高潮无套内谢麻豆| 国产亚洲国产av网站在线| 青青草精品在线视频观看| 亚洲码av无色中文| 亚洲国产欧美一区二区三区…| av在线资源中文字幕| 3D动漫精品啪啪一区二区下载| 19一区二区三区在线播放| 欧美特色aaa大片| 97精品综合久久在线| 都市激情校园春色狠狠| 91传媒一区二区三区| 伊人开心婷婷国产av| 成人sm视频在线观看| 99人妻视频免费在线| h国产小视频福利在线观看| 色呦呦视频在线观看视频| 欧美日韩高清午夜蜜桃大香蕉| 国产精品国产三级麻豆| 午夜精品一区二区三区4| 香蕉片在线观看av| 中文字幕综合一区二区| 99的爱精品免费视频| 亚洲麻豆一区二区三区| 2021国产一区二区| 国产麻豆国语对白露脸剧情| 欧美日本aⅴ免费视频| 在线观看的a站 最新| 欧美一区二区三区激情啪啪啪| 99热99这里精品6国产| yy96视频在线观看| 国产污污污污网站在线| 亚洲一级特黄特黄黄色录像片| 黑人巨大精品欧美视频| 乱亲女秽乱长久久久| 国产精品女邻居小骚货| 蜜桃臀av蜜桃臀av| 精品一区二区亚洲欧美| 1区2区3区不卡视频| 青青青青爽手机在线| 亚洲国产在人线放午夜| 亚洲欧美精品综合图片小说| 天天躁日日躁狠狠躁躁欧美av| 男人的天堂av日韩亚洲| av在线资源中文字幕| 99热国产精品666| 欧美爆乳肉感大码在线观看 | 天天干天天日天天谢综合156| 国产午夜福利av导航| 久久三久久三久久三久久| 自拍偷拍日韩欧美亚洲| 直接观看免费黄网站| 漂亮 人妻被中出中文| 国产高清在线在线视频| 初美沙希中文字幕在线| 人妻丝袜精品中文字幕| 亚欧在线视频你懂的| 福利视频一区二区三区筱慧 | 亚洲专区激情在线观看视频| 一区二区三区 自拍偷拍| 在线观看视频网站麻豆| 中国把吊插入阴蒂的视频| 亚洲av自拍天堂网| 国产视频一区在线观看| 成人av免费不卡在线观看| 久精品人妻一区二区三区| 中文字幕在线第一页成人 | 亚洲免费成人a v| 青青青青青青草国产| 91国内精品自线在拍白富美| 日韩伦理短片在线观看| 精品久久久久久高潮| 东游记中文字幕版哪里可以看到| 亚洲特黄aaaa片| 九色视频在线观看免费| 国产亚洲四十路五十路| 亚洲 中文 自拍 另类 欧美 | 2o22av在线视频| 青娱乐极品视频青青草| 激情啪啪啪啪一区二区三区| 午夜成午夜成年片在线观看| xxx日本hd高清| 亚洲精品在线资源站| 中国把吊插入阴蒂的视频| 2021最新热播中文字幕| 亚洲第17页国产精品| 欧美第一页在线免费观看视频| 午夜激情久久不卡一区二区| 亚洲日本一区二区三区| 免费69视频在线看| 美女视频福利免费看| 伊人综合免费在线视频| 91一区精品在线观看| 亚欧在线视频你懂的| 日韩北条麻妃一区在线| 日韩av免费观看一区| 中文字幕视频一区二区在线观看| 国产黑丝高跟鞋视频在线播放| 岳太深了紧紧的中文字幕| 亚洲美女高潮喷浆视频| 2021最新热播中文字幕| 91试看福利一分钟| 午夜毛片不卡免费观看视频| 亚洲精品高清自拍av| 丝袜国产专区在线观看| 亚洲熟妇久久无码精品| 啪啪啪啪啪啪啪啪av| 天天日天天干天天爱| 国产精品成久久久久三级蜜臀av| 精品一线二线三线日本| 欧美视频中文一区二区三区| 中国把吊插入阴蒂的视频| av手机免费在线观看高潮| 欧洲日韩亚洲一区二区三区| 91麻豆精品传媒国产黄色片| 精品suv一区二区69| 97少妇精品在线观看| 老司机深夜免费福利视频在线观看| 亚洲中文精品字幕在线观看 | 久久一区二区三区人妻欧美| 成人sm视频在线观看| 亚洲欧美另类自拍偷拍色图| 午夜在线观看一区视频| 欧洲欧美日韩国产在线| 亚洲av日韩精品久久久久久hd| 插小穴高清无码中文字幕| 少妇露脸深喉口爆吞精| 57pao国产一区二区| 五十路av熟女松本翔子| 男人和女人激情视频| 2022国产综合在线干| 另类av十亚洲av| 人妻熟女中文字幕aⅴ在线| 粉嫩av蜜乳av蜜臀| 亚洲区美熟妇久久久久| 91精品啪在线免费| av天堂中文免费在线| 久久久久久久99精品| 国产精品手机在线看片| 在线观看911精品国产| 超黄超污网站在线观看| 久久机热/这里只有| 青青青视频手机在线观看| weyvv5国产成人精品的视频| 亚洲另类伦春色综合小| 中文 成人 在线 视频| 不卡一不卡二不卡三| 日韩成人性色生活片| 国产日韩精品一二三区久久久| 天天操天天干天天艹| 色哟哟在线网站入口| 欧美在线一二三视频| 欧美男人大鸡吧插女人视频| 亚洲av男人天堂久久| 亚洲欧美综合另类13p| www骚国产精品视频| 青青擦在线视频国产在线| 人妻素人精油按摩中出| 精品久久久久久久久久久a√国产| 婷婷久久久久深爱网| 亚洲色偷偷综合亚洲AV伊人| wwwxxx一级黄色片| 天天色天天操天天透| 黄色无码鸡吧操逼视频| 自拍偷拍亚洲欧美在线视频| 久久久久久久久久一区二区三区| 93精品视频在线观看| 99re国产在线精品| 中文字幕1卡1区2区3区| 视频一区二区在线免费播放| 伊人开心婷婷国产av| 天堂av在线最新版在线| 九色精品视频在线播放| 蜜臀av久久久久久久| 少妇一区二区三区久久久| 老司机在线精品福利视频| 黄色中文字幕在线播放| 综合精品久久久久97| 11久久久久久久久久久| 国产九色91在线视频| 亚洲av自拍偷拍综合| 欧美日韩精品永久免费网址| 99热这里只有国产精品6| 黄色三级网站免费下载| 懂色av之国产精品| 午夜精品一区二区三区4| 51国产成人精品视频| 亚洲欧美久久久久久久久| 在线视频自拍第三页| 日本xx片在线观看| 女同久久精品秋霞网| 97成人免费在线观看网站| 国产伦精品一区二区三区竹菊| 国产一区二区在线欧美| 福利一二三在线视频观看| 亚洲美女美妇久久字幕组| 都市家庭人妻激情自拍视频| 免费看高清av的网站| 最近的中文字幕在线mv视频| 青青青青视频在线播放| 国产精品自偷自拍啪啪啪| 日本男女操逼视频免费看| 亚洲成av人无码不卡影片一| 日本一区美女福利视频| 伊人成人在线综合网| 操人妻嗷嗷叫视频一区二区| 久久久久久97三级| 亚洲国产美女一区二区三区软件| 亚洲另类伦春色综合小| 天美传媒mv视频在线观看| 91人妻精品一区二区久久| 很黄很污很色的午夜网站在线观看| 亚洲图库另类图片区| 天天夜天天日天天日| 一区二区三区日韩久久| 天天夜天天日天天日| 在线不卡日韩视频播放| 熟女视频一区,二区,三区| 五十路熟女人妻一区二| 大鸡吧插逼逼视频免费看| 中文字幕一区二区三区人妻大片| 国产精品国产三级国产午| 国产成人精品av网站| 狠狠嗨日韩综合久久| 久久艹在线观看视频| 精品国产乱码一区二区三区乱| 国产成人无码精品久久久电影| 国产成人精品久久二区91| 天天操天天爽天天干| 国产片免费观看在线观看| 色偷偷伊人大杳蕉综合网| 天天日夜夜操天天摸| 中文字幕人妻熟女在线电影| 91chinese在线视频| 欧美va亚洲va天堂va| 成年人免费看在线视频| 99精品免费久久久久久久久a| 国产精品熟女久久久久浪潮| 热思思国产99re| 男人在床上插女人视频| 日本少妇人妻xxxxx18| 1000部国产精品成人观看视频| 精品黑人巨大在线一区| 91av精品视频在线| 午夜激情高清在线观看| 国产亚洲四十路五十路| 日本男女操逼视频免费看| 亚洲av无码成人精品区辽| 香蕉91一区二区三区| 91九色国产熟女一区二区| 99精品免费观看视频| 好男人视频在线免费观看网站| 91‖亚洲‖国产熟女| 国产精品成久久久久三级蜜臀av | 天天干天天爱天天色| 国产日韩av一区二区在线| 我想看操逼黄色大片| 欧美精品 日韩国产| 91大神福利视频网| 77久久久久国产精产品| 亚洲另类伦春色综合小| 黄色片黄色片wyaa| 中文字幕亚洲久久久| 天天日天天爽天天干| 岳太深了紧紧的中文字幕| 在线观看免费av网址大全| 亚洲福利午夜久久久精品电影网 | 亚洲精品 欧美日韩| 中文字幕高清在线免费播放| 午夜国产免费福利av| 无忧传媒在线观看视频| asmr福利视频在线观看| 国产视频在线视频播放| av网址在线播放大全| 亚洲免费va在线播放| 青春草视频在线免费播放| 在线免费观看欧美小视频| 日韩中文字幕福利av| 亚洲免费国产在线日韩| 国产精品熟女久久久久浪潮| 国产欧美精品免费观看视频| 大香蕉日本伊人中文在线| 日本在线一区二区不卡视频| 欧美男同性恋69视频| 97欧洲一区二区精品免费| 成熟熟女国产精品一区| 成人30分钟免费视频| 天天操天天干天天日狠狠插| 亚洲男人让女人爽的视频| 亚洲最大免费在线观看| 9l人妻人人爽人人爽| 亚洲成人av一区久久| 国产九色91在线视频| 亚洲欧洲一区二区在线观看| 99热色原网这里只有精品| 成人亚洲国产综合精品| 黄色大片免费观看网站| 100%美女蜜桃视频| 中文字幕人妻av在线观看| 老有所依在线观看完整版 | 成年人的在线免费视频| 五月天久久激情视频| 五月天中文字幕内射| 少妇高潮无套内谢麻豆| 久久三久久三久久三久久| 成人蜜臀午夜久久一区| 亚洲国产成人最新资源| 免费黄色成人午夜在线网站| 日本性感美女视频网站| 伊人情人综合成人久久网小说 | 男人天堂av天天操| 一区二区久久成人网| 超碰在线观看免费在线观看| 粉嫩小穴流水视频在线观看| 亚洲av色香蕉一区二区三区| 777奇米久久精品一区| 熟妇一区二区三区高清版| 人妻少妇中文有码精品| 天堂va蜜桃一区入口| 91一区精品在线观看| 精品av久久久久久久| 久久久久国产成人精品亚洲午夜| 国产精品亚洲а∨天堂免| 激情色图一区二区三区| 欧美成人猛片aaaaaaa| 亚洲精品ww久久久久久| 日日夜夜大香蕉伊人| 成人午夜电影在线观看 久久| 亚洲一区二区三区偷拍女厕91 | 国产一区二区欧美三区| 天天插天天色天天日| 欧美爆乳肉感大码在线观看| 国产卡一卡二卡三乱码手机| 欧美地区一二三专区| 精品国产乱码一区二区三区乱| 一区二区三区麻豆福利视频| 天天干天天啪天天舔| 岛国av高清在线成人在线| 狠狠操操操操操操操操操| 日韩欧美亚洲熟女人妻| 天天干天天日天天干天天操| 欧美 亚洲 另类综合| 国产极品美女久久久久久| 污污小视频91在线观看| 38av一区二区三区| 欧美视频综合第一页| 成人福利视频免费在线| 不卡一区一区三区在线| 中文字幕人妻av在线观看| 一区二区三区久久久91| 99国产精品窥熟女精品| 天天做天天干天天舔| 国产欧美精品免费观看视频| 欧美亚洲一二三区蜜臀| 免费观看丰满少妇做受| 日韩人妻xxxxx| 中文字幕奴隷色的舞台50| 中文人妻AV久久人妻水| av俺也去在线播放| 日日日日日日日日夜夜夜夜夜夜| 亚洲中文字字幕乱码 | 久久这里只有精彩视频免费| 日本黄在免费看视频| 国产在线观看黄色视频| 中英文字幕av一区| 日本少妇人妻xxxxx18| huangse网站在线观看| 特级无码毛片免费视频播放| 在线新三级黄伊人网| 北条麻妃高跟丝袜啪啪| 亚洲欧美一卡二卡三卡| 亚洲国产在人线放午夜| 日本熟妇丰满厨房55| 日本真人性生活视频免费看| 午夜av一区二区三区| 日韩av熟妇在线观看| 人妻素人精油按摩中出| 91九色porny国产在线| 国产成人一区二区三区电影网站| 精品91自产拍在线观看一区| 天堂av在线最新版在线| 1区2区3区4区视频在线观看| 国产精品日韩欧美一区二区| 大陆胖女人与丈夫操b国语高清| 欧美国品一二三产区区别| 黑人解禁人妻叶爱071| 色哟哟国产精品入口| 国产精品午夜国产小视频| 狠狠躁狠狠爱网站视频| 老司机免费视频网站在线看| japanese日本熟妇另类| 天天插天天狠天天操| 精品91高清在线观看| 欧美视频综合第一页| 91免费观看在线网站| 国产又粗又黄又硬又爽| 蜜桃臀av蜜桃臀av| 春色激情网欧美成人| 岛国av高清在线成人在线| free性日本少妇| 欧美视频不卡一区四区| 国产精品午夜国产小视频| 亚洲综合图片20p| 岛国一区二区三区视频在线| 天堂av狠狠操蜜桃| 天天操天天射天天操天天天| 午夜青青草原网在线观看| 天天日天天爽天天干| 亚洲av黄色在线网站| 久久尻中国美女视频| 国产男女视频在线播放| 国产精品人久久久久久| 91人妻精品一区二区在线看| 这里只有精品双飞在线播放| 一区二区三区蜜臀在线| 日本性感美女写真视频| 日本福利午夜电影在线观看| av在线shipin| www骚国产精品视频| 日本韩国免费一区二区三区视频| 人妻少妇亚洲一区二区| 亚洲一区二区久久久人妻| 99re6热在线精品| 国产精品人久久久久久| 五十路息与子猛烈交尾视频| 福利视频网久久91| 精品人妻每日一部精品| 熟女在线视频一区二区三区| 国产无遮挡裸体免费直播视频| 免费在线观看污污视频网站| 久青青草视频手机在线免费观看 | 75国产综合在线视频| 日韩美av高清在线| 91九色porny蝌蚪国产成人| 精品高潮呻吟久久av| 亚洲久久午夜av一区二区| 一区国内二区日韩三区欧美| 日本三极片视频网站观看| 在线国产日韩欧美视频| 色在线观看视频免费的| 午夜91一区二区三区| 国产亚洲精品欧洲在线观看| 偷拍美女一区二区三区| 岛国一区二区三区视频在线| 成年美女黄网站18禁久久| 亚洲国产精品美女在线观看| 偷拍3456eee| 美女 午夜 在线视频| av天堂加勒比在线| 91精品国产黑色丝袜| 2o22av在线视频| 又大又湿又爽又紧A视频| 天天日天天干天天爱| 日本午夜福利免费视频| 精品av国产一区二区三区四区| 欧美成人小视频在线免费看| 免费在线播放a级片| 999久久久久999| 亚洲高清视频在线不卡| 视频一区二区在线免费播放| 视频啪啪啪免费观看| 福利视频广场一区二区| 天天躁日日躁狠狠躁av麻豆| 97黄网站在线观看| 大鸡吧插入女阴道黄色片| 熟女少妇激情五十路| 55夜色66夜色国产精品站| 国产白袜脚足J棉袜在线观看| 天天干狠狠干天天操| 老司机福利精品视频在线| 91麻豆精品秘密入口在线观看| 日本韩国在线观看一区二区| 999九九久久久精品| 天天操天天污天天射| sw137 中文字幕 在线| 欧美日韩激情啪啪啪| 97香蕉碰碰人妻国产樱花| 国产精品亚洲在线观看| 亚洲国产免费av一区二区三区| 韩国三级aaaaa高清视频| 亚洲一区自拍高清免费视频| 黑人解禁人妻叶爱071| 97国产福利小视频合集|