我来教大家“缘起麻将开挂下什么软件”(确实是有挂)-哔哩哔哩

网上有关“懂80C51单片机的进~”话题很是火热,小编也是针对懂80C51单片机的进~寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。

您好:手机麻将有挂是真的吗这款游戏可以开挂,确实是有挂的,咨询加微信【】很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,而且好像能看到其他人的牌一样。所以很多小伙伴就怀疑这款游戏是不是有挂,实际上这款游戏确实是有挂的
http://www.boyicom.net/sheng/1.jpg
1.手机麻将有挂是真的吗这款游戏可以开挂,确实是有挂的,通过添加客服微信 2.咨询软件加微信【】在"设置DD功能DD微信手麻工具"里.点击"开启". 3.打开工具.在"设置DD新消息提醒"里.前两个选项"设置"和"连接软件"均勾选"开启"(好多人就是这一步忘记做了) 4.打开某一个微信组.点击右上角.往下拉."消息免打扰"选项.勾选"关闭"(也就是要把"群消息的提示保持在开启"的状态.这样才能触系统发底层接口)

贴上两个自己用过的LCD1602驱动(总线、IO口的都有,肯定派得上用场)

再贴上ADC0809总线上的驱动,只是不知道楼主的具体要求如何显示在LCD上,只能保存在数组里面

硬件连接在代码中已经基本补齐了,其他的应该不用再多说了吧?!^_^

*********************************************************************

/*===========================================================================

KS0070(44780) 16x2 字符液晶屏驱动演示程序总线方式 晓奇

=============================================================================

连接线图: LCM-------51 LCM-------51 LCM--------51

DB0-----P0.0 DB4-----P0.4 RW-------P2.0

DB1-----P0.1 DB5-----P0.5 RC-------P2.1

DB2-----P0.2 DB6-----P0.6 E--------P2.7 =>74ls00+wr+rd

DB3-----P0.3 DB7-----P0.7 VLCD接1K2电阻到GND

[注]:AT89C51的晶振频率为12MHz

============================================================================*/

//#pragma src // 产生汇编文件

#include <reg51.h>

#include<intrins.h>

//========= 变量类型标识的宏定义,大家都喜欢这么做 ==============

#define Uchar unsigned char

#define Uint unsigned int

// ================= LCM1602A端口地址定义 =======================

char xdata Lcd1602CmdPort _at_ 0x7cff; //E=1 RS=0 RW=0

char xdata Lcd1602WdataPort _at_ 0x7eff; //E =1 RS=1 RW=0

char xdata Lcd1602StatusPort _at_ 0x7dff; //CS=1 RS=0 RW=1

#define Busy 0x80 // 忙判别位

code char exampl[]="For an example. - By xiaoqi\n";

void Delay400Ms(void);

void Delay5Ms(void);

void LcdWriteData( char dataW );

void LcdWriteCommand( Uchar CMD,Uchar AttribC );

void LcdReset( void );

void Display( Uchar dd );

void DispOneChar(Uchar x,Uchar y,Uchar Wdata);

void ePutstr(Uchar x,Uchar y, Uchar code *ptr);

//================ 随便写几句测试主程序 ================

void main(void)

{

Uchar temp;

Delay400Ms(); // 启动时必须的延时,等待lcm进入工作状态

LcdReset(); // 这也是必需的....初始化

temp = 32;

ePutstr(0,0,exampl); // 上面一行显示一个预定字符串

Delay400Ms(); // 保留显示内容

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

while(1)

{

temp &= 0x7f; // 只显示ASCII字符

if (temp<32)temp=32; // 屏蔽控制字符,不予显示

Display( temp++ );

Delay400Ms();

}

}

/*=======================================================

显示字符串

=======================================================*/

void ePutstr(Uchar x,Uchar y, Uchar code *ptr) {

Uchar i,l=0;

while (ptr[l] >31){l++;};

for (i=0;i<l;i++) {

DispOneChar(x++,y,ptr[i]);

if ( x == 16 ){

x = 0; y ^= 1;

}

}

}

/*=======================================================

演示一行连续字符串,配合上位程序演示移动字串

=======================================================*/

void Display( Uchar dd ) {

Uchar i;

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

DispOneChar(i,1,dd++);

dd &= 0x7f;

if (dd<32) dd=32;

}

}

/*=======================================================

显示光标定位

=======================================================*/

void LocateXY( char posx,char posy) {

Uchar temp;

temp = posx & 0xf;

posy &= 0x1;

if ( posy )temp |= 0x40;

temp |= 0x80;

LcdWriteCommand(temp,0);

}

/*=======================================================

按指定位置显示数出一个字符

=======================================================*/

void DispOneChar(Uchar x,Uchar y,Uchar Wdata) {

LocateXY( x, y ); // 定位显示地址

LcdWriteData( Wdata ); // 写字符

}

/*=======================================================

初始化程序, 必须按照产品资料介绍的初始化过程进行

=======================================================*/

void LcdReset( void ) {

LcdWriteCommand( 0x38, 0); // 显示模式设置(不检测忙信号)

Delay5Ms();

LcdWriteCommand( 0x38, 0); // 共三次

Delay5Ms();

LcdWriteCommand( 0x38, 0);

Delay5Ms();

LcdWriteCommand( 0x38, 1); // 显示模式设置(以后均检测忙信号)

LcdWriteCommand( 0x08, 1); // 显示关闭

LcdWriteCommand( 0x01, 1); // 显示清屏

LcdWriteCommand( 0x06, 1); // 显示光标移动设置

LcdWriteCommand( 0x0c, 1); // 显示开及光标设置

}

/*=======================================================

写控制字符子程序: E=1 RS=0 RW=0

=======================================================*/

void LcdWriteCommand( Uchar CMD,Uchar AttribC ) {

if (AttribC) while( Lcd1602StatusPort & Busy ); // 检测忙信号?

Lcd1602CmdPort = CMD;

}

/*=======================================================

当前位置写字符子程序: E =1 RS=1 RW=0

=======================================================*/

void LcdWriteData( char dataW ) {

while( Lcd1602StatusPort & Busy ); // 检测忙信号

Lcd1602WdataPort = dataW;

}

// 短延时

void Delay5Ms(void)

{

Uint i = 5552;

while(i--);

}

//长延时

void Delay400Ms(void)

{

Uchar i = 5;

Uint j;

while(i--)

{

j=7269;

while(j--);

};

}

*********************************************************************

/*===================================================================

KS0070(44780) 16x2 字符液晶屏驱动演示程序 晓奇

=====================================================================

连接线图: LCM-------51 LCM-------51 LCM--------51

DB0-----P0.0 DB4-----P0.4 RS-------P2.5

DB1-----P0.1 DB5-----P0.5 RW-------P2.6

DB2-----P0.2 DB6-----P0.6 E--------P2.7

DB3-----P0.3 DB7-----P0.7 VLCD接1K2电阻到GND

[注]:AT89C51的晶振频率为12MHz

====================================================================*/

#include <reg51.h>

#include<intrins.h>

//变量类型标识的宏定义,大家都喜欢这么做

#define Uchar unsigned char

#define Uint unsigned int

// 控制引脚定义,不同的连接必须修改的部分

sbit RS = P2^5;

sbit RW = P2^6;

sbit Elcm = P2^7;

#define DataPort P0 // 数据端口,必须上拉电阻

#define Busy 0x80

code char exampl[]="For an example. - By xiaoqi\n";

void Delay400Ms(void);

void Delay5Ms(void);

void WaitForEnable( void );

void LcdWriteData( char dataW );

void LcdWriteCommand( Uchar CMD,Uchar AttribC );

void LcdReset( void );

void Display( Uchar dd );

void DispOneChar(Uchar x,Uchar y,Uchar Wdata);

void ePutstr(Uchar x,Uchar y, Uchar code *ptr);

//测试主程序

void main(void)

{

Uchar temp;

Delay400Ms();

LcdReset();

temp = 32;

ePutstr(0,0,exampl); // 上面一行显示一个预定字符串

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

Delay400Ms();

while(1)

{

temp &= 0x7f; // 只显示ASCII字符

if (temp<32)temp=32; // 屏蔽控制字符,不予显示

Display( temp++ );

Delay400Ms();

}

}

/*=======================================================

显示字符串

=======================================================*/

void ePutstr(Uchar x,Uchar y, Uchar code *ptr) {

Uchar i,l=0;

while (ptr[l] >31){l++;};

for (i=0;i<l;i++) {

DispOneChar(x++,y,ptr[i]);

if ( x == 16 ){

x = 0; y ^= 1;

}

}

}

/*=======================================================

演示一行连续字符串,配合上位程序演示移动字串

=======================================================*/

void Display( Uchar dd ) {

Uchar i;

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

DispOneChar(i,1,dd++);

dd &= 0x7f;

if (dd<32) dd=32;

}

}

/*=======================================================

显示光标定位

=======================================================*/

void LocateXY( char posx,char posy) {

Uchar temp;

temp = posx & 0xf;

posy &= 0x1;

if ( posy )temp |= 0x40;

temp |= 0x80;

LcdWriteCommand(temp,0);

}

/*=======================================================

按指定位置显示数出一个字符

=======================================================*/

void DispOneChar(Uchar x,Uchar y,Uchar Wdata) {

LocateXY( x, y ); // 定位显示地址

LcdWriteData( Wdata ); // 写字符

}

/*=======================================================

初始化程序, 必须按照产品资料介绍的初始化过程进行

=======================================================*/

void LcdReset( void ) {

LcdWriteCommand( 0x38, 0); // 显示模式设置(不检测忙信号)

Delay5Ms();

LcdWriteCommand( 0x38, 0); // 共三次

Delay5Ms();

LcdWriteCommand( 0x38, 0);

Delay5Ms();

LcdWriteCommand( 0x38, 1); // 显示模式设置(以后均检测忙信号)

LcdWriteCommand( 0x08, 1); // 显示关闭

LcdWriteCommand( 0x01, 1); // 显示清屏

LcdWriteCommand( 0x06, 1); // 显示光标移动设置

LcdWriteCommand( 0x0c, 1); // 显示开及光标设置

}

/*=======================================================

写控制字符子程序: E=1 RS=0 RW=0

=======================================================*/

void LcdWriteCommand( Uchar CMD,Uchar AttribC ) {

if (AttribC) WaitForEnable(); // 检测忙信号?

RS = 0; RW = 0; _nop_();

DataPort = CMD; _nop_(); // 送控制字子程序

Elcm = 1;_nop_();_nop_();Elcm = 0; // 操作允许脉冲信号

}

/*=======================================================

当前位置写字符子程序: E =1 RS=1 RW=0

=======================================================*/

void LcdWriteData( char dataW ) {

WaitForEnable(); // 检测忙信号

RS = 1; RW = 0; _nop_();

DataPort = dataW; _nop_();

Elcm = 1; _nop_(); _nop_(); Elcm = 0; // 操作允许脉冲信号

}

/*=======================================================

正常读写操作之前必须检测LCD控制器状态: CS=1 RS=0 RW=1

DB7: 0 LCD控制器空闲; 1 LCD控制器忙

========================================================*/

void WaitForEnable( void ) {

DataPort = 0xff;

RS =0; RW = 1; _nop_(); Elcm = 1; _nop_(); _nop_();

while( DataPort & Busy );

Elcm = 0;

}

// 短延时

void Delay5Ms(void)

{

Uint i = 5552;

while(i--);

}

//长延时

void Delay400Ms(void)

{

Uchar i = 5;

Uint j;

while(i--)

{

j=7269;

while(j--);

};

}

*********************************************************************

#include<REG51.H>

#include<ABSACC.H>

#define uchar unsigned char

//通道号,根据硬件实际改动

#define IN0 XBYTE[0X0000] //通道0

#define IN1 XBYTE[0X0001]

#define IN2 XBYTE[0X0002]

#define IN3 XBYTE[0X0003]

#define IN4 XBYTE[0X0004]

#define IN5 XBYTE[0X0005]

#define IN6 XBYTE[0X0006]

#define IN7 XBYTE[0X0007]

sbit ad_busy=P3^5;

void AD0809(uchar idata *x);

//调用该程序后应将模拟量转换成数字量存于一数组adcRes[]之中

void AD0809(uchar idata *adcRes)

{

uchar i;

data uchar xdata *ad_adr;

ad_adr=&IN0; // 指向第一个通道

for(i=0;i<8;i++) {

*ad_adr=0; //启动AD转换

ad_busy=0; //调试后发现0才是正确的

while(ad_busy==0); //等待AD转换结束

adcRes[i]=*ad_adr; //保存转换结果

ad_adr++; //下一个通道

}

}

你好! 给你两个份实例 基本可以搞定啦 !

一。。。。流水灯实例

1. 基础知识:寻址方式是寻找、确定参与操作的数据的地址的方式。8051单片机的寻址方式包括寄存器寻址、直接寻址、寄存器间接寻址、立即寻址、变址寻址和位寻址7种寻址方式。

2. 硬件电路(等级不够还不能传哈)

3. 软件程序设计:

ORG 0000H ;伪指令,指定程序从0000H开始存放

LJMP MAIN; 跳转指令,程序跳转到MAIN处

ORG 0100H ;伪指令,指定以下程序从0100H开始存放

MAIN:

MOV SP,#60H ;给堆栈指针赋初值

MOV P1,#0FFH ;给P1赋初值,LED全灭

;以下为查表程序

MOV DPTR,#LED_TABLE

LIGHT:

MOV R7,#42

LOOP:

MOV A,#42

SUBB A,R7

MOVC A,@A+DPTR

MOV P1,A ;输出显示

LCALL DELAY ;调延时子程序

DJNZ R7,LOOP

SJMP LIGHT ;跳转,程序继续

DELAY:

MOV R7,#10H

DELAY0:

MOV R6,#7FH

DELAY1:

MOV R5,#7FH

DJNZ R5,$

DJNZ R6,DELAY1

DJNZ R7,DELAY0

RET

;表格数据

LED_TABLE:

DB 0FFH ;全部熄灭

DB 0FEH. , 0FDH , 0FBH , 0F7H , 0EFH , 0DFH , 0BFH, 07FH ;依次逐个点亮

DB 0FEH. , 0FCH , 0F8H , 0F0H , 0E0H , 0C0H , 080H, 000H ; 依次逐个叠加

DB 080H. , 0C0H , 0E0H , 0F0H , 0F8H , 0FCH , 0FEH, 0FFH ;依次逐个递减

DB 07EH. , 0BDH , 0DBH , 0E7H , 0E7H , 0DBH , 0BDH, 07EH ;两边靠拢后分开

DB 07EH. , 03CH , 01BH , 000H , 000H , 018H , 03CH, 07EH ;从两边叠加后递减

DB 000H ;全部点亮

END

4. 运行结果

程序运行后,将依次循环出现8只LED依次逐个点亮 、依次逐个叠加、依次逐个递减、从两边靠拢后分开、从两边叠加后递减的流水灯效果。

5. 技巧总结

查表指令可用于复杂代码转换显示,通过查表指令可以实现复杂的显示效果,并可以减少程序代码。

二 。。。。用单片机控制的LED流水灯设计(电路、程序全部给出)

1.引言

当今时代是一个新技术层出不穷的时代,在电子领域尤其是自动化智能控制领域,传统的分立元件或数字逻辑电路构成的控制系统,正以前所未见的速度被单片机智能控制系统所取代。单片机具有体积小、功能强、成本低、应用面广等优点,可以说,智能控制与自动控制的核心就是单片机。目前,一个学习与应用单片机的高潮正在工厂、学校及企事业单位大规模地兴起。学习单片机的最有效方法就是理论与实践并重,本文笔者用AT89C51单片机自制了一款简易的流水灯,重点介绍了其软件编程方法,以期给单片机初学者以启发,更快地成为单片机领域的优秀人才。

2.硬件组成

按照单片机系统扩展与系统配置状况,单片机应用系统可分为最小系统、最小功耗系统及典型系统等。AT89C51单片机是美国ATMEL公司生产的低电压、高性能CMOS

8位单片机,具有丰富的内部资源:4kB闪存、128BRAM、32根I/O口线、2个16位定时/计数器、5个向量两级中断结构、2个全双工的串行口,具有4.25~5.50V的电压工作范围和0~24MHz工作频率,使用AT89C51单片机时无须外扩存储器。因此,本流水灯实际上就是一个带有八个发光二极管的单片机最小应用系统,即为由发光二极管、晶振、复位、电源等电路和必要的软件组成的单个单片机。其具体硬件组成如图1所示。

图1 流水灯硬件原理图

从原理图中可以看出,如果要让接在P1.0口的LED1亮起来,那么只要把P1.0口的电平变为低电平就可以了;相反,

如果要接在P1.0口的LED1熄灭,就要把P1.0口的电平变为高电平;同理,接在P1.1~P1.7口的其他7个LED的点亮和熄灭的方法同LED1。因此,要实现流水灯功能,我们只要将发光二极管LED1~LED8依次点亮、熄灭,8只LED灯便会一亮一暗的做流水灯了。在此我们还应注意一点,由于人眼的视觉暂留效应以及单片机执行每条指令的时间很短,我们在控制二极管亮灭的时候应该延时一段时间,否则我们就看不到“流水”效果了。

3.软件编程

单片机的应用系统由硬件和软件组成,上述硬件原理图搭建完成上电之后,我们还不能看到流水灯循环点亮的现象,我们还需要告诉单片机怎么来进行工作,即编写程序控制单片机管脚电平的高低变化,来实现发光二极管的一亮一灭。软件编程是单片机应用系统中的一个重要的组成部分,是单片机学习的重点和难点。下面我们以最简单的流水灯控制功能即实现8个LED灯的循环点亮,来介绍实现流水灯控制的几种软件编程方法。

3.1位控法

这是一种比较笨但又最易理解的方法,采用顺序程序结构,用位指令控制P1口的每一个位输出高低电平,从而来控制相应LED灯的亮灭。程序如下:

ORG 0000H ;单片机上电后从0000H地址执行

AJMP START ;跳转到主程序存放地址处

ORG 0030H ;设置主程序开始地址

START:MOV SP,#60H ;设置堆栈起始地址为60H

CLR P1.0 ;P1.0输出低电平,使LED1点亮

ACALL DELAY ;调用延时子程序

SETB P1.0 ;P1.0输出高电平,使LED1熄灭

CLR P1.1 ;P1.1输出低电平,使LED2点亮

ACALL DELAY ;调用延时子程序

SETB P1.1 ;P1.1输出高电平,使LED2熄灭

CLR P1.2 ;P1.2输出低电平,使LED3点亮

ACALL DELAY ;调用延时子程序

SETB P1.2 ? ;P1.2输出高电平,使LED3熄灭

CLR P1.3 ;P1.3输出低电平,使LED4点亮

ACALL DELAY ;调用延时子程序

SETB P1.3 ;P1.3输出高电平,使LED4熄灭

CLR P1.4 ;P1.4输出低电平,使LED5点亮

ACALL DELAY ;调用延时子程序

SETB P1.4 ;P1.4输出高电平,使LED5熄灭

CLR P1.5 ;P1.5输出低电平,使LED6点亮

ACALL DELAY ;调用延时子程序

SETB P1.5 ;P1.5输出高电平,使LED6熄灭

CLR P1.6 ;P1.6输出低电平,使LED7点亮

ACALL DELAY ;调用延时子程序

SETB P1.6 ;P1.6输出高电平,使LED7熄灭

CLR P1.7 ;P1.7输出低电平,使LED8点亮

ACALL DELAY ;调用延时子程序

SETB P1.7 ;P1.7输出高电平,使LED8熄灭

ACALL DELAY ;调用延时子程序

AJMP START ;8个LED流了一遍后返回到标号START处再循环

DELAY: ;延时子程序

MOV R0,#255 ;延时一段时间

D1: MOV R1,#255

DJNZ R1,$

DJNZ R0,D1

RET ;子程序返回

END ;程序结束

3.2循环移位法

在上个程序中我们是逐个控制P1端口的每个位来实现的,因此程序显得有点复杂,下面我们利用循环移位指令,采用循环程序结构进行编程。我们在程序一开始就给P1口送一个数,这个数本身就让P1.0先低,其他位为高,然后延时一段时间,再让这个数据向高位移动,然后再输出至P1口,这样就实现“流水”效果啦。由于8051系列单片机的指令中只有对累加器ACC中数据左移或右移的指令,因此实际编程中我们应把需移动的数据先放到ACC中,让其移动,然后将ACC移动后的数据再转送到P1口,这样同样可以实现“流水”效果。具体编程如下所示,程序结构确实简单了很多。

ORG 0000H ;单片机上电后从0000H地址执行

AJMP START ;跳转到主程序存放地址处

ORG 0030H ;设置主程序开始地址

START:MOV SP,#60H ;设置堆栈起始地址为60H

MOV A,#0FEH ;ACC中先装入LED1亮的数据(二进制的11111110)

MOV P1,A ;将ACC的数据送P1口

MOV R0,#7 ;将数据再移动7次就完成一个8位流水过程

LOOP: RL A ;将ACC中的数据左移一位

MOV P1,A ;把ACC移动过的数据送p1口显示

ACALL DELAY ;调用延时子程序

DJNZ R0,LOOP ;没有移动够7次继续移动

AJMP START ;移动完7次后跳到开始重来,以达到循环流动效果

DELAY: ;延时子程序

MOV R0,#255 ;延时一段时间

D1: MOV R1,#255

DJNZ R1,$

DJNZ R0,D1

RET ;子程序返回

END ;程序结束

3.3查表法

上面的两个程序都是比较简单的流水灯程序,“流水”花样只能实现单一的“从左到右”流方式。运用查表法所编写的流水灯程序,能够实现任意方式流水,而且流水花样无限,只要更改流水花样数据表的流水数据就可以随意添加或改变流水花样,真正实现随心所欲的流水灯效果。我们首先把要显示流水花样的数据建在一个以TAB为标号的数据表中,然后通过查表指令“MOVC A,@A+DPTR”把数据取到累加器A中,然后再送到P1口进行显示。具体源程序如下,TAB标号处的数据表可以根据实现效果的要求任意修改。

ORG 0000H ;单片机上电后从0000H地址执行

AJMP START ;跳转到主程序存放地址处

ORG 0030H ;设置主程序开始地址

START:MOV SP,#60H ;设置堆栈起始地址为60H

MOV DPTR,# TAB ;流水花样表首地址送DPTR

LOOP: CLR A ;累加器清零

MOVC A,@A+DPTR ;取数据表中的值

CJNE A,#0FFH,SHOW;检查流水结束标志

AJMP START ;所有花样流完,则从头开始重复流

SHOW: MOV P1,A ;将数据送到P1口

ACALL DELAY ;调用延时子程序

INC DPTR ;取数据表指针指向下一数据

AJMP LOOP ;继续查表取数据

DELAY: ;延时子程序

MOV R0,#255 ;延时一段时间

D1: MOV R1,#255

DJNZ R1,$

DJNZ R0,D1

RET ? ;子程序返回

TAB: ;下面是流水花样数据表,用户可据要求任意编写

DB 11111110B ;二进制表示的流水花样数据,从低到高左移

DB 11111101B

DB 11111011B

DB 11110111B

DB 11101111B

DB 11011111B

DB 10111111B

DB 01111111B

DB 01111111B ;二进制表示的流水花样数据,从高到低右移

DB 10111111B

DB 11011111B

DB 11101111B

DB 11110111B

DB 11111011B

DB 11111101B

DB 11111110B

DB 0FEH,0FDH,0FBH,0F7H ;十六进制表示的流水花样数据

DB 0EFH,0DFH,0BFH,7FH

DB 7FH,0BFH,0DFH,0EFH

DB 0F7H,0FBH,0FDH,0FEH

……

DB 0FFH ;流水花样结束标志0FFH

END ;程序结束

4.结语

当上述程序之一编写好以后,我们需要使用编译软件对其编译,得到单片机所能识别的二进制代码,然后再用编程器将二进制代码烧写到AT89C51单片机中,最后连接好电路通电,我们就看到LED1~LED8的“流水”效果了。本文所给程序实现的功能比较简单,旨在抛砖引玉,用户可以自己在此基础上扩展更复杂的流水灯控制,比如键盘控制流水花样、控制流水灯显示数字或图案等等。

希望能帮上你

关于“懂80C51单片机的进~”这个话题的介绍,今天小编就给大家分享完了,如果对你有所帮助请保持对本站的关注!

(0)
上一篇 2024年05月15日
下一篇 2024年05月15日

相关推荐