[RISC-V MCU 应用开发] 第八十六章、CH32V103应用教程——模拟SPI驱动OLED

[复制链接]
 楼主| RISCVLAR 发表于 2021-3-30 19:16 | 显示全部楼层 |阅读模式
本帖最后由 RISCVLAR 于 2021-3-30 19:16 编辑

CH32V103应用教程——模拟SPI驱动OLED

前面章节有介绍过IIC驱动OLED,使用的为4引脚OLED屏,本章教程主要使用模拟SPI驱动OLED,使用的为7引脚的OLED屏。

1、SPI简介及相关函数介绍
关于SPI,在前面章节已进行过介绍,在此不再赘述。

2、硬件设计
本章教程主要使用模拟SPI驱动OLED屏,所用OLED屏为7引脚0.96寸OLED屏。程序中配置PA0作为D0线,PA1作为D1线,PA2连接RES线,PA3连接DC线,PA4连接CS线,具体连接方式如下:
  • PA0连接OLED屏的D0引脚
  • PA1连接OLED屏的D1引脚
  • PA2连接OLED屏的RES引脚
  • PA3连接OLED屏的DC引脚
  • PA4连接OLED屏的CS引脚

3软件设计
关于模拟SPI的初始化配置以及各状态的配置,与前面模拟IIC驱动OLED屏配置类似,在此不再赘述,具体如下:
spi.h文件
  1. #ifndef __SPI_H
  2. #define __SPI_H

  3. #include "ch32v10x_conf.h"
  4. #include "stdlib.h"

  5. //-----------------OLED端口定义----------------

  6. #define OLED_SCL_Clr() GPIO_ResetBits(GPIOA,GPIO_Pin_0)//SCL
  7. #define OLED_SCL_Set() GPIO_SetBits(GPIOA,GPIO_Pin_0)

  8. #define OLED_SDA_Clr() GPIO_ResetBits(GPIOA,GPIO_Pin_1)//SDA
  9. #define OLED_SDA_Set() GPIO_SetBits(GPIOA,GPIO_Pin_1)

  10. #define OLED_RES_Clr() GPIO_ResetBits(GPIOA,GPIO_Pin_2)//RES
  11. #define OLED_RES_Set() GPIO_SetBits(GPIOA,GPIO_Pin_2)

  12. #define OLED_DC_Clr()  GPIO_ResetBits(GPIOA,GPIO_Pin_3)//DC
  13. #define OLED_DC_Set()  GPIO_SetBits(GPIOA,GPIO_Pin_3)

  14. #define OLED_CS_Clr()  GPIO_ResetBits(GPIOA,GPIO_Pin_4)//CS
  15. #define OLED_CS_Set()  GPIO_SetBits(GPIOA,GPIO_Pin_4)


  16. #define OLED_CMD  0 //写命令
  17. #define OLED_DATA 1 //写数据

  18. void OLED_ClearPoint(u8 x,u8 y);
  19. void OLED_ColorTurn(u8 i);
  20. void OLED_DisplayTurn(u8 i);
  21. void OLED_WR_Byte(u8 dat,u8 mode);
  22. void OLED_DisPlay_On(void);
  23. void OLED_DisPlay_Off(void);
  24. void OLED_Refresh(void);
  25. void OLED_Clear(void);
  26. void OLED_DrawPoint(u8 x,u8 y,u8 t);
  27. void OLED_DrawLine(u8 x1,u8 y1,u8 x2,u8 y2,u8 mode);
  28. void OLED_DrawCircle(u8 x,u8 y,u8 r);
  29. void OLED_ShowChar(u8 x,u8 y,u8 chr,u8 size1,u8 mode);
  30. void OLED_ShowChar6x8(u8 x,u8 y,u8 chr,u8 mode);
  31. void OLED_ShowString(u8 x,u8 y,u8 *chr,u8 size1,u8 mode);
  32. void OLED_ShowNum(u8 x,u8 y,u32 num,u8 len,u8 size1,u8 mode);
  33. void OLED_ShowChinese(u8 x,u8 y,u8 num,u8 size1,u8 mode);
  34. void OLED_ScrollDisplay(u8 num,u8 space,u8 mode);
  35. void OLED_ShowPicture(u8 x,u8 y,u8 sizex,u8 sizey,u8 BMP[],u8 mode);
  36. void OLED_Init(void);

  37. #endif
spi.h文件主要进行OLED端口相关定义和函数声明;
spi.c文件
  1. #include "spi.h"
  2. #include "stdlib.h"
  3. #include "oledfont.h"
  4. #include "debug.h"

  5. u8 OLED_GRAM[144][8];

  6. //反显函数
  7. void OLED_ColorTurn(u8 i)
  8. {
  9.     if(i==0)
  10.         {
  11.             OLED_WR_Byte(0xA6,OLED_CMD);//正常显示
  12.         }
  13.     if(i==1)
  14.         {
  15.             OLED_WR_Byte(0xA7,OLED_CMD);//反色显示
  16.         }
  17. }

  18. //屏幕旋转180度
  19. void OLED_DisplayTurn(u8 i)
  20. {
  21.     if(i==0)
  22.         {
  23.             OLED_WR_Byte(0xC8,OLED_CMD);//正常显示
  24.             OLED_WR_Byte(0xA1,OLED_CMD);
  25.         }
  26.     if(i==1)
  27.         {
  28.             OLED_WR_Byte(0xC0,OLED_CMD);//反转显示
  29.             OLED_WR_Byte(0xA0,OLED_CMD);
  30.         }
  31. }

  32. void OLED_WR_Byte(u8 dat,u8 cmd)
  33. {
  34.     u8 i;
  35.     if(cmd)
  36.       OLED_DC_Set();
  37.     else
  38.       OLED_DC_Clr();
  39.     OLED_CS_Clr();
  40.     for(i=0;i<8;i++)
  41.     {
  42.         OLED_SCL_Clr();
  43.         if(dat&0x80)
  44.            OLED_SDA_Set();
  45.         else
  46.            OLED_SDA_Clr();
  47.         OLED_SCL_Set();
  48.         dat<<=1;
  49.     }
  50.     OLED_CS_Set();
  51.     OLED_DC_Set();
  52. }

  53. //开启OLED显示
  54. void OLED_DisPlay_On(void)
  55. {
  56.     OLED_WR_Byte(0x8D,OLED_CMD);//电荷泵使能
  57.     OLED_WR_Byte(0x14,OLED_CMD);//开启电荷泵
  58.     OLED_WR_Byte(0xAF,OLED_CMD);//点亮屏幕
  59. }

  60. //关闭OLED显示
  61. void OLED_DisPlay_Off(void)
  62. {
  63.     OLED_WR_Byte(0x8D,OLED_CMD);//电荷泵使能
  64.     OLED_WR_Byte(0x10,OLED_CMD);//关闭电荷泵
  65.     OLED_WR_Byte(0xAE,OLED_CMD);//关闭屏幕
  66. }

  67. //更新显存到OLED
  68. void OLED_Refresh(void)
  69. {
  70.     u8 i,n;
  71.     for(i=0;i<8;i++)
  72.     {
  73.        OLED_WR_Byte(0xb0+i,OLED_CMD); //设置行起始地址
  74.        OLED_WR_Byte(0x00,OLED_CMD);   //设置低列起始地址
  75.        OLED_WR_Byte(0x10,OLED_CMD);   //设置高列起始地址
  76.        for(n=0;n<128;n++)
  77.        OLED_WR_Byte(OLED_GRAM[n][i],OLED_DATA);
  78.     }
  79. }
  80. //清屏函数
  81. void OLED_Clear(void)
  82. {
  83.     u8 i,n;
  84.     for(i=0;i<8;i++)
  85.     {
  86.        for(n=0;n<128;n++)
  87.             {
  88.              OLED_GRAM[n][i]=0;//清除所有数据
  89.             }
  90.     }
  91.     OLED_Refresh();//更新显示
  92. }

  93. //画点
  94. //x:0~127
  95. //y:0~63
  96. //t:1 填充 0,清空
  97. void OLED_DrawPoint(u8 x,u8 y,u8 t)
  98. {
  99.     u8 i,m,n;
  100.     i=y/8;
  101.     m=y%8;
  102.     n=1<<m;
  103.     if(t){OLED_GRAM[x][i]|=n;}
  104.     else
  105.     {
  106.         OLED_GRAM[x][i]=~OLED_GRAM[x][i];
  107.         OLED_GRAM[x][i]|=n;
  108.         OLED_GRAM[x][i]=~OLED_GRAM[x][i];
  109.     }
  110. }

  111. //画线
  112. //x1,y1:起点坐标
  113. //x2,y2:结束坐标
  114. void OLED_DrawLine(u8 x1,u8 y1,u8 x2,u8 y2,u8 mode)
  115. {
  116.     u16 t;
  117.     int xerr=0,yerr=0,delta_x,delta_y,distance;
  118.     int incx,incy,uRow,uCol;
  119.     delta_x=x2-x1; //计算坐标增量
  120.     delta_y=y2-y1;
  121.     uRow=x1;//画线起点坐标
  122.     uCol=y1;
  123.     if(delta_x>0)incx=1; //设置单步方向
  124.     else if (delta_x==0)incx=0;//垂直线
  125.     else {incx=-1;delta_x=-delta_x;}
  126.     if(delta_y>0)incy=1;
  127.     else if (delta_y==0)incy=0;//水平线
  128.     else {incy=-1;delta_y=-delta_x;}
  129.     if(delta_x>delta_y)distance=delta_x; //选取基本增量坐标轴
  130.     else distance=delta_y;
  131.     for(t=0;t<distance+1;t++)
  132.     {
  133.         OLED_DrawPoint(uRow,uCol,mode);//画点
  134.         xerr+=delta_x;
  135.         yerr+=delta_y;
  136.         if(xerr>distance)
  137.         {
  138.             xerr-=distance;
  139.             uRow+=incx;
  140.         }
  141.         if(yerr>distance)
  142.         {
  143.             yerr-=distance;
  144.             uCol+=incy;
  145.         }
  146.     }
  147. }
  148. //x,y:圆心坐标
  149. //r:圆的半径
  150. void OLED_DrawCircle(u8 x,u8 y,u8 r)
  151. {
  152.     int a, b,num;
  153.     a = 0;
  154.     b = r;
  155.     while(2 * b * b >= r * r)
  156.     {
  157.         OLED_DrawPoint(x + a, y - b,1);
  158.         OLED_DrawPoint(x - a, y - b,1);
  159.         OLED_DrawPoint(x - a, y + b,1);
  160.         OLED_DrawPoint(x + a, y + b,1);

  161.         OLED_DrawPoint(x + b, y + a,1);
  162.         OLED_DrawPoint(x + b, y - a,1);
  163.         OLED_DrawPoint(x - b, y - a,1);
  164.         OLED_DrawPoint(x - b, y + a,1);

  165.         a++;
  166.         num = (a * a + b * b) - r*r;//计算画的点离圆心的距离
  167.         if(num > 0)
  168.         {
  169.             b--;
  170.             a--;
  171.         }
  172.     }
  173. }



  174. //在指定位置显示一个字符,包括部分字符
  175. //x:0~127
  176. //y:0~63
  177. //size1:选择字体 6x8/6x12/8x16/12x24
  178. //mode:0,反色显示;1,正常显示
  179. void OLED_ShowChar(u8 x,u8 y,u8 chr,u8 size1,u8 mode)
  180. {
  181.     u8 i,m,temp,size2,chr1;
  182.     u8 x0=x,y0=y;
  183.     if(size1==8)size2=6;
  184.     else size2=(size1/8+((size1%8)?1:0))*(size1/2);  //得到字体一个字符对应点阵集所占的字节数
  185.     chr1=chr-' ';  //计算偏移后的值
  186.     for(i=0;i<size2;i++)
  187.     {
  188.         if(size1==8)
  189.             {temp=asc2_0806[chr1][i];} //调用0806字体
  190.         else if(size1==12)
  191.             {temp=asc2_1206[chr1][i];} //调用1206字体
  192.         else if(size1==16)
  193.             {temp=asc2_1608[chr1][i];} //调用1608字体
  194.         else if(size1==24)
  195.             {temp=asc2_2412[chr1][i];} //调用2412字体
  196.         else return;
  197.         for(m=0;m<8;m++)
  198.         {
  199.             if(temp&0x01)OLED_DrawPoint(x,y,mode);
  200.             else OLED_DrawPoint(x,y,!mode);
  201.             temp>>=1;
  202.             y++;
  203.         }
  204.         x++;
  205.         if((size1!=8)&&((x-x0)==size1/2))
  206.         {x=x0;y0=y0+8;}
  207.         y=y0;
  208.   }
  209. }


  210. //显示字符串
  211. //x,y:起点坐标
  212. //size1:字体大小
  213. //*chr:字符串起始地址
  214. //mode:0,反色显示;1,正常显示
  215. void OLED_ShowString(u8 x,u8 y,u8 *chr,u8 size1,u8 mode)
  216. {
  217.     while((*chr>=' ')&&(*chr<='~'))//判断是不是非法字符!
  218.     {
  219.         OLED_ShowChar(x,y,*chr,size1,mode);
  220.         if(size1==8)x+=6;
  221.         else x+=size1/2;
  222.         chr++;
  223.   }
  224. }

  225. //m^n
  226. u32 OLED_Pow(u8 m,u8 n)
  227. {
  228.     u32 result=1;
  229.     while(n--)
  230.     {
  231.       result*=m;
  232.     }
  233.     return result;
  234. }

  235. //显示数字
  236. //x,y :起点坐标
  237. //num :要显示的数字
  238. //len :数字的位数
  239. //size:字体大小
  240. //mode:0,反色显示;1,正常显示
  241. void OLED_ShowNum(u8 x,u8 y,u32 num,u8 len,u8 size1,u8 mode)
  242. {
  243.     u8 t,temp,m=0;
  244.     if(size1==8)m=2;
  245.     for(t=0;t<len;t++)
  246.     {
  247.         temp=(num/OLED_Pow(10,len-t-1))%10;
  248.         if(temp==0)
  249.         {
  250.             OLED_ShowChar(x+(size1/2+m)*t,y,'0',size1,mode);
  251.         }
  252.         else
  253.         {
  254.           OLED_ShowChar(x+(size1/2+m)*t,y,temp+'0',size1,mode);
  255.         }
  256.   }
  257. }

  258. //显示汉字
  259. //x,y:起点坐标
  260. //num:汉字对应的序号
  261. //mode:0,反色显示;1,正常显示
  262. void OLED_ShowChinese(u8 x,u8 y,u8 num,u8 size1,u8 mode)
  263. {
  264.     u8 m,temp;
  265.     u8 x0=x,y0=y;
  266.     u16 i,size3=(size1/8+((size1%8)?1:0))*size1;  //得到字体一个字符对应点阵集所占的字节数
  267.     for(i=0;i<size3;i++)
  268.     {
  269.         if(size1==16)
  270.                 {temp=Hzk1[num][i];}//调用16*16字体
  271.         else if(size1==24)
  272.                 {temp=Hzk2[num][i];}//调用24*24字体
  273.         else if(size1==32)
  274.                 {temp=Hzk3[num][i];}//调用32*32字体
  275.         else if(size1==64)
  276.                 {temp=Hzk4[num][i];}//调用64*64字体
  277.         else return;
  278.         for(m=0;m<8;m++)
  279.         {
  280.             if(temp&0x01)OLED_DrawPoint(x,y,mode);
  281.             else OLED_DrawPoint(x,y,!mode);
  282.             temp>>=1;
  283.             y++;
  284.         }
  285.         x++;
  286.         if((x-x0)==size1)
  287.             {
  288.                 x=x0;
  289.                 y0=y0+8;
  290.             }
  291.         y=y0;
  292.     }
  293. }

  294. //num 显示汉字的个数
  295. //space 每一遍显示的间隔
  296. //mode:0,反色显示;1,正常显示
  297. void OLED_ScrollDisplay(u8 num,u8 space,u8 mode)
  298. {
  299.     u8 i,n,t=0,m=0,r;
  300.     while(1)
  301.     {
  302.         if(m==0)
  303.         {
  304.             OLED_ShowChinese(128,24,t,16,mode); //写入一个汉字保存在OLED_GRAM[][]数组中
  305.             t++;
  306.         }
  307.         if(t==num)
  308.         {
  309.             for(r=0;r<16*space;r++)      //显示间隔
  310.              {
  311.                 for(i=1;i<144;i++)
  312.                     {
  313.                         for(n=0;n<8;n++)
  314.                         {
  315.                             OLED_GRAM[i-1][n]=OLED_GRAM[i][n];
  316.                         }
  317.                     }
  318.                 OLED_Refresh();
  319.              }
  320.             t=0;
  321.         }
  322.         m++;
  323.         if(m==16){m=0;}
  324.         for(i=1;i<144;i++)   //实现左移
  325.         {
  326.             for(n=0;n<8;n++)
  327.             {
  328.                 OLED_GRAM[i-1][n]=OLED_GRAM[i][n];
  329.             }
  330.         }
  331.         OLED_Refresh();
  332.     }
  333. }

  334. //x,y:起点坐标
  335. //sizex,sizey,图片长宽
  336. //BMP[]:要写入的图片数组
  337. //mode:0,反色显示;1,正常显示
  338. void OLED_ShowPicture(u8 x,u8 y,u8 sizex,u8 sizey,u8 BMP[],u8 mode)
  339. {
  340.     u16 j=0;
  341.     u8 i,n,temp,m;
  342.     u8 x0=x,y0=y;
  343.     sizey=sizey/8+((sizey%8)?1:0);
  344.     for(n=0;n<sizey;n++)
  345.     {
  346.          for(i=0;i<sizex;i++)
  347.          {
  348.                 temp=BMP[j];
  349.                 j++;
  350.                 for(m=0;m<8;m++)
  351.                 {
  352.                     if(temp&0x01)OLED_DrawPoint(x,y,mode);
  353.                     else OLED_DrawPoint(x,y,!mode);
  354.                     temp>>=1;
  355.                     y++;
  356.                 }
  357.                 x++;
  358.                 if((x-x0)==sizex)
  359.                 {
  360.                     x=x0;
  361.                     y0=y0+8;
  362.                 }
  363.                 y=y0;
  364.      }
  365.      }
  366. }
  367. //OLED的初始化
  368. void OLED_Init(void)
  369. {
  370.     GPIO_InitTypeDef  GPIO_InitStructure;
  371.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_AFIO, ENABLE);    //使能A端口时钟
  372.     GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable, ENABLE);
  373.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_15;
  374.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;         //推挽输出
  375.     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;//速度50MHz
  376.     GPIO_Init(GPIOA, &GPIO_InitStructure);    //初始化GPIOA
  377.     GPIO_SetBits(GPIOA,GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_15);

  378.     OLED_RES_Clr();
  379.     Delay_Ms(200);
  380.     OLED_RES_Set();

  381.     OLED_WR_Byte(0xAE,OLED_CMD);//--turn off oled panel
  382.     OLED_WR_Byte(0x00,OLED_CMD);//---set low column address
  383.     OLED_WR_Byte(0x10,OLED_CMD);//---set high column address
  384.     OLED_WR_Byte(0x40,OLED_CMD);//--set start line address  Set Mapping RAM Display Start Line (0x00~0x3F)
  385.     OLED_WR_Byte(0x81,OLED_CMD);//--set contrast control register
  386.     OLED_WR_Byte(0xCF,OLED_CMD);// Set SEG Output Current Brightness
  387.     OLED_WR_Byte(0xA1,OLED_CMD);//--Set SEG/Column Mapping     0xa0左右反置 0xa1正常
  388.     OLED_WR_Byte(0xC8,OLED_CMD);//Set COM/Row Scan Direction   0xc0上下反置 0xc8正常
  389.     OLED_WR_Byte(0xA6,OLED_CMD);//--set normal display
  390.     OLED_WR_Byte(0xA8,OLED_CMD);//--set multiplex ratio(1 to 64)
  391.     OLED_WR_Byte(0x3f,OLED_CMD);//--1/64 duty
  392.     OLED_WR_Byte(0xD3,OLED_CMD);//-set display offset   Shift Mapping RAM Counter (0x00~0x3F)
  393.     OLED_WR_Byte(0x00,OLED_CMD);//-not offset
  394.     OLED_WR_Byte(0xd5,OLED_CMD);//--set display clock divide ratio/oscillator frequency
  395.     OLED_WR_Byte(0x80,OLED_CMD);//--set divide ratio, Set Clock as 100 Frames/Sec
  396.     OLED_WR_Byte(0xD9,OLED_CMD);//--set pre-charge period
  397.     OLED_WR_Byte(0xF1,OLED_CMD);//Set Pre-Charge as 15 Clocks & Discharge as 1 Clock
  398.     OLED_WR_Byte(0xDA,OLED_CMD);//--set com pins hardware configuration
  399.     OLED_WR_Byte(0x12,OLED_CMD);
  400.     OLED_WR_Byte(0xDB,OLED_CMD);//--set vcomh
  401.     OLED_WR_Byte(0x40,OLED_CMD);//Set VCOM Deselect Level
  402.     OLED_WR_Byte(0x20,OLED_CMD);//-Set Page Addressing Mode (0x00/0x01/0x02)
  403.     OLED_WR_Byte(0x02,OLED_CMD);//
  404.     OLED_WR_Byte(0x8D,OLED_CMD);//--set Charge Pump enable/disable
  405.     OLED_WR_Byte(0x14,OLED_CMD);//--set(0x10) disable
  406.     OLED_WR_Byte(0xA4,OLED_CMD);// Disable Entire Display On (0xa4/0xa5)
  407.     OLED_WR_Byte(0xA6,OLED_CMD);// Disable Inverse Display On (0xa6/a7)
  408.     OLED_Clear();
  409.     OLED_WR_Byte(0xAF,OLED_CMD);
  410. }
sp.c文件主要进行OLED显示相关函数的配置。关于函数的具体功能请查看程序中函数具体注释,在此不再一一介绍。
main.c文件
  1. /********************************** (C) COPYRIGHT *******************************
  2. * File Name          : main.c
  3. * Author             : WCH
  4. * Version            : V1.0.0
  5. * Date               : 2020/04/30
  6. * Description        : Main program body.
  7. *******************************************************************************/

  8. #include "debug.h"
  9. #include "spi.h"
  10. #include "bmp.h"

  11. /*******************************************************************************
  12. * Function Name  : main
  13. * Description    : Main program.
  14. * Input          : None
  15. * Return         : None
  16. *******************************************************************************/
  17. int main(void)
  18. {
  19.     u8 t=' ';
  20.     Delay_Init();
  21.     OLED_Init();
  22.     OLED_ColorTurn(0);  //0正常显示,1 反色显示
  23.     OLED_DisplayTurn(0);//0正常显示 1 屏幕翻转显示
  24.     while(1)
  25.     {
  26.         OLED_ShowPicture(0,0,128,64,BMP1,1);
  27.         OLED_Refresh();
  28.         Delay_Ms(5000);
  29.         OLED_Clear();
  30.         OLED_ShowChinese(0,0,0,16,1); //沁
  31.         OLED_ShowChinese(18,0,1,16,1);//恒
  32.         OLED_ShowChinese(36,0,2,16,1);//微
  33.         OLED_ShowChinese(54,0,3,16,1);//电
  34.         OLED_ShowChinese(72,0,4,16,1);//子
  35.         OLED_ShowString(8,16,"SPI Drive OLED",16,1);
  36.         OLED_ShowString(20,32,"2021/03/23",16,1);
  37.         OLED_ShowString(0,48,"ASCII:",16,1);
  38.         OLED_ShowString(63,48,"CODE:",16,1);
  39.         OLED_ShowChar(48,48,t,16,1);//显示ASCII字符
  40.         t++;
  41.         if(t>'~')t=' ';
  42.         OLED_ShowNum(103,48,t,3,16,1);
  43.         OLED_Refresh();
  44.         Delay_Ms(500);
  45.         OLED_ScrollDisplay(5,4,1);
  46.     }
  47. }
main.c文件主要进行OLED屏显示操作,显示图片、汉字等信息。

4下载验证
将编译好的程序下载到开发版并复位,OLED显示如下:
图片1.png

85、模拟SPI驱动OLED.rar

491.18 KB, 下载次数: 231

您需要登录后才可以回帖 登录 | 注册

本版积分规则

133

主题

296

帖子

44

粉丝
快速回复 在线客服 返回列表 返回顶部

133

主题

296

帖子

44

粉丝
快速回复 在线客服 返回列表 返回顶部