wwwxxx国产_337p日本欧洲亚洲大胆张筱雨_免费在线看成人av_日本黄色不卡视频_国产精品成熟老女人_99视频一区_亚洲精品97久久中文字幕_免费精品视频在线_亚洲色图欧美视频_欧美一区二三区

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機pov彩燈旋轉LED顯示原理介紹與程序電路原理圖設計

[復制鏈接]
跳轉到指定樓層
樓主
ID:1164104 發表于 2025-12-4 23:09 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
分享一個基于STC12C5A60S3單片機的pov彩燈設計,含代碼
旋轉LED顯示原理介紹
如何讓一列燈旋轉起來感覺像穩定的字顯示在空中呢?首先我們來分析下人的眼睛,其實人的眼睛非常好騙的,只要讓電機掃描的快一點就行了,實際上肉眼在24幀/秒以上就不會看到閃爍的,所以要保證電機的速度能在一秒轉24圈以上,這樣的話人眼就覺得旋轉的字很穩定很清晰的顯示在空中了。
旋轉LED旋轉起來是一個圓,那么就需要有一個傳感器來判斷起點位置,有人用霍爾傳感器,有人用紅外對管,筆者覺得用紅外對管來的便宜些,而且實現起來也容易。這個起點檢測非常重要,單片機就是根據這個起點來判斷是否要開始顯示 數據的。如果起點檢測不到 單片機就不開始顯示。
如何讓一列燈不斷的送數據實現一個文字的顯示呢?這個我們就要了解文字取模的原理了,這里以PC2002字幕軟件為例,取一個16*16的中文字,見字幕選項設置:
從第一列開始向下每取8個點作為一個字節,如果最后不足8個點就補滿8位。
   取模順序是從低到高,即第一個點作為最低位。如*-------取為00000001
  
取模后如下表:
0xFF,0x7F,0xFF,0xBF,0x3F,0xC8,0xBF,0xFB,0xBF,0xFB,0xBF,0xEB,0x80,0x9B,0xB7,0xFB,0xB7,0xEB,0xB7,0x9B,0xB7,0xFB,0x37,0xF8,0xF7,0xEF,0xF7,0x1F,0xFF,0xFF,0xFF,0xFF,/*"點",0*/
現在我們知道16*16取模是一列一列取的了,一列有2個字節,一共16列,所以一個16*16的漢字就有32個字節,需要占用單片機的Code空間 32個字節。然后再結合硬件來分析,如下圖:
一列燈16個 剛好對應16*16一個漢字的一列:2個字節,所以把取模到的數據依次送到P2口 和P4 P5口,這里硬件中P4 P5組成一個字節,所以顯示程序如下:
for(i=0;i<16;i++) //送16列   顯示 這里只顯示一個字。
            {                  
              P2=zimo[i*2]; //送數據低位顯示
              P4=(zimo[i*2+1]);//送數據高位顯示 這里用了單片機P4 和P5口 是LQFP48腳才有的IO口
              P5=(zimo[i*2+1])>>4;//這里行和列 都是IO口獨立驅動的LED
                DelayUs(200);  //延時讓LED亮起來 每列延時的時間
                          P2=0XFF;
                          P4=P5=0XFF;
               
            }
在什么時候送顯示呢?單片機IO一判斷到 紅外接收管接收到起點信號,就開始顯示,顯示完16列后等待下一次的起點信號。這樣只要電機的速度夠快就會穩定的把字顯示字空中了。平面的文字顯示同理。
如何讓一組文字不斷的移動?這就需要一個字幕計數器,旋轉LED每旋轉一圈,這個字幕計數器就加一,指向下一列,這樣不斷的刷新,感覺文字就在移動了,程序如下:
j就是字幕計數器,每轉一圈j就會加1;
if(KEY==0) //紅外接收管 判斷起始位
        {
            j++;           
if(j>672) //根據顯示的字數定義改數值672/16=42個字 顯示完42個字后 重新開始
            {
                j=0 ;
            }           
for(i=j;i<128+j;i++) //每轉一圈  前進一列  這里定義一圈中同時顯示128/16=8個字,
            {                                                                             P2=zimo[i*2]; //送數據低位顯示
             P4=(zimo[i*2+1]);//送數據高位顯示  這里用了單片機P4 和P5口 是LQFP48腳才有的
             P5=(zimo[i*2+1])>>4;//這里行和列 都是IO口獨立驅動的LED
                DelayUs(200);  //延時讓LED亮起來 每列延時的時間
                         P2=0XFF;
                         P4=P5=0XFF;
               
            }
最后一點是供電的問題,旋轉LED供電問題是比較麻煩的,這里我采用了無線供電方式,經過實踐論證,功率很有限,需要改進的地方還很多,電路原理是把直流轉成交流,然后經過初級線圈 ,最后次級線圈感應得電,經過整流濾波后給旋轉部分供電,直流轉交流部分電路是一個自激震蕩電路。動手能力強的朋友經過改造電機電刷方法實現,如果有條件制作的歡迎用此種方式。





單片機源程序如下:
  1. /*************************************************************
  2.                       旋轉LED綜合功能程序 平面立體一起顯示
  3. 單片機 STC12C5A32S2  
  4. 運用無線供電方法 旋轉起來平靜 (特別說明;旋轉LED轉接塑料需放點紙巾壓進電機軸,這樣旋轉起來摩擦力才夠大,夠穩定。這個對旋轉是否安靜影響很大
  5.      一個就是配重的問題,利用兩個銅柱可以配平衡,長銅柱固定在旋轉方向那頭,即后備電池正極旁邊,短銅柱在另一邊)        結構做的好旋轉是非常靜的,幾乎是一臺風扇!
  6. 字模軟件用的PC2002
  7. 實現效果:1.立體顯示旋轉字 (通過 “暫停按鍵” 進行靜態與移動顯示8-29更新
  8.                   2.平面顯示數字時鐘 年月日 星期+\立體顯示字(時鐘可調 時鐘芯片用DS1302 帶后備電池 掉電時鐘繼續走)
  9.                   3.平面顯示模擬表盤時鐘  (如果表盤不全或者過多顯示 請按配套的遙控器"快進"或者"快退"來調整單列顯示時間 設置后參數保存到DS1302RAM 中 下次啟用無需調整 2012-8-28)
  10.                   4.平面\立體顯示字體模式 通過 “暫停按鍵” 進行靜態與移動顯示8-29更 新   
  11.                   5.立體下拉顯示字+停頓
  12.                   6.兩顆心閃動
  13.                   7.一顆心填滿效果
  14.                   8.笑臉動畫
  15.                   9.打印字效果 (打印一封寫給親愛的信)
  16.                  10.立體顯示時間+顯示文字
  17. 上述10種效果對應遙控器按鍵1、 2、 3、 4、 5、 6、 7、 8、 9 、0 原時鐘復位按鍵 改到按鍵“Meun”

  18. 通過上位機改 立體顯示字        平面顯示字
  19. ***************************************************************/
  20. #include "NEW_8051.H"
  21. #include "task.h"
  22. #include <stddef.h>
  23. #define ucNumRows  224//224 //定義一周顯示字個數 一個字16列 224/16=13個字
  24. #define uclineNumRows  104//定義立體顯示時間中的立體顯示文字

  25. sbit Led1=P3^0;//最里面LED
  26. sbit Led2=P3^1;
  27. sbit Led3=P3^4;

  28. uchar Delay=1 ;
  29. bit BIT_timeout=0;
  30. uint uitime=0;
  31. data uint uiicount=0;
  32. uint uiCountFontNumber=0;
  33. uint uiPrintFontNumber=0;
  34. uchar ucMode=1;
  35. data uint uiicountTwo=0;
  36. uchar BuffCount=0;
  37. uchar ucPCA0_TimeCount;
  38. data uint uiBaseAddress=0;
  39. data uint uiFontNumber=0;
  40. data uint uiFontNumber_P=0;

  41. data uchar ucNumRows_p=160;
  42. uchar DelayTimeCount=0;
  43. bit Stop_move=0;
  44. uchar Mod=0;
  45. uchar Buff[448]=0xFF;
  46. uchar ucLine_count=0;
  47. uchar Row;
  48. uchar k;
  49. bit Error=0;
  50. uchar Stop_time=0;
  51. uchar ucline=0;
  52. bit bDot=0;
  53. uchar code sw[8]={0XFE,0XFC,0XF8,0XF0,0XE0,0XC0,0X80,0X00};
  54. void delay_200ms(void);
  55. uchar code liushui[8]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//流水掃描數據
  56. /***************模擬表盤變量**************/
  57. uint DISP_LINE=0;
  58. uchar DISP_LINE_ADJ=0;
  59. uchar DISP_TIME_ADJ=0;
  60. uchar Time0_count=0;
  61. //====參數初始化
  62. uchar DISP_TIME_SET = 100 ; //單列顯示時間設置值

  63. /********************************************/
  64. /*********延時子程序**********/
  65. void delay(unsigned char n)        //每列顯示的時間
  66. {
  67.         unsigned char a,b,c;
  68.           c=2;//+DelayTimeCount;
  69.         for(;n>0;n--)
  70.         {            
  71.                 for(b=45;b>0;b--)
  72.         for(a=c;a>0;a--);
  73.         }
  74. }
  75. /*********延時子程序**********/
  76. void delay_PIC(unsigned char n)        //每列顯示的時間
  77. {
  78.         unsigned char a,b,c;
  79.           c=2;//+DelayTimeCount;
  80.         for(;n>0;n--)
  81.         {            
  82.                 for(b=38;b>0;b--)
  83.         for(a=c;a>0;a--);
  84.         }
  85. }

  86. /*********PCA中斷子程序**********/
  87. void PCA() interrupt 7        //PCA定時器
  88. {

  89.         if( CCF0 )
  90.         {
  91.                 CCF0 = 0;
  92.                 CL = 0;
  93.             CH = 0;
  94.                 ucPCA0_TimeCount++;
  95.                 if(ucPCA0_TimeCount>12)
  96.                 {
  97.                         ucPCA0_TimeCount=0;        //調時閃爍
  98.                         if(ucMode==2)
  99.                          {
  100.                                  flag=~flag;
  101.                          }
  102.                 }
  103.         }
  104. }
  105. /************************************/
  106. void Timer0Interrupt(void) interrupt 1
  107. {                        
  108.          TF0=0;
  109.                  TR0=0;
  110.           TH0 =(65536- DISP_TIME_SET)/256;
  111.           TL0 =(65536- DISP_TIME_SET)%256;
  112.           TR0=1;
  113.   //if ( ++Time0_count > 250 ) Time0_count = 250 ; //溢出計數器+1,>最大值,=最大值

  114.   if ( ++DISP_LINE > 180 ) DISP_LINE = 0 ; //顯示列計數器+1,>最大值,=0
  115.                 /***********清空顯示************/
  116.                 P1=0XFF ;
  117.             P0=0XFF ;
  118.                 Led1=0;
  119.                 Led2=1;
  120.                 Led3=1;
  121.                 /*************形成表盤*******************/
  122.            switch (DISP_LINE)   
  123.        {
  124.                 case 180*1/12 :    //1點
  125.                 case 180*2/12 :    //2點
  126.                 case 180*4/12 :    //4點
  127.                 case 180*5/12 :    //5點
  128.                 case 180*7/12 :    //6點
  129.                 case 180*8/12 :    //7點
  130.                 case 180*10/12 :   //10點
  131.                 case 180*11/12 :   //11點
  132.                   P1=0x3F;
  133.                  break;
  134.                         case 180*3/12 :    //3點
  135.                 case 180*6/12 :    //6點
  136.                 case 180*9/12 :    //9點
  137.                         case 0:    //12點
  138.                           P1=0x1F;
  139.                           break;
  140.        }
  141.    /****************************************/   
  142.              //顯示指針"時"
  143. //           i = Hour ;
  144. //       j = Hour ;
  145. //      if ( ++i > 179 ) i=0 ;    //i+1,結果>179,則清零
  146. //      if ( --j > 179 ) i=179 ;   //j-1,結果為負,則重新賦值179
  147.         if(( (Hour-3)<=DISP_LINE)&&((Hour+3)>=DISP_LINE) )
  148.         {
  149.                 if(((Hour-2)==DISP_LINE)||((Hour+2)==DISP_LINE))
  150.                 P0=0XFB;
  151.                 else if(((Hour-3)==DISP_LINE)||((Hour+3)==DISP_LINE))
  152.                 P0=0XFD;
  153.                         
  154.         }
  155.            if(Hour==DISP_LINE)//||(DISP_LINE==i)||(DISP_LINE==j
  156.     {
  157.         P1=P1|0X1F ;
  158.         P0=0XF0 ;
  159.                Led1=0;
  160.                 Led2=0;
  161.                 Led3=0;
  162.     }   
  163.     //顯示指針"分"
  164.         if(( (Cent-2)<=DISP_LINE)&&((Cent+2)>=DISP_LINE) )
  165.         {
  166.                 if(((Cent-1)==DISP_LINE)||((Cent+1)==DISP_LINE))
  167.                 P0=0XBF;
  168.                 else if(((Cent-2)==DISP_LINE)||((Cent+2)==DISP_LINE))
  169.                 P0=0XDF;
  170.                         
  171.         }
  172.         if(Cent==DISP_LINE)
  173.     {
  174.         P1=P1|0X1F ;
  175.         P0=0X00 ;
  176.         Led1=0;
  177.                 Led2=0;
  178.                 Led3=0;
  179.                
  180.     }
  181.         //顯示指針"秒"
  182.         if(( (Sec-2)<=DISP_LINE)&&((Sec+2)>=DISP_LINE) )
  183.         {
  184.                 if(((Sec-1)==DISP_LINE)||((Sec+1)==DISP_LINE))
  185.                 P1=P1&0XF7 ;
  186.                 else if(((Sec-2)==DISP_LINE)||((Sec+2)==DISP_LINE))
  187.                 P1=P1&0XFB ;
  188.                         
  189.         }
  190.     if(Sec==DISP_LINE)
  191.     {
  192.         P1=P1&0XE0 ;
  193.         P0=0X00 ;
  194.                Led1=0;
  195.                 Led2=0;
  196.                 Led3=0;
  197.       
  198.     }

  199.         //}
  200. }


  201. /*********中斷子程序**********/
  202. void int0() interrupt 0        //使用外部中斷0
  203. {
  204.         EX0=0;
  205.         BIT_timeout=1;
  206.         if(ucMode==0x03)
  207.         {
  208.                 //調整單列顯示時間設置值(模糊控制)
  209. //           if ( Time0_count > 183 )
  210. //           {
  211. //                        if ( Time0_count > 220 ) DISP_TIME_SET = DISP_TIME_SET + 4 ;
  212. //                        else if ( Time0_count > 200 ) DISP_TIME_SET = DISP_TIME_SET + 3 ;
  213. //                        else if ( Time0_count > 185 ) DISP_TIME_SET = DISP_TIME_SET + 2 ;
  214. //                        else DISP_TIME_SET = DISP_TIME_SET + 1 ;
  215. //                        
  216. //                        if ( DISP_TIME_SET > 2000 ) DISP_TIME_SET = 2000 ;  //鉗位
  217. //               
  218. //                        }
  219. //                        else if ( Time0_count < 180 )
  220. //                        {
  221. //                        if ( Time0_count < 140 ) DISP_TIME_SET = DISP_TIME_SET - 4 ;
  222. //                        else if ( Time0_count < 160 ) DISP_TIME_SET = DISP_TIME_SET - 3 ;
  223. //                        else if ( Time0_count < 175 ) DISP_TIME_SET = DISP_TIME_SET - 2 ;
  224. //                        else DISP_TIME_SET = DISP_TIME_SET - 1 ;
  225. //                                if ( DISP_TIME_SET < 100 ) DISP_TIME_SET = 100 ;  //鉗位
  226. //               
  227. //                        }
  228. //                        
  229.                 //        DISP_TIME_SET=DISP_TIME_SET+DISP_TIME_ADJ;
  230.                 //        Time0_count=0; //溢出計數器 = 0
  231.                         TR0=0;
  232.                         TH0 =(65536- DISP_TIME_SET)/256;
  233.                           TL0 =(65536- DISP_TIME_SET)%256;
  234.                         TR0=1;
  235.                     DISP_LINE =0;// DISP_LINE_ADJ ;   //顯示列計數器(0~179)=校正值
  236.                          du1302();//獲取時間
  237.                         Sec=59-(Sec/16*10+Sec%16) ; //由于電機反轉 所以需要用最大值減去當前值
  238.                 Cent=59-(Cent/16*10+Cent%16) ;
  239.                     Hour=Hour/16*10+Hour%16 ;
  240.                         if(Hour>11)
  241.                         {
  242.                                 Hour=Hour-12;        
  243.                         }
  244.                         Hour=12-Hour;
  245.                         Sec=Sec*3;//秒針定位="秒"*3
  246.                         Hour=(Hour*15)+(Cent/4);//時針定位="時"*15+"分"/4
  247.                         Cent=Cent*3;//分針定位="分"*3        
  248.                         
  249.                 }
  250.                 EX0=1;        
  251. }
  252. /********************************/
  253. void start(void)
  254. {
  255.         P1=0XFF;
  256.         P2=0XFF;
  257.         P0=0XFF;
  258.         P3=0XFF;
  259.         P4=0XFF;
  260.         P5=0XFF;

  261. //        uiFontNumber=(byte_read(0x0100)<<8)+byte_read(0x0101);
  262.         uiFontNumber=((byte_read(0)<<8)+byte_read(1))*16; //讀取EEP立體數據總數
  263.         uiPrintFontNumber=uiFontNumber*2;
  264.         uiFontNumber_P=((byte_read(0x3600)<<8)+byte_read(0x3601))*16; //讀取EEP平面數據總數
  265.         //ucNumRows=R1302(ucNumRows_adder+1)*16;        //讀立體一圈中顯示字總數
  266. //        if(ucNumRows<16)
  267. //        {
  268. //                ucNumRows=224;        
  269. //        }
  270. //        ucNumRows_p=R1302(ucNumRows_p_adder+1)*16;
  271. //        if(ucNumRows_p<16)
  272. //        {
  273. //                ucNumRows_p=96;        
  274. //        }
  275.         //Send_data(uiFontNumber>>8);
  276.         //Send_data(uiFontNumber);
  277.         //Send_data(BCD2DEC(R1302(LINE_ADJ_adder+1)));
  278. //        DISP_LINE_ADJ=BCD2DEC(R1302(LINE_ADJ_adder+1));//讀取列計數器校正值
  279. //        if(DISP_LINE_ADJ>20)//防止值過大
  280. //        {
  281. //                DISP_LINE_ADJ=0;        
  282. //        }
  283.         //write_1302Data(DISP_TIME_adder,160);

  284. //        DISP_LINE = DISP_LINE_ADJ ; //顯示列計數器(0~179)=校正值

  285. //        DISP_TIME_SET=DISP_TIME_SET+ DISP_TIME_ADJ;
  286.         //DISP_LINE = DISP_LINE_ADJ ; //顯示列計數器(0~179)=校正值  
  287.         //uiAllRows=uiAllRows-128;;

  288. }
  289. /***************************************/
  290. void OS_ALLRun(void)
  291. {        
  292.         
  293.         //BIT_timeout=1;
  294.         if(BIT_timeout)//起始點
  295.          {                          
  296.                 BIT_timeout=0;
  297.                 Error=1;

  298.                 if( new_code ) //有紅外按鍵
  299.                 {
  300.                         new_code=0;
  301.                         
  302.                         //Send_data(key_code);
  303.                         switch( key_code ) //根據不同的按鍵值執行不同的動作
  304.                         {
  305.                                 case 0x07:
  306.                                         if(ucMode==3)
  307.                                         {                                                
  308.                                                 if(DISP_TIME_SET<250)
  309.                                                     {
  310.                                                                 DISP_TIME_SET++;                                                
  311.                                                                 write_1302Data(DISP_TIME_adder,DISP_TIME_SET);//寫入DS1302 RAM中保存
  312.                                                         }        
  313.                                         }
  314.                                         else
  315.                                         {
  316.                                                  DelayTimeCount++;//單列延時時間+
  317.                                         }
  318.                                 break;
  319.         
  320.                                 case 0x09://
  321.                                         if(ucMode==3)
  322.                                         {
  323.                                                 if(DISP_TIME_SET>20)
  324.                                                 {
  325.                                                         DISP_TIME_SET--;                                       
  326.                                                         write_1302Data(DISP_TIME_adder,DISP_TIME_SET);//寫入DS1302 RAM中保存               
  327.                                             }
  328.                                         }
  329.                                         else
  330.                                         {
  331.                                                 if(DelayTimeCount>0)//單列延時時間-
  332.                                                 DelayTimeCount--;
  333.                                         }
  334.                                 break;

  335.                            /*********************************/
  336.                                 case 0x0C:
  337.                                         ucMode=0x01;//立體顯示字 移動效果+靜態顯示
  338.                                         CR=0;
  339.                                         TR0=0;
  340.                                         uiCountFontNumber=0;
  341.                                         Led1=1;
  342.                                         Led2=1;
  343.                                         Led3=1;
  344.                                 break;
  345.                                    case 0x1C:
  346.                                         ucMode=0x05;//立體顯示字 下拉效果+靜態顯示
  347.                                         CR=0;
  348.                                         TR0=0;
  349.                                         Led1=1;
  350.                                         Led2=1;
  351.                                         Led3=1;
  352.                                         uiCountFontNumber=0;
  353.                                 break;
  354.                                  case 0x5A:
  355.                                         ucMode=0x06;//立體顯示簡單動畫
  356.                                         CR=0;
  357.                                         TR0=0;
  358.                                         uiCountFontNumber=0;
  359.                                         Led1=1;
  360.                                         Led2=1;
  361.                                         Led3=1;
  362.                                 break;
  363.                                 case 0x42:
  364.                                         ucMode=0x07;//立體顯示心型變化
  365.                                         CR=0;
  366.                                         TR0=0;
  367.                                         uiCountFontNumber=0;
  368.                                         Led1=1;
  369.                                         Led2=1;
  370.                                         Led3=1;
  371.                                 break;
  372.                                 case 0x52:
  373.                                         ucMode=0x08;//笑臉變化
  374.                                         CR=0;
  375.                                         TR0=0;
  376.                                         uiCountFontNumber=0;
  377.                                         Led1=1;
  378.                                         Led2=1;
  379.                                         Led3=1;
  380.                              break;
  381.                                 case 0x4A:                                       
  382.                                         CR=0;
  383.                                         TR0=0;
  384.                                         uiCountFontNumber=0;
  385.                                         ucMode=0x09;//打印字效果
  386.                                         ucLine_count=0;
  387.                                         Led1=1;
  388.                                         Led2=1;
  389.                                         Led3=1;
  390.                              break;
  391.                                 case 0x16:                                       
  392.                                         CR=0;
  393.                                         TR0=0;
  394.                                         uiCountFontNumber=0;
  395.                                         ucMode=0x0A;//立體顯示時間 與文字
  396.                                         Led1=1;
  397.                                         Led2=1;
  398.                                         Led3=1;
  399.                              break;
  400.                                 case 0x18:                                       
  401.                                         TR0=0;
  402.                                         CR=0;
  403.                                         Auto_Set1302(starts_time);
  404.                                         ucMode=0x02;//數字鐘模式
  405.                                         Led1=1;
  406.                                         Led2=1;
  407.                                         Led3=1;
  408.                                 break;

  409.                                 case 0x5E:
  410.                                 
  411.                                          DISP_TIME_SET=R1302(DISP_TIME_adder+1);//讀取單列顯示時間
  412.                                          //Send_data(DISP_TIME_SET);
  413.                                         if((DISP_TIME_SET>250)||(DISP_TIME_SET<20)) //防止值過大        過小
  414.                                         {
  415.                                                 DISP_TIME_SET=115;        
  416.                                         }
  417.                                         ucMode=0x03;//指針時鐘模式
  418.                                         TR0=1;
  419.                                          CR=0;
  420.                                         Led1=0;
  421.                                 break;
  422.                                 case 0x08:
  423.                                         ucMode=0x04;//平面顯示字模式
  424.                                         CR=0;
  425.                                         TR0=0;
  426.                                         uiCountFontNumber=0;
  427.                                         Led1=1;
  428.                                         Led2=1;
  429.                                         Led3=1;
  430.                                 break;
  431.                                 /*********************************/
  432.                                 case 0x40:         //調時加
  433.                                         if(ucMode==0x02)
  434.                                         {
  435.                                                 Set(id,1);
  436.                                                 
  437.                                         }
  438.                                         else if(ucMode==0x03)
  439.                                         {
  440.                                                 if(++DISP_LINE_ADJ>179)        //盤面校正值
  441.                                                 {
  442.                                                         DISP_LINE_ADJ=0;
  443.                                                         
  444.                                                 }
  445.                                                 write_1302Data(LINE_ADJ_adder,DISP_LINE_ADJ);//寫入DS1302 RAM中保存        
  446.                                         }
  447.                                 break;

  448.                                 case 0x19: //調時減
  449.                                         if(ucMode==0x02)
  450.                                         {                                                
  451.                                                 Set(id,0);
  452.                                         }
  453.                                         else if(ucMode==0x03)
  454.                                         {
  455.                                                 if(--DISP_LINE_ADJ==0) //盤面校正值
  456.                                                 {
  457.                                                         DISP_LINE_ADJ=179;
  458.                                                         
  459.                                                 }
  460.                                           write_1302Data(LINE_ADJ_adder,DISP_LINE_ADJ);//寫入DS1302 RAM中保存               
  461.                                         }

  462.                                 break;
  463.                                 
  464.                                 case 0x15://調時切換
  465.                                                 if(ucMode==2)
  466.                                                 {
  467.                                                         id++;                                                
  468.                                                         //CCAPM1 = 0x49; //開PCA0中斷
  469.                                                         //CCAPM0 = 0x00; //關PCA1中斷
  470.                                                         CR=1;//啟動PCA計數
  471.                                                            if(id>4)
  472.                                                         {
  473.                                                             id=0;
  474.                                                                 CR=0;//關閉PCA計數
  475.                                                         //        CCAPM0 = 0x00;//關PCA0中斷
  476.                                                         }
  477.                                                 }
  478.                                                 else if((ucMode==4)||(ucMode==5)||(ucMode==1))
  479.                                                 {
  480.                                                         Stop_move=~Stop_move;               
  481.                                                 }
  482.                                 break;
  483.                                         case 0x47://時鐘初始化
  484.                                                 Set1302(starts_time);    //初始化
  485.                                                 W1302(0x8e,0x00); //控制命令,WP=0,寫操作               
  486.                                                 W1302(0x90,0xa5); //打淶二級? 一個二級管串聯一個2K玷
  487.                                                 //write_1302Data(DISP_TIME_adder,160);
  488.                                 break;

  489.                                 default: break;
  490.                         }
  491.                         key_code=0;
  492.                 }
  493.                 //DelayTime=TimeCount/(ucNumRows+60);        
  494.                 //TimeCount=0;        //延時周期計數清零
  495.                 switch (ucMode)
  496.                 {
  497.                         case 0x01://立體顯示字移動模式
  498.                                 //uiCountFontNumber++;
  499.                                 Led3=1;
  500.                                 P1=0XFF;
  501.                                 P0=0XFF;
  502.                                         if(Stop_move==0) //是否暫停移動
  503.                                         {
  504.                                                 uiCountFontNumber++;        
  505.                                         }                                          
  506.                     if(uiCountFontNumber >uiFontNumber ) //uiFontNumber
  507.                     {
  508.                         
  509.                                         uiCountFontNumber = 0;
  510.                                        
  511.                     }            
  512.                     for( uiicount = uiCountFontNumber;uiicount<ucNumRows+uiCountFontNumber+32;uiicount++)
  513.                     {                                                               
  514.                        
  515.                                         P2=byte_read(2+uiicount*2);//讀取內部EEPROM字幕數據 數據在2地址后 所以要加上2
  516.                                         P4=byte_read(2+uiicount*2+1);
  517.                                         P5=byte_read(2+uiicount*2+1)>>4;
  518.                                         delay(1);
  519.                                         P2=P4=P5=0XFF;
  520.                        if(BIT_timeout)
  521.                                    {
  522.                                             
  523.                                           break;
  524.                                    }
  525.                                 }

  526.                                 break;
  527.                         case 0X0A://立體顯示時間 與文字
  528.                                  du1302();
  529.                                  Show_line_time();//立體顯示時間
  530.                                  delay(48);
  531.                                  uiCountFontNumber++;        
  532.                                 if(uiCountFontNumber >uiFontNumber ) //uiFontNumber
  533.                     {
  534.                         
  535.                                         uiCountFontNumber = 0;
  536.                                        
  537.                     }            
  538.                     for( uiicount = uiCountFontNumber;uiicount<uclineNumRows+uiCountFontNumber;uiicount++)
  539.                     {                                                               
  540.                        
  541.                                         P2=byte_read(2+uiicount*2);//讀取內部EEPROM字幕數據 數據在2地址后 所以要加上2
  542.                                         P4=byte_read(2+uiicount*2+1);
  543.                                         P5=byte_read(2+uiicount*2+1)>>4;
  544.                                         delay(1);
  545.                                         P2=P4=P5=0XFF;
  546.                        if(BIT_timeout)
  547.                                    {
  548.                                             
  549.                                           break;
  550.                                    }
  551.                                 }
  552.                         break;
  553.                         case 0x05://立體顯示字下拉模式
  554.                                 //uiCountFontNumber++;
  555.                                 {
  556.                                 if(uiCountFontNumber >uiFontNumber ) //uiFontNumber
  557.                     {
  558.                         
  559.                                         uiCountFontNumber = 0;
  560.                                        
  561.                     }            
  562.                     for( uiicount = 0;uiicount<ucNumRows;uiicount++)
  563.                     {                                                               
  564.                        
  565.                                         P2=Buff[uiicount*2];//讀取內部EEPROM字幕數據 數據在2地址后 所以要加上2
  566.                                         P4=Buff[uiicount*2+1];
  567.                                         P5=Buff[uiicount*2+1]>>4;
  568.                                         delay(1);
  569.                                         P2=P4=P5=0XFF;
  570.                        if(BIT_timeout)
  571.                                    {
  572.                                             
  573.                                           break;
  574.                                    }
  575.                                 }
  576.                                  
  577.                                 /****************************************/
  578.                             switch (Mod) //根據當前狀態顯示
  579.                                 {
  580.                                         case 0://下拉顯示
  581.                                                 for(k=0;k<=ucNumRows;k++)
  582.                                                 {
  583.                                                         if(Row<8)
  584.                                                         {
  585.                                                                 Buff[k*2]=(byte_read(2+uiCountFontNumber+k*2))|(sw[Row]);
  586.                                                                 Buff[k*2+1]=0xFF;
  587.                                                         }
  588.                                                         else
  589.                                                         {
  590.                                                                 Buff[k*2]=(byte_read(2+uiCountFontNumber+k*2));
  591.                                                                 Buff[k*2+1]=(byte_read(2+uiCountFontNumber+k*2+1))|(sw[Row-8]);                                                        
  592.                                                         }        
  593.                                                 }
  594.                                                 break;
  595.                                         case 1: //靜態顯示
  596.                                         case 2:                                                
  597.                                                 break;
  598.                                         case 3:        //擦除
  599.                                                 for(k=0;k<=ucNumRows;k++)
  600.                                                 {
  601.                                                         if(Row<8)
  602.                                                         {
  603.                                                                 Buff[k*2]=(byte_read(2+uiCountFontNumber+k*2))|(~sw[Row]);
  604.                                                         }
  605.                                                         else
  606.                                                         {
  607.                                                                 Buff[k*2+1]=(byte_read(2+uiCountFontNumber+k*2+1))|(~sw[Row-8]);                                                        
  608.                                                         }        
  609.                                                 }                 
  610.                                         break;
  611.                                         default:
  612.                                                 break;
  613.                                 }
  614.                                 if(++Row>=16)
  615.                                 {
  616.                                         Row=0;
  617.                                         Mod++;
  618.                                         if(Mod>3)
  619.                                         {
  620.                                                 Mod=0;
  621.                                                 if(Stop_move==0) //是否暫停移動
  622.                                                 {
  623.                                                         uiCountFontNumber+=64;        
  624.                                                 }
  625.                                         }
  626.                                        
  627.                                 }
  628.                                 }                                                                           
  629.                                 break;
  630.                                 case 0x06://立體顯示兩顆心動畫
  631.                                          for(k=0;k<4;k++)
  632.                                          {
  633.                                                 for( uiicount = 0;uiicount<32;uiicount++)
  634.                                     {                                                               
  635.                                        
  636.                                                         P2=Buff[uiicount*2];
  637.                                                         P4=Buff[uiicount*2+1];
  638.                                                         P5=Buff[uiicount*2+1]>>4;
  639.                                                         delay(2);
  640.                                                         P2=P4=P5=0XFF;
  641.                                        if(BIT_timeout)
  642.                                                    {
  643.                                                             
  644.                                                           break;
  645.                                                    }
  646.                                                   }
  647.                                            }
  648.                                         for(k=0;k<32;k++)
  649.                                         {
  650.                                        
  651.                                                 Buff[k*2]=flash[uiCountFontNumber+k*2];
  652.                                                 Buff[k*2+1]=flash[uiCountFontNumber+k*2+1];
  653.                                        
  654.                                         }
  655.                                         if(++Row>=8)
  656.                                         {
  657.                                                 Row=0;
  658.                                                 uiCountFontNumber+=64;
  659.                                                 if(uiCountFontNumber>=192)
  660.                                                         {uiCountFontNumber=0;}        
  661.                                                 
  662.                                         }                                       
  663.                                         break;
  664.                                 case 0x07://立體顯示心形動畫
  665.                                          for(k=0;k<4;k++)
  666.                                          {
  667.                                                 for( uiicount = 0;uiicount<32;uiicount++)
  668.                                     {                                                               
  669.                                        
  670.                                                         P2=Buff[uiicount*2];
  671.                                                         P4=Buff[uiicount*2+1];
  672.                                                         P5=Buff[uiicount*2+1]>>4;
  673.                                                         delay(2);
  674.                                                         P2=P4=P5=0XFF;
  675.                                        if(BIT_timeout)
  676.                                                    {
  677.                                                             
  678.                                                           break;
  679.                                                    }
  680.                                                   }
  681.                                            }
  682.                                         for(k=0;k<32;k++)
  683.                                         {
  684.                                        
  685.                                                 Buff[k*2]=xinxing[uiCountFontNumber+k*2];
  686.                                                 Buff[k*2+1]=xinxing[uiCountFontNumber+k*2+1];
  687.                                        
  688.                                         }
  689.                                         if(++Row>=8)
  690.                                         {
  691.                                                 Row=0;
  692.                                                 uiCountFontNumber+=64;
  693.                                                 if(uiCountFontNumber>=576)
  694.                                                         {uiCountFontNumber=0;}        
  695.                                                 
  696.                                         }                                       
  697.                                         break;
  698.                                 case 0x08://立體顯示笑臉動畫
  699.                                          for(k=0;k<4;k++)
  700.                                          {
  701.                                                 for( uiicount = 0;uiicount<32;uiicount++)
  702.                                     {                                                               
  703.                                        
  704.                                                         P2=Buff[uiicount*2];
  705.                                                         P4=Buff[uiicount*2+1];
  706.                                                         P5=Buff[uiicount*2+1]>>4;
  707.                                                         delay(2);
  708.                                                         P2=P4=P5=0XFF;
  709.                                        if(BIT_timeout)
  710.                                                    {
  711.                                                             
  712.                                                           break;
  713.                                                    }
  714.                                                   }
  715.                                            }
  716.                                         for(k=0;k<32;k++)
  717.                                         {
  718.                                        
  719.                                                 Buff[k*2]=xiaolian[uiCountFontNumber+k*2];
  720.                                                 Buff[k*2+1]=xiaolian[uiCountFontNumber+k*2+1];
  721.                                        
  722.                                         }
  723.                                         if(++Row>=15)
  724.                                         {
  725.                                                 Row=0;
  726.                                                 uiCountFontNumber+=64;
  727.                                                 if(uiCountFontNumber>=256)
  728.                                                         {uiCountFontNumber=0;}        
  729.                                                 
  730.                                         }                                       
  731.                                         break;
  732.                                 case 0x09://打印字效果
  733.                                 
  734.                                                 for( uiicount = 0;uiicount<176;uiicount++)
  735.                                     {                                                               
  736.                                        
  737.                                                         P2=Buff[uiicount*2];
  738.                                                         P4=Buff[uiicount*2+1];
  739.                                                         P5=Buff[uiicount*2+1]>>4;
  740.                                                         delay(1);
  741.                                                         P2=P4=P5=0XFF;
  742.                                        if(BIT_timeout)
  743.                                                    {
  744.                                                             
  745.                                                           break;
  746.                                                    }
  747.                                                   }
  748.                                                 
  749.                                                 ucline=0;
  750.                                         for(k=0;k<176;k++)
  751.                                         {
  752.                                        
  753.                                                 if(k<ucLine_count)
  754.                                                 {
  755.                                                         Buff[k*2]=byte_read(2+uiCountFontNumber+k*2);
  756.                                                         Buff[k*2+1]=byte_read(2+uiCountFontNumber+k*2+1);
  757.                                                 }
  758.                                                 else if(k<(ucLine_count+16))
  759.                                                 {
  760.                                                         
  761.                                                         if((bDot==1)&&(ucLine_count==160))
  762.                                                         {
  763.                                                                 Buff[k*2]=0XFF;
  764.                                                                 Buff[k*2+1]=0XFF;        
  765.                                                         }
  766.                                                         else
  767.                                                         {
  768.                                                                 Buff[k*2]=line[ucline++];
  769.                                                                 Buff[k*2+1]=line[ucline++];        
  770.                                                         }
  771.                                                 }
  772.                                                 else
  773.                                                 {
  774.                                                         
  775.                                                         Buff[k*2]=0XFF;
  776.                                                         Buff[k*2+1]=0XFF;        
  777.                                                 }
  778.                                        
  779.                                         }
  780.                                         if(++Row>=10)                                                
  781.                                         {
  782.                                                 Row=0;
  783.                                                 bDot=~bDot;
  784.                                                 if(ucLine_count<160)
  785.                                                 {
  786.                                                         ucLine_count=ucLine_count+16;
  787.                                                 }                                                        
  788.                                                 if(ucLine_count>=160)
  789.                                                         {
  790.                                                                 if(++Stop_time>4)
  791.                                                                 {
  792.                                                                         Stop_time=0;                                                               
  793.                                                                         ucLine_count=0;
  794.                                                                         uiCountFontNumber+=320;
  795.                                                                         if(uiCountFontNumber>=uiPrintFontNumber)
  796.                                                                         {
  797.                                                                                 uiCountFontNumber=0;        
  798.                                                                         }
  799.                                                                 }
  800.                                                         }        
  801.                                                 
  802.                                         }                                                                                
  803.                                         break;
  804.                         case 0x02:        //數字時鐘模式
  805.                                 du1302();
  806.                                 Led1=1;
  807.                                 Led3=1;
  808.                                 if( ++uiCountFontNumber >uiFontNumber ) //uiFontNumber
  809.                     {
  810.                         
  811.                                         uiCountFontNumber = 0;
  812.                                        
  813.                     }
  814.                                  uiicount = uiCountFontNumber;                                 
  815.                                 display();
  816.                                 break;
  817.                         /*********************/
  818.                
  819.                         case 0x04:        //平面顯示字體模式
  820.                                 Led3=1;
  821.                                 if(Stop_move==0)
  822.                                 {
  823.                                         uiCountFontNumber++;
  824.                                 }                                            
  825.                     if( uiCountFontNumber>uiFontNumber_P )
  826.                     {
  827.                         uiCountFontNumber=0 ;
  828.                     }            
  829.                     for(uiicountTwo=uiCountFontNumber;uiicountTwo<ucNumRows_p+uiCountFontNumber;uiicountTwo++)
  830.                     {                              
  831.                         P1=byte_read(0x3602+uiicountTwo*2);
  832.                         P0=byte_read(0x3603+uiicountTwo*2);
  833.                                         P2=byte_read(2+uiicountTwo*4);//讀取內部EEPROM字幕數據 數據在2地址后 所以要加上2
  834.                                         P4=byte_read(3+uiicountTwo*4);
  835.                                         P5=byte_read(3+uiicountTwo*4)>>4;
  836.                                         delay(1);
  837.                                         P2=P4=P5=0XFF;
  838.                                         P2=byte_read(4+uiicountTwo*4);//讀取內部EEPROM字幕數據 數據在2地址后 所以要加上2
  839.                                         P4=byte_read(5+uiicountTwo*4);
  840.                                         P5=byte_read(5+uiicountTwo*4)>>4;                                
  841.                                         delay(1);
  842.                                         P1=0xFF;
  843.                                         P0=0XFF;
  844.                                         P2=P4=P5=0XFF;                                
  845.                        if(BIT_timeout)
  846.                                    {
  847.                                           break;
  848.                                    }
  849.                                 }
  850.                                 break;
  851.                         default:
  852.                                 break;
  853.                 }
  854.                   
  855.         }
  856.         if(Error==0) //上電后如果紅外對管 不正常 (無起點檢測)會以流水燈形式跑起來,流水燈也可檢測LED焊接是否正常
  857.         {
  858.                 for(k=0;k<8;k++)
  859.                         {                                
  860.                                 P0=~liushui[k];
  861.                                 P1=~liushui[k];
  862.                                 P2=~liushui[k];
  863.                                 P3=~liushui[k]|0x0F;
  864.                                 P4=~liushui[k];
  865.                                 P5=~liushui[k];               
  866.                             delay_200ms();

  867.                         }               
  868.         }
  869. }
復制代碼

代碼下載: 基于STC12的pov彩燈程序設計.7z (1.19 MB, 下載次數: 0)

評分

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

查看全部評分

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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
亚洲丁香婷深爱综合| 日韩欧美中文字幕制服| 成人sese在线| 免费欧美日韩国产三级电影| 亚洲免费观看| 精品1区2区3区4区| 国模吧精品视频| 高潮按摩久久久久久av免费| 北条麻妃在线一区二区免费播放| 日韩精选视频| 日本综合字幕| 人人鲁人人莫人人爱精品| av网站大全在线| 国产私拍精品| 欧美日韩在线资源| 国产精品免费播放| 91无套直看片红桃| 国产精久久久久久| 九九免费精品视频| 欧美成人精品一区二区免费看片 | 亚洲欧美综合色| 国产午夜精品福利| 成人av黄色| 亚洲已满18点击进入久久| 日本在线电影一区二区三区| 精品国产一区二区三区小蝌蚪| 亚洲人亚洲人色久| 日韩理论在线| 亚洲精品1区| 日本美女视频一区二区| 国产乱子轮精品视频| 91性感美女视频| 国产精品精品国产色婷婷| 亚洲一区在线看| 欧洲一区二区三区在线| 7777精品伊人久久久大香线蕉经典版下载| 日韩欧美亚洲国产另类| 精品香蕉一区二区三区| 欧美成人精品不卡视频在线观看| 欧美亚洲成人免费| 97在线中文字幕| 亚洲第一在线综合在线| 精品人妻少妇一区二区| 超碰91在线播放| 精品无码在线观看| 黑人一级大毛片| 国产又粗又猛又黄又爽| 成人影院午夜久久影院| www污网站在线观看| 亚洲综合图片| www视频在线观看| 一区二区三区国产好| 欧美日韩一二| 日韩和欧美的一区| 久久久综合激的五月天| 五月婷婷另类国产| 亚洲成av人乱码色午夜| 欧美精品九九久久| 91九色蝌蚪国产| 正在播放一区| 亚洲制服中文字幕| 日本精品在线免费观看| 国产精品人妻一区二区三区| 三级全黄做爰视频| 国产三区在线播放| 性生活视频网站| 三级理论午夜在线观看| 欧美成人精品三级网站| 91欧美大片| 激情综合色丁香一区二区| 中文字幕一区视频| 日韩一区二区三区电影| 国内成人精品视频| 日韩亚洲不卡在线| 日本不卡一区二区在线观看| 国产在线观看免费视频软件| 国产又大又黄又爽| 国产香蕉成人综合精品视频| 一区二区三区不卡在线视频 | 蜜桃专区在线| 亚洲插插视频| 最猛黑人系列在线播放| av在线麻豆| 日韩激情啪啪| 久久97超碰色| 精品国产福利在线| 亚洲深夜福利在线| 国产日韩欧美一二三区| 一二三四中文字幕| 香蕉视频黄色在线观看| 国产又粗又黄又爽的视频| 大肉大捧一进一出好爽| 欧美hdxxx| 91综合久久一区二区| 97精品久久久午夜一区二区三区 | frxxee中国xxx麻豆hd| 丰满少妇一级片| 日本五十路在线| 欧洲成人一区| 免费日韩精品中文字幕视频在线| 综合色中文字幕| 亚洲免费视频网站| 亚洲最大av在线| 污污的网站18| 国产免费一区二区三区四区五区| 色视频免费观看| 日韩精品亚洲人成在线观看| 精品视频免费| aaa欧美日韩| 日韩欧美专区在线| 成人免费视频网址| 中国黄色片免费看| 欧美brazzers| 五月婷婷导航| jizzyou欧美16| 日韩在线一区二区| 在线免费观看日韩欧美| 日韩av手机在线看| 日本成人中文字幕在线| 欧美人一级淫片a免费播放| 99视频免费| 狠狠久久伊人中文字幕| 青椒成人免费视频| 欧美色图免费看| 国产精品入口尤物| 特级丰满少妇一级| 伊人久久中文字幕| 少妇免费视频| 狼人天天伊人久久| 久久久亚洲国产美女国产盗摄| 欧美精品一区视频| 精品国产一区二区三区麻豆小说| 日本道中文字幕| 神马午夜电影一区二区三区在线观看| 欧美高清电影在线| 欧美精品尤物在线观看| 国产精品欧美极品| 久久影院中文字幕| 伊人天天久久大香线蕉av色| 黄色香蕉视频在线观看| 日本免费看黄| 九七影院97影院理论片久久| 国产制服丝袜一区| 精品国产免费久久| 免费看污久久久| 欧美一级特黄高清视频| 青青操视频在线观看| 成人在线视频观看| 99综合视频| 欧洲精品中文字幕| 成人中心免费视频| 最近中文字幕无免费| 久草在线免费资源站| 后进极品白嫩翘臀在线播放| 亚洲成人人体| 日韩欧美一区二区视频在线播放| 中文字幕日韩欧美| 一区不卡字幕| 欧美成人免费看| 国产bdsm| 欧美欧美黄在线二区| 欧美激情一区二区三区全黄| 美日韩精品免费观看视频| 免费欧美一级视频| 午夜免费福利视频| 草莓福利社区在线| 美美哒免费高清在线观看视频一区二区 | 伊人婷婷欧美激情| 国产xxx69麻豆国语对白| 亚洲制服在线观看| 欧美日韩一区二区三区视视频| 欧美18av| 久久香蕉国产线看观看99| 欧美久久久精品| 美女在线视频一区二区| 国产午夜精品理论片在线| 66av99| 精品国产视频| 欧美在线观看一区二区| 免费电影一区| 国产精品免费精品一区| 草碰在线视频| 老色鬼精品视频在线观看播放| 国产亚洲免费的视频看| 黄色片视频在线播放| 一区二区三区免费视频播放器| 伦一区二区三区中文字幕v亚洲| 亚洲国产高清不卡| 91精品免费视频| 欧美日韩在线国产| 色中色在线视频| 日本美女一区二区三区视频| 亚洲免费av网站| 亚洲在线免费观看| 久久网免费视频| 97超碰人人在线| 国产一区二区三区四区在线观看| 欧美疯狂xxxx大交乱88av| 中国xxxx性xxxx产国| 成人午夜剧场免费观看完整版| 这里只有精品在线| 亚洲精品av在线播放| www黄色在线| 91精品国产福利尤物| 奇米狠狠一区二区三区| 91精品国产欧美一区二区| 成人短视频在线观看免费| 神宫寺奈绪一区二区三区| 久久综合给合| 一本到三区不卡视频| 夜夜爽99久久国产综合精品女不卡 | 国产免费的av| 欧美大片免费观看网址| 亚洲激情自拍视频| 欧美精品亚洲| 精品黑人一区二区三区在线观看| 欧美jizz18| 欧美日韩亚洲一区二区三区| 亚洲精品久久区二区三区蜜桃臀| 风流老熟女一区二区三区| 亚洲国产欧美国产第一区| 日韩欧美一区二区三区| 色一情一乱一乱一区91| 777琪琪电影午夜理伦片| 欧美一区 二区| 欧美一区二区三区在| wwwwxxxx日韩| 99re热在线观看| 三级不卡在线观看| 欧美一级在线亚洲天堂| 久久精品无码人妻| 成人影院在线播放| 亚洲精品视频在线观看网站| 亚洲一卡二卡三卡| 欧美图片欧美激情欧美精品| 四虎国产精品免费观看| 尤物yw午夜国产精品视频明星| 精品无码在线视频| 成人精品福利| 国产欧美一区二区精品性| 欧洲在线视频一区| 在线天堂中文www官网| 日韩欧美国产精品综合嫩v| 亚洲深夜福利网站| 少妇人妻好深好紧精品无码| 免费黄色在线| 亚洲伦理在线精品| 国内外成人激情免费视频| 91popny丨九色丨国产| 亚洲精品婷婷| 欧美一区二三区| 日本中文字幕第一页| 精品176极品一区| 5566中文字幕一区二区电影| www.日本久久| 国产高清视频在线| 国产精品不卡一区| 日本福利视频在线观看| 黄色动漫网站| 毛片一区二区三区| 亚洲在线观看视频网站| 人妻无码中文字幕| 天天色天天射综合网| 欧美国产极速在线| 日韩精品在线免费视频| 99久久人爽人人添人人澡| 国产手机视频精品| 亚洲欧洲综合网| 中文字幕影音在线| 欧美精品在欧美一区二区少妇| 国产91在线免费观看| 风间由美一区| 亚洲大片免费看| 一区二区三区视频网| 免费福利在线视频| 一区二区三区四区高清精品免费观看 | 国产人成一区二区三区影院| 91手机视频在线| av电影在线免费观看| 国产成人8x视频一区二区| 欧美日产一区二区三区在线观看| 国产成在线观看免费视频| 久久精品国产99国产| 国产一区二区三区四区hd| 精品卡一卡卡2卡3网站| 日本aⅴ免费视频一区二区三区 | 国产一区在线不卡| 国产自产在线视频一区| 国产porn视频| 国产一区二区免费在线| 欧美视频1区| 国产女人伦码一区二区三区不卡| 国产精品一区二区三区四| 欧美三级午夜理伦三级| 亚洲日韩第九十九页| 日韩国产欧美三级| 好吊妞www.84com只有这里才有精品| 欧美成人精品福利网站| 奇米影视7777精品一区二区| 国模一区二区三区私拍视频| www.xxx.国产| 成人性视频免费网站| 热这里只有精品| 人成在线视频| 亚洲精品国产视频| 99re精彩视频| 日本在线观看高清完整版| 在线电影院国产精品| 欧美激情视频二区| 四虎精品永久免费| 一区二区三区精品| 亚洲三级在线视频| 在线精品亚洲欧美日韩国产| 欧美成人性战久久| 免费人成年激情视频在线观看| 哺乳一区二区三区中文视频| 久久久免费观看视频| 手机在线不卡av| 美女在线一区二区| 日本黄色播放器| 污视频网站在线观看| 亚洲va韩国va欧美va精品| www午夜视频| av大大超碰在线| 亚洲国产精品yw在线观看 | 国产69精品久久| 日韩中文综合网| 国产精品视频在线观看免费 | 国产精品怡红院| 新67194成人永久网站| 美女被啪啪一区二区| 18深夜视频在线观看| 亚洲日本一区二区三区| 日韩av成人网| 国产欧美成人xxx视频| 久久色在线视频| 日本一二三区在线| 自拍视频在线看| 久久五月天综合| 天天躁日日躁狠狠躁喷水| 国产精品一区二区男女羞羞无遮挡| 色综合久久久久无码专区| 亚洲男同gay网站| 亚洲四色影视在线观看| 国产高清精品软件丝瓜软件| 捆绑调教美女网站视频一区| 国产无限制自拍| а√天堂资源官网在线资源| 精品国模在线视频| 美女禁区视频免费观看精选| 99视频超级精品| 国内自拍第二页| 国产精品久一| 国产97免费视| av资源在线看| 色婷婷精品大视频在线蜜桃视频| 久久国产精品二区| 亚洲午夜极品| 国产精品av免费观看| 欧美巨大xxxx做受沙滩| 日韩一区二区久久久| 小说区图片区综合久久亚洲| 国产女主播一区| 亚洲国产欧美视频| 精品国产一区二区三区四区| 欧美亚洲丝袜| 日本韩国在线视频爽| 这里只有精品在线观看| 先锋资源一区| 国产精品女同互慰在线看| 精品人妻中文无码av在线 | 国产精品久久77777| 99re热视频在线| 欧美日韩精品一二三区| 中文天堂在线视频| 国产九色精品成人porny| 日韩精品一区二区视频| 国产高清在线观看免费不卡| 国产精品爽爽爽| 另类图片亚洲色图| 欧洲精品在线观看| 在线观看黄色网| 福利视频网站一区二区三区| 四虎国产精品免费| 国产欧美日韩在线观看视频| 日本一区二区精品| 性爱视频在线播放| 国模精品视频一区二区| jizz在亚洲| 666欧美在线视频| 国产 欧美 自拍| 国产视频不卡一区| 黑人と日本人の交わりビデオ| 欧美精品三级| 久久久999视频| 秋霞影院一区| 蜜桃精品久久久久久久免费影院| 好吊日视频在线观看| 欧美日本在线视频中文字字幕| eeuss影院在线|