有人用过TLV5638这块DA吗我编好程了他就是不工作!

有人用过TLV5638这块DA吗我编好程了他就是不工作!,第1张

恩挺好用的这个芯片

#include<reg52h>

#include<intrinsH>

#include<stringh>

#define uint unsigned int

unsigned char code table_sin[256]=

{0x7f,0x82,0x85,0x88,0x8b,0x8f,0x92,0x95,0x98,0x9b,0x9e,0xa1,

0xa4,0xa7,0xaa,0xad,0xb0,0xb3,0xb6,0xb8,0xbb,0xbe,0xc1,0xc3,0xc6,0xc8,

0xcb,0xcd,0xd0,0xd2,0xd5,0xd7,0xd9,0xdb,0xdd,0xe0,0xe2,0xe4,0xe5,0xe7,

0xe9,0xeb,0xec,0xee,0xef,0xf1,0xf2,0xf4,0xf5,0xf6,0xf7,0xf8,0xf9,0xfa,

0xfb,0xfb,0xfc,0xfd,0xfd,0xfe,0xfe,0xfe,0xfe,0xfe,0xff,0xfe,0xfe,0xfe,

0xfe,0xfe,0xfd,0xfd,0xfc,0xfb,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,0xf4,

0xf2,0xf1,0xef,0xee,0xec,0xeb,0xe9,0xe7,0xe5,0xe4,0xe2,0xe0,0xdd,0xdb,

0xd9,0xd7,0xd5,0xd2,0xd0,0xcd,0xcb,0xc8,0xc6,0xc3,0xc1,0xbe,0xbb,0xb8,

0xb6,0xb3,0xb0,0xad,0xaa,0xa7,0xa4,0xa1,0x9e,0x9b,0x98,0x95,0x92,0x8f,

0x8b,0x88,0x85,0x82,0x7f,0x7c,0x79,0x76,0x73,0x6f,0x6c,0x69,0x66,0x63,

0x60,0x5d,0x5a,0x57,0x54,0x51,0x4e,0x4b,0x48,0x46,0x43,0x40,0x3d,0x3b,

0x38,0x36,0x33,0x31,0x2e,0x2c,0x29,0x27,0x25,0x23,0x21,0x1e,0x1c,0x1a,

0x19,0x17,0x15,0x13,0x12,0x10,0xf,0xd,0xc,0xa,0x9,0x8,0x7,0x6,0x5,0x4,

0x3,0x3,0x2,0x1,0x1,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x1,0x1,

0x2,0x3,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xa,0xc,0xd,0xf,0x10,0x12,0x13,0x15,

0x17,0x19,0x1a,0x1c,0x1e,0x21,0x23,0x25,0x27,0x29,0x2c,0x2e,0x31,0x33,0x36,

0x38,0x3b,0x3d,0x40,0x43,0x46,0x48,0x4b,0x4e,0x51,0x54,0x57,0x5a,0x5d,0x60,

0x63,0x66,0x69,0x6c,0x6f,0x73,0x76,0x79,0x7c};

#define uchar unsigned char

//速度模式参数

#define FASTSP 1 //快速模式

#define SLOESP 0 //慢速模式

//电源模式参数

#define PWR_DOWN 1 //掉电模式

#define PWR_ON 0 //正常模式

//寄存器选择参数

#define DACB_BUFFER 0 //写DACB和BUFFER

#define BUFFER 1 //写BUFFER

#define DACA_BUFFERTOB 2 //写DACA和BUFFER的值更新DACB

#define CONTROL 3 //写控制寄存器

//参考源选择参数

#define EXTERNAL 0 //外部参考源

#define IN_1024 1 //内部1024V参考源

#define IN_2048 2 //内部2048V参考源

//引脚定义

sbit PinDIN=P1^0;

sbit PinSCLK=P1^1;

sbit CS=P1^2;

//函数功能:短延时

void nNOP(uchar x);

//函数功能:长延时

void LongDelay(uint i);

//函数功能:置/复位CS信号

//说明:x=1-置位,x=0-复位

//函数功能:置/复位SCLK信号

//说明:x=1-置位,x=0-复位

#define SetSCLK(x) (PinSCLK=(x)1:0)

//函数功能:向SPI写16位数据

//说明:temp为16位的数据

void SPIWrite(int temp);

//函数功能:将电压值转换为对应的12位数字量

//说明:ref为参考源,ex_ref为当选择外部参考源的电压值,

// out_volt为输出模拟电压值

// 返回12数字量

int VoltToData(uint ref,float ex_ref,float out_volt);

//函数功能:设置DAC A(即A通道)输出

//说明:speed为速度模式,ref为参考源选择,temp为需要输出的电压

// ex_ref为当选择外部参考源的电压值

void SetDAC_A(uint speed,uint ref,float ex_ref,float temp);

//函数功能:设置DAC B(即B通道)输出

//说明:speed为速度模式,ref为参考源选择,temp为需要输出的电压

// ex_ref为当选择外部参考源的电压值

void SetDAC_B(uint speed,uint ref,float ex_ref,float temp);

//函数功能:设置DAC A与DAC B同时输出

//说明:speed为速度模式,ref为参考源选择,

// temp1为A通道需要输出的电压,temp2为B通道需要输出的电压

// ex_ref为当选择外部参考源的电压值

void SetDAC_AB(uint speed,uint ref,float ex_ref,float temp1,float temp2);

//短延时函数:nNop( )

void nNop(uchar i)

{

for(;i>0;i--);

}

//长延时函数:LongDelay( )

void LongDelay(uint i)

{ uint j;

for(;i>0;i--)

{ for(j=1000;j>0;j--);

}

}

//向SPI写16位数据函数:SPIWrite( )

void SPIWrite(int temp)

{ uint i;

CS=0;

for(i=0;i<16;i++)

{ PinDIN=(bit)(temp&0x8000);

SetSCLK(1);

temp<<=1;

nNop(1);

SetSCLK(0);

nNop(1);

}

CS=1;

}

//将电压值转换为对应的12位数字量函数:VoltToData( )

int VoltToData(uint ref,float ex_ref,float out_volt)

{ int temp;

switch(ref)

{ case EXTERNAL:temp=(int)((out_volt4096)/(2ex_ref));

break;

//case IN_1024:temp=(int)((out_volt4096)/(21024));

break;

case IN_2048:temp=(int)((out_volt4096)/(22048));

//case IN_2048:temp=out_volt;

break;

default:break;

}

return(temp&0xfff);

}

//设置DAC A(即A通道)输出函数:SetDAC_A( )

void SetDAC_A(uint speed,uint ref,float ex_ref,float temp)

{ int ModCMD;

int Data;

ModCMD=0x9000|(speed<<14)|(ref);

Data=VoltToData(ref,ex_ref,temp);

Data=Data|0x8000|(speed<<14);

SPIWrite(ModCMD);

nNop(10);

SPIWrite(Data);

}

//设置DAC B(即B通道)输出函数:SetDAC_B( )

void SetDAC_B(uint speed,uint ref,float ex_ref,float temp)

{ int ModCMD;

int Data;

ModCMD=0x9000|(speed<<14)|(ref);

Data=VoltToData(ref,ex_ref,temp);

Data=Data|0x0000|(speed<<14);

SPIWrite(ModCMD);

nNop(10);

SPIWrite(Data);

}

//设置DAC A与DAC B同时输出函数SetDAC_AB( )

void SetDAC_AB(uint speed,uint ref,float ex_ref,float temp1,float temp2)

{ int ModCMD;

int DataA,DataB;

ModCMD=0x9000|(speed<<14)|(ref);

DataA=VoltToData(ref,ex_ref,temp1);

DataA=DataA|0x8000|(speed<<14);

DataB=VoltToData(ref,ex_ref,temp2);

DataB=DataB|0x1000|(speed<<14);

SPIWrite(ModCMD);

SPIWrite(DataB);

SPIWrite(DataA);

}

void InitIO( )

{ PinDIN=0;

CS=0;

PinSCLK=0;

}

void main()

{

float i;

InitIO();

while(1)

{ //SetDAC_A(FASTSP,IN_1024,0,10);

//SetDAC_B(FASTSP,IN_1024,0,10);

SetDAC_AB(SLOESP,IN_2048,0,1,2);

}

}

这个是从网上找的 改改就能用想输出几伏电压改改SetDAC_AB(SLOESP,IN_2048,0,1,2);

最后2个数字就可以这个是让AB同时输出的。接的时候不要让REF接东西就行了不然就成外部参考了

几乎所有的需要在卡片和终端之间传送的数据都是TLV格式的

我给你举个例子方便快速理解:

TLV 是 tag , length 和 value 的缩写一个基本的数据元就包括上面三个域 Tag 唯一标识该数据元, length 是 value 域的长度 Value就是数据本身了 举个例子, 下面是一个tlv格式的AID(应用标识符)字节串” 9F0607A0000000031010 ”, 其中 9F06 是tag, 07 是长度, A0000000031010 就是AID本身的值了

对于程序编写人员来说,如果有类似上面这样的一串TLV编码的字节串从卡片传过来, 怎么样从中提取我们想要的数据 这就牵扯出TLV解码的问题了

TLV一种可变格式,TLV的意思就是:Type类型, Lenght长度,Value值;

Type和Length的长度固定,一般那是2、4个字节;

Value的长度有Length指定;

解析方法:

1读取type 转换为ntohl、ntohs转换为主机字节序得到类型;指针偏移+2或4

2读取lenght,转换为ntohl、ntohs转换为主机字节序得到长度;指针偏移+2或4

3根据得到的长度读取value,指针偏移+Length;

TLV编码就是指先对Tag编码,再对Length编码,最后对Value编码。

//09/10/24

//lcd1602显示时间 日期 星期 温度

//通过按键校时:K10--小时,K11--分钟,K12--秒(归零),K13-星期,BR1--年,RB2--月,RB3--日。

//芯片要求:PIC16F877A

#include<pich> //包含单片机内部资源预定义

__CONFIG(0x1832);

//芯片配置字,看门狗关,上电延时开,掉电检测关,低压编程关,加密,4M晶体HS振荡

#define i_o RB4 //定义DS1302的数据口

#define sclk RB0 //定义DS1302的时钟口

#define rst RB5 //定义DS1302的复位口

#define rs RA1 //1602

#define rw RA2

#define e RA3

# define DQ RA0 //定义18B20数据端口

unsigned char TLV=0 ; //采集到的温度高8位

unsigned char THV=0; //采集到的温度低8位

unsigned char bai;

unsigned char shi; //整数十位

unsigned char ge; //整数个位

unsigned char shifen; //十分位

float temp;

void display();

//定义读取时间和日期存放表格

char table1[7];

//定义0-9的显示代码

const char table2[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};

unsigned char rx_data,read_data,count,sec,min,hour,day,mon,week,year,time;

//----------------------------------------------

//ds18b20部分

//------------------------------------------------

//延时函数

void delay1(unsigned int x)

{

unsigned int i;

for(i=x;i>0;i--);

}

//------------------------------------------------

//延时函数

void delay2(char x,char y)

{

char z;

do{

z=y;

do{;}while(--z);

}while(--x);

}

//其指令时间为:7+(3(Y-1)+7)(X-1)如果再加上函数调用的call 指令、页面设定、传递参数花掉的7 个指令。

//则是:14+(3(Y-1)+7)(X-1)。

//

//初始化ds18b20

void ds18b20_init()

{

char presence=1;

while(presence)

{

TRISA0=0; //主机拉至低电平

DQ=0;

delay2(2,99); //延时503us

TRISA0=1; //释放总线等电阻拉高总线,并保持15~60us

delay2(2,8); //延时70us

if(DQ==1) presence=1; //没有接收到应答信号,继续复位

else presence=0; //接收到应答信号

delay2(2,60); //延时430us

}

}

//

//写ds18b20

void ds18b20_write_byte(unsigned char code)

{

unsigned char i,k;

for(i=8;i>0;i--)

{

k=code&0x01;

TRISA0=0;

DQ=0; //数据线拉低产生时间片

asm("nop");

asm("nop");

if(k) DQ=1; //写1则拉高数据电平

delay1(3); //延时42us,ds18b20对数据线采样

asm("nop");

TRISA0=1; //采样结束,释放总线,拉高电平

code=code>>1;

delay1(7); //延时82us

}

}

//

//读ds18b20

unsigned char ds18b20_read_byte()

{

unsigned char i,k;

for(i=8;i>0;i--)

{

k=k>>1;

TRISA0=0;

DQ=0; //数据线拉低再拉高产生读时间片

asm("nop");

asm("nop");

TRISA0=1;

asm("nop");

asm("nop");

if(DQ) k=k|0x80; //15us内要完成读位

delay1(6); //延时72us后释放总线

}

return (k);

}

//

//启动温度转换函数

void get_temp()

{

int i;

signed int t;

TRISA0=1;

ds18b20_init(); //复位等待从机应答

ds18b20_write_byte(0XCC); //忽略ROM匹配

ds18b20_write_byte(0X44); //发送温度转化命令

for(i=2;i>0;i--)

{

display(); //调用多次显示函数,确保温度转换完成所需要的时间

}

ds18b20_init(); //再次复位,等待从机应答

ds18b20_write_byte(0XCC); //忽略ROM匹配

ds18b20_write_byte(0XBE); //发送读温度命令

TLV=ds18b20_read_byte(); //读出温度低8

THV=ds18b20_read_byte(); //读出温度高8位

TRISA0=1; //释放总线

t=THV<<8;

t=t|TLV;

if(t<0) //负温度

{

temp=(~t+1)0062510+05; //负温度时,取反加1再乘以00625得实际温度,乘10+05显示小数点一位,且四舍五入

}

else

temp=t0062510+05; //正温度

if(t<0)

bai='-'; //负温度时百位显示负号

else

bai=(const) temp/1000+0x30; //百位

shi=((const) temp%1000)/100; //十位

ge=((const) temp%1000)%100/10; //个位

shifen=((const) temp%1000)%100%10; //十分位

NOP();

}

//---------------------------------------------

//------------DS1303部分-----------------------

//---------------------------------------------

//延时程序

void delay() //延时程序

{

int i; //定义整形变量

for(i=0x64;i--;); //延时

}

//写一个字节数据函数

void write_byte(unsigned char data)

{

int j; //设置循环变量

for(j=0;j<8;j++) //连续写8bit

{

i_o=0; //先设置数据为0

sclk=0; //时钟信号拉低

if(data&0x01) //判断待发送的数据位是0或1

{

i_o=1; //待发送数据位是1

}

data=data>>1; //待发送的数据右移1位

sclk=1; //拉高时钟信号

}

sclk=0; //写完一个字节,拉低时钟信号

}

//---------------------------------------------

//读一个字节函数

unsigned char read_byte()

{

int j; //设置循环变量

TRISB4=1; //设置数据口方向为输入

for(j=8;j--;) //连续读取8bit

{

sclk=0; //拉低时钟信号

rx_data=rx_data>>1; //接收寄存器右移1位

if(i_o==1) rx_data=rx_data|0x80;

sclk=1; //拉高时钟信号

}

TRISB4=0; //恢复数据口方向为输出

sclk=0; //拉低时钟信号

return(rx_data); //返回读取到的数据

}

//----------------------------------------------

//写DS1302

void write_ds1302(unsigned char addr,unsigned char code)

{

rst=0;

sclk=0;

rst=1;

write_byte(addr);

write_byte(code);

sclk=0;

rst=1;

}

//-------------------------------------------

//读DS1302

void read_ds1302(unsigned char addr)

{

rst=0;

sclk=0;

rst=1;

write_byte(addr);

read_data=read_byte();

//return read_data;

}

//---------------------------------------------

//读取时间函数

void get_time()

{

int i; //设置循环变量

rst=1; //使能DS1302

write_byte(0xbf); //发送多字节读取命令

for(i=0;i<7;i++) //连续读取7个字节数据

{

table1[i]=read_byte(); //调用读取1个字节数据的函数

}

rst=0; //复位DS1302

}

//DS1302初始化函数

void ds1302_init()

{

sclk=0; //拉低时钟信号

rst =0; //复位DS1302

rst=1; //使能DS1302

write_ds1302(0x8e,0); //发控制命令

rst=0; //复位

}

//---------------------------------------------

//设置时间函数

void set_time()

{

//定义待设置的时间: 秒、 分、 时、 日、月、星期、年、控制字

const char table[]={0x00,0x00,0x12,0x23,0x10,0x05,0x09,0x00};

int i; //定义循环变量

rst=1; //使能DS1302

write_byte(0xbe); //时钟多字节写命令

for(i=0;i<8;i++) //连续写8个字节数据

{

write_byte(table[i]); //调用写一个字节函数

}

rst=0; //复位

}

//-------------------------------------------

//8位二进制数转换为十进制数

void two_to_ten(unsigned char i)

{

time=(table1[i]&0x0f)+(table1[i]>>4)0;

}

//-------------------------------------------

//十进制数转换为BCD码

void ten_to_bcd(unsigned char i)

{

time=((i/0)<<4)|(i%0);

}

//------------------------------------------

//校时程序

void change_time()

{

if(RC0==0) //改变星期---k13

{

delay();

if(RC0==0)

{

if(count==0)

{

count=1;

two_to_ten(5);

week=time;

week++;

if(week>=8)

{

week==1;

write_ds1302(0x8A,1);

}

else

write_ds1302(0x8A,week);

}

}

}

else if(RC1==0) //秒归零--k12

{

delay();

if(RC1==0)

{

if(count==0)

{

count=1;

write_ds1302(0x80,0);

}

}

}

else if(RC2==0) //改变分位--k11

{

delay();

if(RC2==0)

{

if(count==0)

{

count=1;

two_to_ten(1);//BCD码转换成十进制数

min=time;

min++;

if(min>=60)

{

min=0;

write_ds1302(0x82,min);

}

else

{

ten_to_bcd(min);//十进制数转换为BCD码存进DS1302

write_ds1302(0x82,time);

}

}

}

}

else if(RC3==0) //改变小时位--k10

{

delay();

if(RC3==0)

{

if(count==0)

{

count=1;

two_to_ten(2);//BCD码转换成十进制数

hour=time;

hour++;

if(hour>=24)

{

hour=0;

write_ds1302(0x84,hour);

}

else

{

ten_to_bcd(hour);

write_ds1302(0x84,time);

}

}

}

}

else if(RB2==0)

{

delay();

if(RB2==0)

{

if(count==0)

{

count=1;

two_to_ten(4);//BCD码转换成十进制数

mon=time;

mon++;

if(mon>=13)

{

mon=1;

write_ds1302(0x88,mon);

}

else

{

ten_to_bcd(mon);

write_ds1302(0x88,time);

}

}

}

}

else if(RB3==0)

{

delay();

if(RB3==0)

{

if(count==0)

{

count=1;

two_to_ten(3);//BCD码转换成十进制数

day=time;

day++;

if((table1[6]%4==0)&&(table1[4]==2)&&(day>=30)) //润年2月

{

day=1;

write_ds1302(0x86,day);

}

else if(((table1[6]%4)!=0)&&(table1[4]==2)&&(day>=29))//非润年的2月

{

day=1;

write_ds1302(0x86,day);

}

else if(((table1[4]==1)||(table1[4]==3)||(table1[4]==5)||(table1[4]==7)||(table1[4]==8)||(table1[4]==0x10)||(table1[4]==0x12))&&(day>=32))

{

day=1;

write_ds1302(0x86,day);

}

else if(((table1[4]==4)||(table1[4]==6)||(table1[4]==9)||(table1[4]==0x11))&&(day>=31))

{

day=1;

write_ds1302(0x86,day);

}

else

{

ten_to_bcd(day);

write_ds1302(0x86,time);

}

}

}

}

else if(RB1==0)

{

delay();

if(RB1==0)

{

if(count==0)

{

count=1;

two_to_ten(6);//BCD码转换成十进制数

year=time;

year++;

if(year>=16)

{

year=0x00;

write_ds1302(0x8c,0);

}

else

{

ten_to_bcd(year);

write_ds1302(0x8c,time);

}

}

}

}

else

count=0;

}

//

//lcd1602

//

//延时程序

//void delay()

// {

// unsigned char i;

// for(i=100;i>0;i--);

// }

//

//LCD写一个字节数据

void write_lcd(unsigned char code)

{

PORTD=code;

rs=1;

rw=0;

e=0;

delay();

e=1;

}

//

//lcd写命令函数

void lcd_enable(unsigned char code)

{

PORTD=code;

rs=0;

rw=0;

e=0;

delay();

e=1;

}

//

//lcd显示设置

void lcd_init()

{

lcd_enable(0x01); //清除显示

lcd_enable(0x38); //设置16X2显示,5X7点阵

lcd_enable(0x0c); //开显示,不显示光标

lcd_enable(0x06); //光标左移

}

//-------------------------------------------

//显示函数

void display()

{

// PORTD=0X80; //小时

lcd_enable(0X80);

write_lcd((table1[2]>>4)+0x30);

// PORTD=0x81;

lcd_enable(0x81);

write_lcd((table1[2]&0x0f)+0x30);

// PORTD=0X82;

lcd_enable(0X82);

write_lcd(':');

// PORTD=0X83; //分

lcd_enable(0X83);

write_lcd((table1[1]>>4)+0x30);

// PORTD=0x84;

lcd_enable(0x84);

write_lcd((table1[1]&0x0f)+0x30);

// PORTD=0X85;

lcd_enable(0X85);

write_lcd(':');

// PORTD=0X86; //秒

lcd_enable(0X86);

write_lcd((table1[0]>>4)+0x30);

// PORTD=0x87;

lcd_enable(0x87);

write_lcd((table1[0]&0x0f)+0x30);

// PORTD=0X89; //温度的百位

lcd_enable(0X89);

write_lcd(bai);

// PORTD=0X8a; //温度的十位

lcd_enable(0X8a);

write_lcd(shi+0x30);

// PORTD=0X8b; //温度的个位

lcd_enable(0X8b);

write_lcd(ge+0x30);

// PORTD=0X8c;

lcd_enable(0X8c);

write_lcd('');

// PORTD=0X8d; //温度的十分位

lcd_enable(0X8d);

write_lcd(shifen+0x30);

// PORTD=0X8e; //显示'C'

lcd_enable(0X8e);

write_lcd('C');

//

// PORTD=0XC0; //年

lcd_enable(0XC0);

write_lcd((table1[6]>>4)+0x30);

//PORTD=0XC1;

lcd_enable(0XC1);

write_lcd((table1[6]&0x0f)+0x30);

// PORTD=0XC2;

lcd_enable(0XC2);

write_lcd('-');

// PORTD=0XC3; //月

lcd_enable(0XC3);

write_lcd((table1[4]>>4)+0x30);

// PORTD=0xC4;

lcd_enable(0xC4);

write_lcd((table1[4]&0x0f)+0x30);

// PORTD=0XC5;

lcd_enable(0XC5);

write_lcd('-');

// PORTD=0XC6; //日

lcd_enable(0XC6);

write_lcd((table1[3]>>4)+0x30);

// PORTD=0xC7;

lcd_enable(0xC7);

write_lcd((table1[3]&0x0f)+0x30);

// PORTD=0XCD; //星期

lcd_enable(0XCD);

write_lcd((table1[5]&0x0f)+0x30);

}

//--------------------------------------------

//引脚定义函数

void port_init()

{

TRISA=0x00; //设置A口全输出

TRISD=0X00; //设置D口全输出

ADCON1=0X06; //设置A口为普通I/O口

TRISB=0X0E; //

OPTION=0X00; //开启B口弱上拉

PORTA=0XFF;

PORTD=0XFF; //先熄灭所有显示

lcd_init();

TRISC=0XEF; //RC3输出,其他为输入

PORTC=0XEF;

count=0;

}

//----------------------------------------------

//主函数

void main()

{

port_init(); //调用引脚初始化函数

read_ds1302(0x81); //查看DS1302是否起振

if(read_data&0x80) //否,则初始化DS1302

{

ds1302_init(); //调用DS1302初始化函数

set_time(); //调用设置时间函数

}

while(1)

{

get_time(); //调用取时间函数

change_time();

get_temp(); //调用温度转换函数

display(); //调用显示函数

}

}

以上就是关于有人用过TLV5638这块DA吗我编好程了他就是不工作!全部的内容,包括:有人用过TLV5638这块DA吗我编好程了他就是不工作!、TLV 格式及编解码、在pic中如何用C语言编写程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10622698.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存