久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4615|回復: 0
打印 上一主題 下一主題
收起左側

基于IAP15F2K61S2單片機水質檢測系統程序設計

[復制鏈接]
跳轉到指定樓層
樓主
本系統由前級采集電路和運算放大電路等信號處理模塊,A/D轉換模塊和數據顯示模塊三部分組成。單片機模塊以STC15F60S2為核心,利用PH傳感器檢測液體PH值,超聲波傳感器檢測水位。本系統主要實現PH值測量,液位情況測量和電壓測量三個功能,經過最終級聯、調試,結果表明,PH值測量誤差低于0.3,液位測量誤差低于1mm,因此達到很高的準確度,各項指標均優于題目要求。

系統方案1.1  PH傳感器選擇
【方案一】采用無溫度檢測的PH傳感器
該方案電路簡單,易于實現,但是在溫度變化大的情況下,易受溫度影響,測量值波動較大,誤差較大不易修正。
【方案二】采用自帶溫度監測的PH傳感器
該方案克服了環境溫度與液體溫度相差較小時,PH檢測誤差較小,易于檢測,穩定性好,誤差易于修正。
【方案三】采用液體溫度檢測與PH傳感器相結合
該方案電路相對來說比較復雜,可實現性不大,穩定性不高。
考慮到電路的穩定性及可實現性,我們選擇方案二。
1.2  液位測量選擇
【方案一】光電監測
該方法對于定位測量效果好、精度高。但不適合對水位高度的測量,無法實時檢測液面高度。
【方案二】超聲波監測
此方法測量時間短,對實時測量液面精度高。測量范圍取決于高頻脈沖的頻率及聲波的大小,對于近距離測量精確都高,價格實惠。
【方案三】平行導線線跡測量
此方法測量精度高,但測量范圍小、易沾被測物,不適合強酸性或強堿性液體測量。
考慮到測量精度和系統的可行性,我們選擇方案二。
系統理論分析與計算
2.1
水情信號處理的分析
2.1.1 PH值處理的分析
本系統利用PH傳感器檢測液體酸堿度。PH檢測電路由前置120dB緩沖放大部分與后級高增益部分構成。本模塊的PH檢測采取TLC4502進行放大。最終系統將輸出信號與標準信號源的輸出值進行比較,得出PH值,并計算出相對精度。
2.1.2 液位處理的分析
采用超聲波傳感器對水和白醋、純凈水進行液位檢測,運用TI公司的高速比較器TL047對前級放大電路輸出信號進行處理。通過超聲波發射裝置發出超聲波,根據接收器接到超聲波時的時間差就可以知道距離。超聲波發射器向某一方向發射超聲波,在發射時刻的同時開始計時,超聲波在空氣中傳播,途中碰到障礙物就立即返回來,超聲波接收器收到反射波就立即停止計時。返回信號通過IO口ECHO輸出一個高電平,高電平持續的時間就是超聲波發射到返回的時間,測試距離=(高電平持續時間*聲速(340M/S))/2,最后將測量值與系統所得值進行對比,并計算得到相對誤差。
2.2 電壓檢測方法的分析
利用STC15F60S2單片機采用A/D轉換電路將輸入電壓轉換成時間(脈沖寬度信號)或頻率(脈沖頻率),然后由定時器/計數器獲得數字值。與萬用表所測結果進行對比,并計算精度。


電路與程序設計
3.1
總體方案設計
該水情檢測系統由PH傳感器和超聲波傳感器組成。PH傳感器用于液體酸堿度測量,超聲波傳感器用于液體高度測量。信號經過前級的放大整形后進入A/D轉換,A/D轉換后將數據傳輸給單片機,單片機對數據進行整理和計算,并將結果顯示出來。系統總體實現框圖如圖1.1所示。

3.2 電路設計
3.2.1PH檢測電路設計
PH檢測電路由前置120dB緩沖放大部分與后級高增益部分構成。本模塊的PH檢測采取TLC4502進行放大,可有效抑制噪聲。本模塊采用的溫度傳感器為熱敏電阻,其阻值隨溫度變化而變化。采用惠斯登電橋保證后續的差分放大時,運算放大器的正反向輸入電壓值為正值,則在此極限溫度下,電橋處于平衡狀態,差分放大輸入電壓差為0。如圖3.2所示。


3.2.2液位檢測電路
運用TI公司的高速比較器TL047對前級放大電路輸出信號進行處理。同時采用了EM78小型微處理器進行信號轉換使其更加準確,并且很好的抑制了噪聲干擾。如圖3.3所示。


3.3 軟件設計
STC15F60S2單片機在該系統主要完成數據計算,功能切換和顯示功能。主程序流程圖如圖3.4所示。  


測試方案與測試結果
4.1 測試方法與儀器
4.1.1測試方法
1)PH值的測量方法:通過對水和白醋、純凈水進行多次測量,采取TLC4502進行放大,最終將系統的輸出信號與標準信號源的輸出值進行比較,得出PH值,并計算出相對精度。
2) 液位的測量方法:采用超聲波傳感器對水和白醋、純凈水進行液位檢測,運用TI公司的高速比較器TL047對前級放大電路輸出信號進行處理。如有信號返回,通過IO口ECHO輸出一個高電平,高電平持續的時間就是超聲波發射到返回的時間,測試距離=(高電平持續時間*聲速(340M/S)) /2,最后將測量值與系統所得值進行對比,并計算得到相對誤差。
3) 電壓的測量方法:將萬用表測量值與單片機所測值進行對比,得到相對精度。
4.1.2 測試儀器
表4.1   測試儀器
  
序號
  
名稱型號規格
數量
1
SIGLENT-SDS3053(500M示波器)
1
2
Agileat 33600A(DDS函數信號發生器)
1
3
SUIN-SS3323  (直流穩壓源)
1
4
NFC-C1000-1型多功能計數器
1
4.2  測試結果4.2.1 PH值的測量
測量結果:使用信號源輸出不同幅度的直流電壓信號,記錄實際測量值。測試結果如表4.2所示
表4.2   PH測量
  
待測物
  
標準PH值
實際PH值
相對誤差

  
水和白醋
2.45
2.90
18.36*10-2
3.42
3.56
4.66*10-2
3.60
3.70
2.77*10-2

  
純凈水和白醋
3.50
3.40
2.86*10-2
3.90
3.93
0.76*10-2
3.70
3.55
4.05*10-2
結論:向塑料容器中注入若干毫升的水和白醋,可以在規定時間內完成PH值測量并顯示,測量偏差遠小于0.5;多次向純凈水中注入若干白醋,能在2分鐘內穩定顯示每次的PH值,同時測量偏差不大于0.1。
4.2.2 液位的測量
不同待測物液位測試結果如表4.3所示。
表4.3  液位測量
  
待測物
  
測量距離/mm
實際距離/mm
相對誤差
水和白醋
158
153
3.1*10-2
純凈水
120
122
1.6*10-2
結論:向塑料容器中注入若干毫升的水和白醋,在1分鐘內完成水位測量并顯示,測量偏差不大于5mm;將塑料容器清空,多次向塑料容器注入若干純凈水,在1分鐘內穩定顯示,每次的水位值偏差不大于2mm。
4.2.3 電壓的測量
供電電池的電壓測試結果如表4.4所示。
表4.4   電壓測量
  
輸入幅度/V
  
測量值/V
相對誤差
3.25
3.24
3.0*10-3
4.98
4.96
4.0*10-3
結論:可以完成供電電池的輸出電壓測量并顯示,測量偏差小于0.01V。
綜上所述,本設計已達到要求。
總結
該系統以STC15F60S2為核心測量器件,配合放大電路設計了高精度水情檢測系統。經過最終的調試,實現了不同情況下水位、PH值及電壓的測量。本系統性能優良,工作可靠,操作簡單,使用方便,完全滿足題目中所有的指標要求。在設計過程中要注意以下問題:電壓小于5V時,采用光耦元器件誤差較大,當電壓高于5V時,應采用A/D轉換電路減小誤差。

單片機源程序如下:
  1. #include <stc15f2k60s2.h>
  2. #include <intrins.h>
  3. #include <lcd12864.h>

  4. //引腳定義
  5. sbit     RX    =  P4^2;
  6. sbit     TX    =  P4^4;

  7. #define FOSC    11059200L
  8. #define BAUD    9600

  9. #define uchar unsigned char
  10. #define uint unsigned int
  11. #define ulong unsigned long

  12. #define     URMD    0           //0:使用定時器2作為波特率發生器
  13.                                 //1:使用定時器1的模式0(16位自動重載模式)作為波特率發生器
  14.                                 //2:使用定時器1的模式2(8位自動重載模式)作為波特率發生器
  15.                              
  16. #define ADC_POWER   0x80            //ADC電源控制位
  17. #define ADC_FLAG    0x10            //ADC完成標志
  18. #define ADC_START   0x08            //ADC起始控制位
  19. #define ADC_SPEEDLL 0x00            //540個時鐘
  20. #define ADC_SPEEDL  0x20            //360個時鐘
  21. #define ADC_SPEEDH  0x40            //180個時鐘
  22. #define ADC_SPEEDHH 0x60            //90個時鐘
  23. /*---全局變量聲明---*/
  24. uchar code CharCode1[]="**水情監測系統**";
  25. uchar code CharCode2[]="液位值:";
  26. uchar code CharCode3[]="PH值:";
  27. uchar code CharCode4[]="電壓值:";
  28. uchar number0[5];                        //水位值儲存
  29. uchar number1[5];                        //PH值儲存
  30. uchar number2[7];                        //電壓值儲存
  31. uchar Test0;                                //標志
  32. uint ad_data1;                                //十位AD值
  33. unsigned int  time=0;
  34.          long S=0;
  35.          bit  flag =0;
  36. ulong distance;                   //距離顯示
  37. /*---函數聲明---*/
  38. void InitUart();
  39. void InitADC();
  40. void Timer0Init(void);                                                                        //10毫秒@11.0592MHz
  41. void Timer2Init(void);                                                                        //10毫秒@11.0592MHz
  42. ulong GetADCResult(uchar ch);
  43. void Delay(uint n);
  44. void IO_Init();                                                                                        //I/O口初始
  45. void LCD12864();                                                                                //LCD初始化顯示
  46. void PH_Value();                                                                                //PH監測化
  47. ulong PH_read(long PH);                                                                        //PH值轉換
  48. void Voltag_read();                                                                                //電壓監測
  49. /*---液位---*/
  50. void Conut(void);
  51. void Distance_Value();                                                                        //液位監測
  52. void delayms(unsigned int ms);
  53. void Timer_Count(void);
  54. void  StartModule();                                                                  //T1中斷用來掃描數碼管和計800MS啟動模塊
  55. ulong datas_Value(long datas);                                                        //數據修正
  56. /*---主函數---*/
  57. void main()
  58. {
  59.           IO_Init();                                                //I/O口初始化
  60.         LCD12864_Init();                                //LCD初始化
  61.         InitUart();                     //初始化串口
  62.     InitADC();                      //初始化ADC
  63.         Timer0Init();                                        //定時器0初始化
  64.         Timer2Init();                                        //定時器2初始化
  65.     while (1)
  66.     {
  67.                         LCD12864();
  68.                         if(Test0==1)
  69.                         {
  70.                                 Test0=0;
  71.                                 PH_Value();
  72.                                 Voltag_read();
  73.                                 Distance_Value();        
  74.                         }                                
  75.     }
  76. }
  77. void IO_Init()                //I/O口模式選擇
  78. {
  79.         P0M0 = 0x00;P0M1 = 0x00;P1M0 = 0x00;P1M1 = 0x00;
  80.         P2M0 = 0x00;P2M1 = 0x00;P3M0 = 0x00;P3M1 = 0x00;
  81.         P4M0 = 0x00;P4M1 = 0x00;P5M0 = 0x00;P5M1 = 0x00;
  82.           P6M0 = 0x00;P6M1 = 0x00;P7M0 = 0x00;P7M1 = 0x00;
  83. }
  84. void LCD12864()                //LCD初始化顯示
  85. {
  86.         uchar i=0;
  87.         uchar j=0;
  88.         uchar k=0;
  89.         uchar t=0;
  90.         LCD12864_SetWindow(0,        0);                        //系統名稱顯示
  91.         while(CharCode1[i]!='\0')
  92.         {
  93.                 LCD12864_WriteData(CharCode1[i]);
  94.                 i++;
  95.                 if(i==16)
  96.                 {
  97.                         i=0;
  98.                         break;
  99.                 }
  100.         }
  101.         LCD12864_SetWindow(1, 0);                        //液位顯示
  102.         while(CharCode2[j]!='\0')
  103.         {
  104.                 LCD12864_WriteData(CharCode2[j]);
  105.                 j++;
  106.                 if(j==15)
  107.                 {
  108.                         j=0;
  109.                         break;
  110.                 }
  111.         }
  112.         LCD12864_SetWindow(2, 0);                        //PH值顯示
  113.         while(CharCode3[k]!='\0')                                
  114.         {
  115.                 LCD12864_WriteData(CharCode3[k]);
  116.                 k++;
  117.                 if(k==8)
  118.                 {
  119.                         k=0;
  120.                         break;
  121.                 }
  122.         }
  123.         LCD12864_SetWindow(3, 0);                 //電壓值顯示
  124.         while(CharCode4[t]!='\0')
  125.         {
  126.                 LCD12864_WriteData(CharCode4[t]);
  127.                 t++;
  128.                 if(t==13)
  129.                 {
  130.                         t=0;
  131.                         break;
  132.                 }
  133.         }
  134. }
  135. void PH_Value()                                                                //PH監測
  136. {
  137.         long PH;
  138.         long datas;
  139.         long num;
  140.         uint i;
  141.         datas=GetADCResult(0);
  142. //        num=datas*(4.5/1.0240);
  143.         num=datas_Value(datas*(4.5/1.024));
  144.         PH=PH_read(num);                                                //PH-Value對比
  145.         number0[0]=PH/1000;                                                 //求十位
  146.         number0[1]=PH%1000/100;                                           //求個位
  147.         number0[2]='.';
  148.         number0[3]=PH%100/10;                                        //求十分位
  149.         number0[4]=PH%10;                                                //求百分位
  150.         LCD12864_SetWindow(2,3);
  151.         for(i=0;i<5;i++)
  152.         {
  153.                 if(i==2)
  154.                         LCD12864_WriteData(number0[i]);
  155.                 else
  156.                         LCD12864_WriteData(number0[i]+48);
  157.         }
  158. }
  159. ulong PH_read(long PH)                                                //PH值轉換
  160. {
  161.                 long datas;
  162.                 if(PH>4242)
  163.                 {
  164.                         datas=0;
  165.                 }else if(PH>4065)
  166.                 {
  167.                         datas=0+(PH-4065)/177.00;
  168.                 }else if(PH>3885)
  169.                 {
  170.                         datas=1+(PH-3885)/180.00;
  171.                 }else if(PH>3709.8)
  172.                 {
  173.                         datas=2+(PH-3709.8)/175.20;
  174.                 }else if(PH>3532.5)
  175.                 {
  176.                         datas=3+(PH-3532.5)/177.30;
  177.                 }else if(PH>3354)
  178.                 {
  179.                         datas=4+(PH-3354)/178.50;
  180.                 }else if(PH>3177.5)
  181.                 {
  182.                         datas=5+(PH-3177.5)/176.50;
  183.                 }else if(PH>3000)
  184.                 {
  185.                         datas=6+(PH-3000)/177.50;
  186.                 }else if(PH>2822.5)
  187.                 {
  188.                         datas=7+(PH-2822.5)/177.50;
  189.                 }else if(PH>2646)
  190.                 {
  191.                         datas=8+(PH-2646)/176.50;
  192.                 }else if(PH>2467.5)
  193.                 {
  194.                         datas=9+(PH-2467.5)/178.50;
  195.                 }else if(PH>2292)
  196.                 {
  197.                         datas=10+(PH-2292)/175.50;
  198.                 }else if(PH>2115)
  199.                 {
  200.                         datas=11+(PH-2115)/177.00;
  201.                 }else if(PH>1938)
  202.                 {
  203.                         datas=12+(PH-1938)/177.00;
  204.                 }else if(PH>1758)
  205.                 {
  206.                         datas=13+(PH-1758)/180.00;
  207.                 }
  208.                 else
  209.                 {
  210.                         datas=14;
  211.                 }
  212.                 datas=datas*100;
  213.                 return datas;
  214. }
  215. void Voltag_read()                                                        //電壓監測
  216. {
  217.         long voltag;
  218.         long datas;
  219.         uint i;
  220.         datas=GetADCResult(1);
  221. //        voltag=datas*(4.5/1.024);
  222.         voltag=datas_Value(datas*(4.5/1.024));
  223.         number1[0]=voltag/1000;                                           //求個位
  224.         number1[1]='.';
  225.         number1[2]=voltag%1000/100;                                //求十分位
  226.         number1[3]=voltag%100/10;                                //求百分位
  227.         number1[4]='V';
  228.         LCD12864_SetWindow(3, 4);
  229.         for(i=0;i<5;i++)
  230.         {
  231.                 if(i==1|i==4)
  232.                         LCD12864_WriteData(number1[i]);
  233.                 else
  234.                         LCD12864_WriteData(number1[i]+48);
  235.         }
  236. }
  237. /*---液位---*/
  238. void Conut(void)
  239. {
  240.         int i;
  241.         time=TH0*256+TL0;
  242.         TH0=0;
  243.         TL0=0;
  244.         S=(time*1.8)/10;                             //算出來是mm
  245.         S=280-S;
  246.         if((S>=7000)||flag==1)                 //超出測量范圍顯示“-”         
  247.                 flag=0;
  248.         else
  249.         {
  250.                 number2[0]=S/1000;
  251.                   number2[1]=S/100%10;
  252.                   number2[2]=S/10%10;
  253.                   number2[3]=S%10;
  254.                   number2[4]='m';
  255.                   number2[5]='m';
  256.                   LCD12864_SetWindow(1,4);
  257.                 for(i=0;i<6;i++)
  258.                 {
  259.                         if(i==4|i==5)
  260.                                 LCD12864_WriteData(number2[i]);        
  261.                         else
  262.                                 LCD12864_WriteData(number2[i]+48);
  263.                 }
  264.          }
  265. }
  266. void delayms(unsigned int ms)
  267. {
  268.         unsigned char i=100,j;
  269.         for(;ms;ms--)
  270.         {
  271.                 while(--i)
  272.                 {
  273.                         j=10;
  274.                         while(--j);
  275.                 }
  276.         }
  277. }
  278. void Timer_Count(void)
  279. {
  280.         TR0=1;                            //開啟計數
  281.         while(RX);                        //當RX為1計數并等待
  282.         TR0=0;                                //關閉計數
  283.     Conut();                        //計算

  284. }
  285. void  StartModule()                          //T1中斷用來掃描數碼管和計800MS啟動模塊
  286. {
  287.           TX=1;                                         //800MS  啟動一次模塊
  288.           _nop_();
  289.           _nop_();
  290.           _nop_();
  291.           _nop_();
  292.           _nop_();
  293.           _nop_();
  294.           _nop_();
  295.           _nop_();
  296.           _nop_();
  297.           _nop_();
  298.           _nop_();
  299.           _nop_();
  300.           _nop_();
  301.           _nop_();
  302.           _nop_();
  303.           _nop_();
  304.           _nop_();
  305.           _nop_();
  306.           _nop_();
  307.           _nop_();
  308.           _nop_();
  309.           TX=0;
  310. }
  311. void Distance_Value()
  312. {
  313.         unsigned int valA;
  314.         delayms(60);
  315.         RX=1;
  316.         StartModule();
  317.     for(valA=7510;valA>0;valA--)
  318.         {   
  319.                 if(RX==1)
  320.                 {
  321.                         Timer_Count();
  322.                 }
  323.         }
  324. }
  325. ulong datas_Value(long datas)                                //數據修正
  326. {
  327.         int i;
  328.         long v,sum,value[20];
  329.         for(i=0;i<20;i++)
  330.         {
  331.                 value[i]=datas;
  332.                 sum+=value[i];
  333.         }
  334.         v=sum/50.00;
  335.         return v;
  336. }
  337. /*---發送ADC結果到PC---*/
  338. /*
  339. void ShowResult(char ch)
  340. {
  341. // SendData(ch);                   //顯示通道號
  342. //        SendData(GetADCResult(ch));     //顯示ADC高8位結果

  343. //   SendData(ADC_RESL);                    //顯示低2位結果
  344. }
  345. */
  346. /*---讀取ADC結果---*/
  347. unsigned long GetADCResult(uchar ch)
  348. {
  349.     ADC_CONTR = ADC_POWER | ADC_SPEEDLL | ch | ADC_START;
  350.     _nop_();                        //等待4個NOP
  351.     _nop_();
  352.     _nop_();
  353.     _nop_();
  354.     while (!(ADC_CONTR & ADC_FLAG));//等待ADC轉換完成
  355.     ADC_CONTR &= ~ADC_FLAG;                                 //Close ADC
  356.         ad_data1=ADC_RES<<2;                                                //因為是10位的AD,因此需要把AD轉換后的低8位向高位移動2位
  357.     ad_data1=ad_data1|ADC_RESL&0x03;                        //再把高8位和低2位相加。
  358.         ad_data1=ad_data1/1.024;
  359.     return ad_data1;                                        //返回ADC結果
  360. }
  361. /*---初始化ADC---*/
  362. void InitADC()
  363. {
  364.     P1ASF = 0xff;                   //設置P1口為AD口
  365.         CLK_DIV &=0xdf;
  366.     ADC_RES = 0;                    //清除結果寄存器
  367.         ADC_RESL= 0;
  368.     ADC_CONTR = ADC_POWER | ADC_SPEEDH;
  369.     Delay(2);                       //ADC上電并延時
  370. }
  371. /*---初始化串口---*/
  372. void InitUart()
  373. {
  374.     SCON = 0x5a;                //設置串口為8位可變波特率
  375. #if URMD == 0
  376.     T2L = 0xd8;                 //設置波特率重裝值
  377.     T2H = 0xff;                 //115200 bps(65536-18432000/4/115200)
  378.     AUXR = 0x14;                //T2為1T模式, 并啟動定時器2
  379.     AUXR |= 0x01;               //選擇定時器2為串口1的波特率發生器
  380. #elif URMD == 1
  381.     AUXR = 0x40;                //定時器1為1T模式
  382.     TMOD = 0x00;                //定時器1為模式0(16位自動重載)
  383.     TL1 = 0xd8;                 //設置波特率重裝值
  384.     TH1 = 0xff;                 //115200 bps(65536-18432000/4/115200)
  385.     TR1 = 1;                    //定時器1開始啟動
  386. #else
  387.     TMOD = 0x20;                //設置定時器1為8位自動重裝載模式
  388.     AUXR = 0x40;                //定時器1為1T模式
  389.     TH1 = TL1 = 0xfb;           //115200 bps(256 - 18432000/32/115200)
  390.     TR1 = 1;
  391. #endif
  392. }
  393. /*---發送串口數據---*/
  394. /*
  395. void SendData(uchar dat)
  396. {
  397.     while (!TI);                    //等待前一個數據發送完成
  398. ……………………

  399. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼


所有資料51hei提供下載(代碼):
簡易水情監測.zip (90.36 KB, 下載次數: 44)


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏2 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产精品99久久久久久宅男 | 久久性色| 天天综合网91 | 日韩免费一区 | 亚洲网站在线观看 | 日韩欧美理论片 | 国产成人精品一区二区三区在线 | 视频一区二区中文字幕 | 五月天婷婷久久 | 久久久精品视频一区二区三区 | 最新免费黄色网址 | 高清欧美性猛交 | 国产乱码精品一区二区三区忘忧草 | 亚洲网站在线观看 | 亚洲国产网 | 欧美日韩精品一区二区三区蜜桃 | 国产在线一区二区 | 亚洲综合视频 | 在线欧美一区二区 | 亚洲激情综合 | 中文字幕中文字幕 | 噜噜噜噜狠狠狠7777视频 | 美女福利网站 | www.jizzjizz| 国产一区二区欧美 | 亚洲午夜视频在线观看 | 午夜精品一区二区三区在线视 | 亚洲国产电影 | 久久激情网 | 夜夜爽99久久国产综合精品女不卡 | 色偷偷人人澡人人爽人人模 | 色综合久| 国产精品一区二区三区四区 | 久久精品| 免费久久网 | 亚洲色综合 | 欧美中文字幕在线观看 | 欧美精品一区二区在线观看 | 91不卡| 日韩网站在线观看 | 欧美一级在线免费观看 |