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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

error C129: missing ';' before 'Ds18b20Init' 請問大佬們怎么修改?

[復制鏈接]
跳轉到指定樓層
樓主
ID:545543 發表于 2019-5-29 22:24 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. #include<reg52.h>
  2. void LcdDisplay(int);
  3. void DigDisplay();
  4. void chaomax();
  5. void chaomin();
  6. void guomax();
  7. void guomin();
  8. //存儲上下限變量
  9. int tempmax=30,tempmin=20,tempt,tempmode=0;
  10. int jileimax=0,jileimin=0,jileimid=0;

  11. void Delay1ms(unsigned char x)
  12. {
  13. unsigned char i,j;
  14.   for(i=0;i<x;i++)
  15.   for(j=0;j<112;j++);
  16. }
  17. uchar  Ds18b20Init()
  18. {
  19.         uchar i;
  20.         DSPORT = 0;                         //將總線拉低480us~960us
  21.         //i = 70;        
  22.         i = 900;        
  23.         while(i--);//延時642us
  24.         DSPORT = 1;                        //然后拉高總線,如果DS18B20做出反應會將在15us~60us后總線拉低
  25.         i = 0;
  26.         while(DSPORT)        //等待DS18B20拉低總線
  27.         {
  28.                 Delay1ms(1);
  29.                 i++;
  30.                 if(i>5)//等待>5MS
  31.                 {
  32.                         return 0;//初始化失敗
  33.                 }
  34.         
  35.         }
  36.         return 1;//初始化成功
  37. }
  38. void Ds18b20WriteByte(uchar dat)//????????
  39. {
  40.         uint i, j;
  41.         for(j=0; j<8; j++)
  42.         {
  43.                 DSPORT = 0;                       //每寫入一位數據之前先把總線拉低1us     
  44.                 i++;
  45.                 DSPORT = dat & 0x01;  //然后寫入一個數據,從最低位開始
  46.                 i=8;
  47.                 while(i--); //延時8us        
  48.                 DSPORT = 1;        //然后釋放總線,至少1us給總線恢復時間才能接著寫入第二個數值
  49.                 dat >>= 1;
  50.         }
  51. }
  52. [u][i][b]uchar Ds18b20ReadByte()[/b][/i][/u]
  53. {
  54.         uchar byte, bi;
  55.         uint i, j;        
  56.         for(j=8; j>0; j--)
  57.         {
  58.                 DSPORT = 0;//先將總線拉低1us
  59.                 i++;
  60.                 DSPORT = 1;//然后釋放總線
  61.                 i++;
  62.                 i++;//延時2us等待數據穩定
  63.                 bi = DSPORT;         //讀取數據,從最低位開始讀取
  64.         /*將byte左移一位,然后或上右移7位后的bi,注意移動之后移掉那位補0。*/
  65.                 byte = (byte >> 1) | (bi << 7);                                                  
  66.                 i = 4;                //讀取完之后等待4us再接著讀取下一個數
  67.                 while(i--);
  68.         }                                
  69.         return byte;
  70. }
  71. void  Ds18b20ChangTemp()
  72. {
  73.         Ds18b20Init();
  74.         Delay1ms(1);
  75.         Ds18b20WriteByte(0xcc);                //跳過ROM操作命令                 
  76.         Ds18b20WriteByte(0x44);            //溫度轉換命令
  77.         Delay1ms(20);        //等待轉換成功,而如果你是一直刷著的話,就不用這個延時了
  78. }
  79. void  Ds18b20ReadTempCom()
  80. {        
  81.         Ds18b20Init();
  82.         Delay1ms(1);
  83.         Ds18b20WriteByte(0xcc);         //跳過ROM操作命令
  84.         Ds18b20WriteByte(0xbe);         //發送讀取溫度命令
  85. }
  86. int Ds18b20ReadTemp()
  87. {
  88.         int temp = 0;
  89.         uchar tmh, tml;
  90.         Ds18b20ChangTemp();                                 //先寫入轉換命令
  91.         Ds18b20ReadTempCom();                        //然后等待轉換完后發送讀取溫度命令
  92.         tml = Ds18b20ReadByte();                //讀取溫度值共16位,先讀低字節
  93.         tmh = Ds18b20ReadByte();                //再讀高字節
  94.         temp = tmh;
  95.         temp <<= 8;
  96.         temp |= tml;
  97.         return temp;
  98. }
  99. void LcdDisplay(int temp)          //lcd顯示
  100.         float tp;  
  101.         if(temp< 0)                                //當溫度值為負數
  102.           {
  103.                 DisplayData[0] = 0x40;
  104.                 //因為讀取的溫度是實際溫度的補碼,所以減1,再取反求出原碼
  105.                 temp=temp-1;
  106.                 temp=~temp;
  107.                 tp=temp;
  108.                 temp=tp*0.0625*100+0.5;        
  109.                 //留兩個小數點就*100,+0.5是四舍五入,因為C語言浮點數轉換為整型的時候把小數點
  110.                 //后面的數自動去掉,不管是否大于0.5,而+0.5之后大于0.5的就是進1了,小于0.5的就
  111.                 //算加上0.5,還是在小數點后面。
  112.           }
  113.          else
  114.           {                        
  115.                 DisplayData[0] = 0x00;
  116.                 tp=temp;//因為數據處理有小數點所以將溫度賦給一個浮點型變量
  117.                 //如果溫度是正的那么,那么正數的原碼就是補碼它本身
  118.                 temp=tp*0.0625*100+0.5;        
  119.                 //留兩個小數點就*100,+0.5是四舍五入,因為C語言浮點數轉換為整型的時候把小數點
  120.                 //后面的數自動去掉,不管是否大于0.5,而+0.5之后大于0.5的就是進1了,小于0.5的就
  121.                 //算加上0.5,還是在小數點后面。
  122.         }
  123.         DisplayData[0] = DIG_CODE[tempmax / 10];
  124.         DisplayData[1] = DIG_CODE[tempmax % 10];
  125.         DisplayData[4] = DIG_CODE[tempmin / 10];
  126.         DisplayData[5] = DIG_CODE[tempmin % 10];
  127.         DisplayData[2] = DIG_CODE[temp % 10000 / 1000];
  128.         DisplayData[3] = DIG_CODE[temp % 1000/100];
  129.          DigDisplay();                                           //掃描顯示
  130. void DigDisplay()
  131. {
  132.         unsigned char i;
  133.         unsigned int j;
  134.         for(i=0;i<6;i++)
  135.         {
  136.                 switch(i)         //位選,選擇點亮的數碼管
  137.                 {
  138.                         
  139.                         case(0):
  140.                                 LS1=0;LS2=1;LS3=1;LS4=1;LS5=1;LS6=1; break;//顯示第0位
  141.                         case(1):
  142.                                 LS1=1;LS2=0;LS3=1;LS4=1;LS5=1;LS6=1; break;//顯示第1位
  143.                         
  144.                         case(2):
  145.                                 LS1=1;LS2=1;LS3=0;LS4=1;LS5=1;LS6=1; break;//顯示第2位
  146.                         case(3):
  147.                                 LS1=1;LS2=1;LS3=1;LS4=0;LS5=1;LS6=1; break;//顯示第3位
  148.                         
  149.                         case(4):
  150.                                 LS1=1;LS2=1;LS3=1;LS4=1;LS5=0;LS6=1; break;//顯示第4位
  151.                         case(5):
  152.                                 LS1=1;LS2=1;LS3=1;LS4=1;LS5=1;LS6=0; break;//顯示第5位
  153.                 }
  154.                 GPIO_DIG=DisplayData[i];//發送段碼
  155.                 j=200;                                                 //掃描間隔時間設定
  156.                 while(j--);        
  157.                 GPIO_DIG=0x00;//消隱
  158.         }
  159. }

  160. void main()
  161. {
  162.         buzzer=1;
  163.         
  164.         while(1)
  165.         {
  166.                 LcdDisplay(Ds18b20ReadTemp());
  167.         }
  168. }
  169. //#include"temp.h"

  170. void chaomax()
  171.       {
  172.         buzzer=1;
  173.                         
  174.        }
  175.         if(key1==0)
  176.                 {
  177.                         Delay1ms(300);//按鍵防抖
  178.                         if(key1==0)
  179.                         {
  180.                         tempmax++;
  181.                         }
  182.                 }
  183.                         if(key2==0)
  184.                 {
  185.                         Delay1ms(300);
  186.                         if(key2==0)
  187.                         {
  188.                         tempmax--;
  189.                         }                        
  190.                 }
  191.                         if(key3==0)
  192.                 {
  193.                         Delay1ms(300);
  194.                         if(key3==0)
  195.                         {
  196.                         tempmin++;
  197.                         }        
  198.                 }
  199.                         if(key4==0)
  200.                 {
  201.                         Delay1ms(300);
  202.                         if(key4==0)
  203.                         {
  204.                         tempmin--;
  205.                         }
  206.                 }

  207. if(temp<(tempmin*100))//*100是為了使當前值和最小值在同一數量級比較
  208.         {
  209.                 jileimin++;
  210.                 jileimid=0;               
  211.                 if(jileimin>3)//掃描3次以確定已經低于下限值
  212.                 {
  213.                 tempmode=1;        //區分當前值是否是原值還是恢復值,原值為0,由上限值恢復是2,由下限值恢復時1
  214.           chaomin();
  215.                 jileimin=0;//積累值置位
  216.                 }
  217.         }
  218.         if(temp>(tempmax*100))
  219.         {
  220.                 jileimax++;
  221.                 jileimid=0;
  222.                 if(jileimax>3)
  223.                 {
  224.                 tempmode=2;         
  225.                         chaomax();
  226.                         jileimax=0;
  227.                 }
  228.         }
  229.         
  230.         if((tempmin*100)<temp&&temp<(tempmax*100))
  231.         {
  232.                 jileimax=0;
  233.                 jileimin=0;
  234.                 jileimid++;
  235.         if(jileimid>3)
  236.         {
  237.            switch(tempmode)
  238.                 {
  239.                          case 0:buzzer=0;break;
  240.                          case 1:guomin();break;
  241.                          case 2:guomax();break;                 
  242.                 }               
  243.                 tempmode=0;
  244.                 buzzer=0;
  245.                 jileimid=0;
  246.         }
  247.         }
  248. //三聲短鳴表示低于溫度下限
  249. void chaomin()
  250.     {
  251.        buzzer=1;
  252.                          Delay1ms(200);
  253.                          buzzer=0;
  254.                          Delay1ms(200);
  255.                          buzzer=1;
  256.                          Delay1ms(200);
  257.                          buzzer=0;
  258.                          Delay1ms(200);
  259.                          buzzer=1;
  260.                          Delay1ms(200);
  261.                          buzzer=0;
  262.                          Delay1ms(1000);
  263.                 }

  264. //三聲短鳴表示超過溫度上限               
  265. void guomax()
  266.                 {
  267.                          buzzer=0;
  268.                          Delay1ms(200);
  269.                    buzzer=1;
  270.                          Delay1ms(200);
  271.                          buzzer=0;
  272.                          Delay1ms(200);
  273.                          buzzer=1;
  274.                          Delay1ms(200);
  275.                          buzzer=0;
  276.                          Delay1ms(200);
  277.                          buzzer=1;
  278.                          Delay1ms(200);
  279.                          buzzer=0;
  280.                          Delay1ms(200);
  281.                 }
  282. //2秒長鳴表示超過溫度下限               
  283. void guomin()
  284.     {
  285.       buzzer=1;
  286.                         Delay1ms(2000);
  287.                         buzzer=0;
  288.     }
復制代碼


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

使用道具 舉報

沙發
ID:155507 發表于 2019-5-29 23:54 | 只看該作者
你這個程序不完整,你檢查一下

少了這個
#define uchar unsigned char
#define uint unsigned int
回復

使用道具 舉報

板凳
ID:155507 發表于 2019-5-30 19:37 | 只看該作者
原理圖得提供啊,怎么接線的
單片機程序是要針對相應的硬件環境的,
給你改了一下試試。這個要看你的硬件電路了


  1. #include <reg52.h>

  2. #define uchar unsigned char
  3. #define uint unsigned int
  4. #define GPIO_DIG P1

  5. sbit DSPORT=P3^6; //DS18B20管腳定義
  6. sbit buzzer=P3^7;
  7. sbit key1=P3^2; //按鍵
  8. sbit key2=P3^3;
  9. sbit key3=P3^4;
  10. sbit key4=P3^5;

  11. sbit LS1=P2^0; //位選
  12. sbit LS2=P2^1;
  13. sbit LS3=P2^2;
  14. sbit LS4=P2^3;
  15. sbit LS5=P2^4;
  16. sbit LS6=P2^5;

  17. void LcdDisplay(int);
  18. void DigDisplay();
  19. void chaomax();
  20. void chaomin();
  21. void guomax();
  22. void guomin();
  23. void key();

  24. //存儲上下限變量
  25. int tempmax=30, tempmin=20, tempt, tempmode=0;
  26. int jileimax=0, jileimin=0, jileimid=0;

  27. void Delay1ms(unsigned char x)
  28. {
  29.         unsigned char i,j;
  30.         for(i=0;i<x;i++)
  31.             for(j=0;j<112;j++);
  32. }
  33. uchar  Ds18b20Init()
  34. {
  35.         uchar i;
  36.         DSPORT = 0;                         //將總線拉低480us~960us
  37.         //i = 70;        
  38.         i = 900;        
  39.         while(i--);//延時642us
  40.         DSPORT = 1;                        //然后拉高總線,如果DS18B20做出反應會將在15us~60us后總線拉低
  41.         i = 0;
  42.         while(DSPORT)        //等待DS18B20拉低總線
  43.         {
  44.                 Delay1ms(1);
  45.                 i++;
  46.                 if(i>5)//等待>5MS
  47.                 {
  48.                         return 0;//初始化失敗
  49.                 }
  50.                
  51.         }
  52.         return 1;//初始化成功
  53. }
  54. void Ds18b20WriteByte(uchar dat)//????????
  55. {
  56.         uint i, j;
  57.         for(j=0; j<8; j++)
  58.         {
  59.                 DSPORT = 0;                       //每寫入一位數據之前先把總線拉低1us     
  60.                 i++;
  61.                 DSPORT = dat & 0x01;  //然后寫入一個數據,從最低位開始
  62.                 i=8;
  63.                 while(i--); //延時8us        
  64.                 DSPORT = 1;        //然后釋放總線,至少1us給總線恢復時間才能接著寫入第二個數值
  65.                 dat >>= 1;
  66.         }
  67. }
  68. uchar Ds18b20ReadByte()
  69. {
  70.         uchar byte, bi;
  71.         uint i, j;        
  72.         for(j=8; j>0; j--)
  73.         {
  74.                 DSPORT = 0; //先將總線拉低1us
  75.                 i++;
  76.                 DSPORT = 1; //然后釋放總線
  77.                 i++;
  78.                 i++; //延時2us等待數據穩定
  79.                 bi = DSPORT;         //讀取數據,從最低位開始讀取
  80.                 /*將byte左移一位,然后或上右移7位后的bi,注意移動之后移掉那位補0。*/
  81.                 byte = (byte >> 1) | (bi << 7);                                                  
  82.                 i = 4;                //讀取完之后等待4us再接著讀取下一個數
  83.                 while(i--);
  84.         }                                
  85.         return byte;
  86. }
  87. void  Ds18b20ChangTemp()
  88. {
  89.         Ds18b20Init();
  90.         Delay1ms(1);
  91.         Ds18b20WriteByte(0xcc);    //跳過ROM操作命令                 
  92.         Ds18b20WriteByte(0x44);    //溫度轉換命令
  93.         Delay1ms(20);         //等待轉換成功,而如果你是一直刷著的話,就不用這個延時了
  94. }
  95. void  Ds18b20ReadTempCom()
  96. {        
  97.         Ds18b20Init();
  98.         Delay1ms(1);
  99.         Ds18b20WriteByte(0xcc);         //跳過ROM操作命令
  100.         Ds18b20WriteByte(0xbe);         //發送讀取溫度命令
  101. }
  102. int Ds18b20ReadTemp()
  103. {
  104.         int temp = 0;
  105.         uchar tmh, tml;
  106.         Ds18b20ChangTemp();                     //先寫入轉換命令
  107.         Ds18b20ReadTempCom();                   //然后等待轉換完后發送讀取溫度命令
  108.         tml = Ds18b20ReadByte();                //讀取溫度值共16位,先讀低字節
  109.         tmh = Ds18b20ReadByte();                //再讀高字節
  110.         temp = tmh;
  111.         temp <<= 8;
  112.         temp |= tml;
  113.         return temp;
  114. }
  115. void LcdDisplay(int temp)          //lcd顯示???
  116. {

  117.         float tp;  
  118.         if(temp< 0)                                //當溫度值為負數
  119.         {
  120.                 DisplayData[0] = 0x40;
  121.                 //因為讀取的溫度是實際溫度的補碼,所以減1,再取反求出原碼
  122.                 temp=temp-1;
  123.                 temp=~temp;
  124.                 tp=temp;
  125.                 temp=tp*0.0625*100+0.5;        
  126.                 //留兩個小數點就*100,+0.5是四舍五入,因為C語言浮點數轉換為整型的時候把小數點
  127.                 //后面的數自動去掉,不管是否大于0.5,而+0.5之后大于0.5的就是進1了,小于0.5的就
  128.                 //算加上0.5,還是在小數點后面。
  129.         }
  130.         else
  131.         {                        
  132.                 DisplayData[0] = 0x00;
  133.                 tp=temp;//因為數據處理有小數點所以將溫度賦給一個浮點型變量
  134.                 //如果溫度是正的那么,那么正數的原碼就是補碼它本身
  135.                 temp=tp*0.0625*100+0.5;        
  136.                 //留兩個小數點就*100,+0.5是四舍五入,因為C語言浮點數轉換為整型的時候把小數點
  137.                 //后面的數自動去掉,不管是否大于0.5,而+0.5之后大于0.5的就是進1了,小于0.5的就
  138.                 //算加上0.5,還是在小數點后面。
  139.         }
  140.         DisplayData[0] = DIG_CODE[tempmax / 10];
  141.         DisplayData[1] = DIG_CODE[tempmax % 10];
  142.         DisplayData[4] = DIG_CODE[tempmin / 10];
  143.         DisplayData[5] = DIG_CODE[tempmin % 10];
  144.         DisplayData[2] = DIG_CODE[temp % 10000 / 1000];
  145.         DisplayData[3] = DIG_CODE[temp % 1000/100];
  146.         DigDisplay();   
  147. }                                        //掃描顯示
  148. void DigDisplay()
  149. {
  150.         unsigned char i;
  151.         unsigned int j;
  152.         for(i=0;i<6;i++)
  153.         {
  154.                 switch(i)         //位選,選擇點亮的數碼管
  155.                 {
  156.                        
  157.                         case(0):
  158.                         LS1=0;LS2=1;LS3=1;LS4=1;LS5=1;LS6=1; break;//顯示第0位
  159.                         case(1):
  160.                         LS1=1;LS2=0;LS3=1;LS4=1;LS5=1;LS6=1; break;//顯示第1位
  161.                        
  162.                         case(2):
  163.                         LS1=1;LS2=1;LS3=0;LS4=1;LS5=1;LS6=1; break;//顯示第2位
  164.                         case(3):
  165.                         LS1=1;LS2=1;LS3=1;LS4=0;LS5=1;LS6=1; break;//顯示第3位
  166.                        
  167.                         case(4):
  168.                         LS1=1;LS2=1;LS3=1;LS4=1;LS5=0;LS6=1; break;//顯示第4位
  169.                         case(5):
  170.                         LS1=1;LS2=1;LS3=1;LS4=1;LS5=1;LS6=0; break;//顯示第5位
  171.                 }
  172.                 GPIO_DIG=DisplayData[i]; //發送段碼
  173.                 j=200;                                         //掃描間隔時間設定
  174.                 while(j--);        
  175.                 GPIO_DIG=0x00; //消隱
  176.         }
  177. }

  178. void main()
  179. {
  180.         buzzer=1;
  181.        
  182.         while(1)
  183.         {
  184.                 LcdDisplay(Ds18b20ReadTemp());
  185.                 key();
  186.         }
  187. }
  188. //#include"temp.h"

  189. void chaomax()
  190. {
  191.         buzzer=1;
  192.        
  193. }

  194. void key()
  195. {

  196.         if(key1==0)
  197.         {
  198.                 Delay1ms(300);//按鍵防抖
  199.                 if(key1==0)
  200.                 {
  201.                         tempmax++;
  202.                 }
  203.         }
  204.         if(key2==0)
  205.         {
  206.                 Delay1ms(300);
  207.                 if(key2==0)
  208.                 {
  209.                         tempmax--;
  210.                 }                        
  211.         }
  212.         if(key3==0)
  213.         {
  214.                 Delay1ms(300);
  215.                 if(key3==0)
  216.                 {
  217.                         tempmin++;
  218.                 }        
  219.         }
  220.         if(key4==0)
  221.         {
  222.                 Delay1ms(300);
  223.                 if(key4==0)
  224.                 {
  225.                         tempmin--;
  226.                 }
  227.         }

  228.         if(temp<(tempmin*100))//*100是為了使當前值和最小值在同一數量級比較
  229.         {
  230.                 jileimin++;
  231.                 jileimid=0;               
  232.                 if(jileimin>3)//掃描3次以確定已經低于下限值
  233.                 {
  234.                         tempmode=1;        //區分當前值是否是原值還是恢復值,原值為0,由上限值恢復是2,由下限值恢復時1
  235.                         chaomin();
  236.                         jileimin=0;//積累值置位
  237.                 }
  238.         }
  239.         if(temp>(tempmax*100))
  240.         {
  241.                 jileimax++;
  242.                 jileimid=0;
  243.                 if(jileimax>3)
  244.                 {
  245.                         tempmode=2;         
  246.                         chaomax();
  247.                         jileimax=0;
  248.                 }
  249.         }

  250.         if((tempmin*100)<temp&&temp<(tempmax*100))
  251.         {
  252.                 jileimax=0;
  253.                 jileimin=0;
  254.                 jileimid++;
  255.                 if(jileimid>3)
  256.                 {
  257.                         switch(tempmode)
  258.                         {
  259.                         case 0:buzzer=0;break;
  260.                         case 1:guomin();break;
  261.                         case 2:guomax();break;                 
  262.                         }               
  263.                         tempmode=0;
  264.                         buzzer=0;
  265.                         jileimid=0;
  266.                 }
  267.         }
  268. }
  269. //三聲短鳴表示低于溫度下限
  270. void chaomin()
  271. {
  272.         buzzer=1;
  273.         Delay1ms(200);
  274.         buzzer=0;
  275.         Delay1ms(200);
  276.         buzzer=1;
  277.         Delay1ms(200);
  278.         buzzer=0;
  279.         Delay1ms(200);
  280.         buzzer=1;
  281.         Delay1ms(200);
  282.         buzzer=0;
  283.         Delay1ms(1000);
  284. }

  285. //三聲短鳴表示超過溫度上限               
  286. void guomax()
  287. {
  288.         buzzer=0;
  289.         Delay1ms(200);
  290.         buzzer=1;
  291.         Delay1ms(200);
  292.         buzzer=0;
  293.         Delay1ms(200);
  294.         buzzer=1;
  295.         Delay1ms(200);
  296.         buzzer=0;
  297.         Delay1ms(200);
  298.         buzzer=1;
  299.         Delay1ms(200);
  300.         buzzer=0;
  301.         Delay1ms(200);
  302. }
  303. //2秒長鳴表示超過溫度下限               
  304. void guomin()
  305. {
  306.         buzzer=1;
  307.         Delay1ms(2000);
  308.         buzzer=0;
  309. }

復制代碼
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久久一区二区三区 | 蜜臀久久99精品久久久久久宅男 | 91久久久久久久久 | 婷婷在线视频 | 成人在线精品视频 | 亚洲成人天堂 | 亚洲精品视频在线播放 | 久久69精品久久久久久久电影好 | 日本不卡一区 | 亚洲综合色视频在线观看 | 欧美性久久久 | 夫妻午夜影院 | 久久久久久国产精品 | 午夜激情在线 | 一区中文字幕 | 亚洲精品一区在线观看 | 91久久久久 | 欧美一区二区三区大片 | 看亚洲a级一级毛片 | 国产精品日韩一区二区 | 一区二区国产精品 | 久久国产精品一区 | 在线观看国产www | 亚洲国产精品一区在线观看 | 欧美成人免费在线 | 国产精品999| 99久久99| 91国内外精品自在线播放 | 久久这里只有 | 欧美高清视频在线观看 | 男人的天堂一级片 | 亚洲第一av网站 | 婷婷久久综合 | 视频一区二区在线观看 | 91视频网址 | 日韩精品中文字幕一区二区三区 | 在线中文字幕国产 | 国产日韩电影 | 国产在线一区二区 | 国产农村妇女毛片精品久久麻豆 | 亚洲精品一区二区三区中文字幕 |