#include <reg51.h>
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int
sbit DQ = P2^0 //定义DS18B20端口DQ
sbit BEEP=P3^7 //蜂鸣器驱动线
bit presence
sbit LCD_RS = P2^6
sbit LCD_RW = P2^5
sbit LCD_EN = P2^4
uchar code cdis1[ ] = {" DS18B20 OK "}
uchar code cdis2[ ] = {""}
uchar code cdis3[ ] = {" DS18B20 ERR0R "}
uchar code cdis4[ ] = {" PLEASE CHECK "}
unsigned char data display[2] = {0x00,0x00}
unsigned char data RomCode[8] = {0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}
unsigned char Temp
unsigned char crc
void beep()
#define delayNOP(){_nop_()_nop_()_nop_()_nop_()}
/*******************************************************************/
void delay1(int ms)
{
unsigned char y
while(ms--)
{
for(y = 0y<250y++)
{
_nop_()
_nop_()
_nop_()
_nop_()
}
}
}
/******************************************************************/
/**/
/*检查LCD忙状态 */
/*lcd_busy为1时,忙,等待。lcd-busy为0时,闲,可写指令与数据。 */
/**/
/******************************************************************/
bit lcd_busy()
{
bit result
LCD_RS = 0
LCD_RW = 1
LCD_EN = 1
delayNOP()
result = (bit)(P0&0x80)
LCD_EN = 0
return(result)
}
/*******************************************************************/
/* */
/*写指令数据到LCD */
/*RS=L,RW=L,E=高脉冲,D0-D7=指令码。 */
/* */
/*******************************************************************/
void lcd_wcmd(uchar cmd)
{
while(lcd_busy())
LCD_RS = 0
LCD_RW = 0
LCD_EN = 0
_nop_()
_nop_()
P0 = cmd
delayNOP()
LCD_EN = 1
delayNOP()
LCD_EN = 0
}
/*******************************************************************/
/* */
/*写显示数据到LCD */
/*RS=H,RW=L,E=高脉冲,D0-D7=数据。 */
/* */
/*******************************************************************/
void lcd_wdat(uchar dat)
{
while(lcd_busy())
LCD_RS = 1
LCD_RW = 0
LCD_EN = 0
P0 = dat
delayNOP()
LCD_EN = 1
delayNOP()
LCD_EN = 0
}
/*******************************************************************/
/* */
/* LCD初始化设定 */
/* */
/*******************************************************************/
void lcd_init()
{
delay1(15)
lcd_wcmd(0x01) //清除LCD的显示内容
lcd_wcmd(0x38) //16*2显示,5*7点阵,8位数据
delay1(5)
lcd_wcmd(0x38)
delay1(5)
lcd_wcmd(0x38)
delay1(5)
lcd_wcmd(0x0c) //显示开,关光标
delay1(5)
lcd_wcmd(0x06) //移动光标
delay1(5)
lcd_wcmd(0x01) //清除LCD的显示内容
delay1(5)
}
/*******************************************************************/
/* */
/* 设定显示位置 */
/* */
/*******************************************************************/
void lcd_pos(uchar pos)
{
lcd_wcmd(pos | 0x80) //数据指针=80+地址变量
}
/*******************************************************************/
/* */
/*us级延时函数 */
/* */
/*******************************************************************/
void Delay(unsigned int num)
{
while( --num )
}
/*******************************************************************/
/* */
/*初始化ds1820 */
/* */
/*******************************************************************/
Init_DS18B20(void)
{
DQ = 1 //DQ复位
Delay(8) //稍做延时
DQ = 0 //将DQ拉低
Delay(90) //精确延时 大于 480us
DQ = 1 //拉高总线
Delay(8)
presence = DQ //读取存在信号
Delay(100)
DQ = 1
return(presence)//返回信号,0=presence,1= no presence
}
/*******************************************************************/
/* */
/* 读一位(bit) */
/* */
/*******************************************************************/
uchar read_bit(void)
{
unsigned char i
DQ = 0 //将DQ 拉低开始读时间隙
DQ = 1 // then return high
for (i=0i<3i++) // 延时15μs
return(DQ) // 返回 DQ 线上的电平值
}
/*******************************************************************/
/* */
/* 读一个字节 */
/* */
/*******************************************************************/
ReadOneChar(void)
{
unsigned char i = 0
unsigned char dat = 0
//for (i = 8i >0i--)
// {
//read_bit()
//DQ = 0// 给脉冲信号
// dat >>= 1
//DQ = 1// 给脉冲信号
for (i=0i<8i++)
{ // 读取字节,每次读取一个字节
if(read_bit()) dat|=0x01<<i // 然后将其左移
//if(DQ)
// dat |= 0x80
Delay(4)
}
return (dat)
}
/*******************************************************************/
/* */
/* 写一位 */
/* */
/*******************************************************************/
void write_bit(char bitval) {
DQ = 0// 将DQ 拉低开始写时间隙
if(bitval==1) DQ =1 // 如果写1,DQ 返回高电平
Delay(5) // 在时间隙内保持电平值,
DQ = 1 // Delay函数每次循环延时16μs,因此delay(5) = 104μs
}
/*******************************************************************/
/* */
/* 写一个字节 */
/* */
/*******************************************************************/
WriteOneChar(unsigned char dat)
{
unsigned char i = 0
unsigned char temp
// for (i = 8i >0i--)
// {
for (i=0i<8i++) // 写入字节, 每次写入一位
{
//DQ = 0
//DQ = dat&0x01
//Delay(5)
//DQ = 1
temp = dat>>i
temp &= 0x01
write_bit(temp)
//dat>>=1
}
Delay(5)
}
/*******************************************************************/
/* */
/* 读取64位序列码 */
/* */
/*******************************************************************/
Read_RomCord(void)
{
unsigned char j
Init_DS18B20()
WriteOneChar(0x33) // 读序列码的操作
for (j = 0j <8j++)
{
RomCode[j] = ReadOneChar()
}
}
/*******************************************************************/
/* */
/*DS18B20的CRC8校验程序*/
/* */
/*******************************************************************/
uchar CRC8()
{
uchar i,xuchar crcbuff
crc=0
for(x = 0x <8x++)
{
crcbuff=RomCode[x]
for(i = 0i <8i++)
{
if(((crc ^ crcbuff)&0x01)==0)
crc >>= 1
else {
crc ^= 0x18 //CRC=X8+X5+X4+1
crc >>= 1
crc |= 0x80
}
crcbuff >>= 1
}
}
return crc
}
/*******************************************************************/
/* */
/* 数据转换与显示 */
/* */
/*******************************************************************/
Disp_RomCode()
{
uchar j
uchar H_num=0x40 //LCD第二行初始位置
for(j=0j<8j++)
{
Temp = RomCode[j]
display[0]=((Temp&0xf0)>>4)
if(display[0]>9)
{ display[0]=display[0]+0x37}
else{display[0]=display[0]+0x30}
lcd_pos(H_num)
lcd_wdat(display[0]) //高位数显示
H_num++
display[1]=(Temp&0x0f)
if(display[1]>9)
{display[1]=display[1]+0x37}
else {display[1]=display[1]+0x30}
lcd_pos(H_num)
lcd_wdat(display[1]) //低位数显示
H_num++
}
}
/*******************************************************************/
/* */
/* 蜂鸣器响一声*/
/* */
/*******************************************************************/
void beep()
{
unsigned char y
for (y=0y<100y++)
{
Delay(60)
BEEP=!BEEP //BEEP取反
}
BEEP=1 //关闭蜂鸣器
Delay(40000)
}
/*******************************************************************/
/* */
/* DS18B20 OK 显示菜单 */
/* */
/*******************************************************************/
void Ok_Menu ()
{
uchar m
lcd_init() //初始化LCD
lcd_pos(0) //设置显示位置为第一行的第1个字符
m = 0
while(cdis1[m] != 'C 自动请求重发')
{ //显示字符
lcd_wdat(cdis1[m])
m++
}
lcd_pos(0x40)//设置显示位置为第二行第1个字符
m = 0
while(cdis2[m] != '接受到的是110111001说明传输的就是这段序列号,假设传输的二进制信息为*****,则由G(x)=11001可知
需要将****后面加4个0然后去除以11001 得到的余数再加到****后面就是110111001
又可知余数是1001 则 原来要传送的信息为11011 则110110000除11001得到的余数如果是1001 就说明再传送过程中没有出错 若不是则说明 出错了
经计算 余数貌似是1011 则说明出错了')
{
lcd_wdat(cdis2[m]) //显示字符
m++
}
}
/*******************************************************************/
/* */
/* DS18B20 ERROR 显示菜单 */
/* */
/*******************************************************************/
void Error_Menu ()
{
uchar m
lcd_init() //初始化LCD
lcd_pos(0) //设置显示位置为第一行的第1个字符
m = 0
while(cdis3[m] != '数据链路层使用帧尾的FCS(帧循环校验序列)完成差错控制
网络层使用数据包中的校验和进行差错校验
传输层使用序列号、确认号、校验和进行差错控制</pre>
<div class="replyask-box u-154740002-e " id="replyask-1741526">
<h4 class="ask">追问</h4>
<div class="replyask-content">
<pre class="replyask-text" id="content-1741526">谢谢!有具体点的吗!</pre>
</div>
<div class="replyask-data" id="data-1741526">
<input type="hidden" name="raid" value="1741526" />
<input type="hidden" name="mapUrl" value="" />
<input type="hidden" name="refer" value="" />
<input type="hidden" name="pid" value="" />
</div>
</div>
<div class="replyask-box u-64187941-e last" id="replyask-1782339">
<h4 class="reply">回答</h4>
<div class="replyask-content">
<pre class="replyask-text" id="content-1782339">数据链路层的帧尾有fcs,当发送方发送帧之前会对帧中的数据进行校验,采用CRC算法,将得到的数值封装到帧尾,也就是fcs。接收方收到该帧后,用同样的算法对帧中的数据进行计算,将得到的数值与帧尾的fcs进行比较,如果一致则该帧正确,如不一致,则该帧错误。
网络层的IP数据包的包头部分由校验和一项,也是发送发将校验值加入,接收方使用相同算法计算后比较。
传输层的校验和作用同上。还可以通过序列号确认号避免报文重传。')
{ //显示字符
lcd_wdat(cdis3[m])
m++
}
lcd_pos(0x40)//设置显示位置为第二行第1个字符
m = 0
while(cdis4[m] != '还有链路标识,流量控制等等,差错检测多用方阵码校验.')
{
lcd_wdat(cdis4[m]) //显示字符
m++
}
}
/*******************************************************************/
/* */
/* 主函数 */
/* */
/*******************************************************************/
void main()
{
P0 = 0xff
P2 = 0xff
while(1)
{
Ok_Menu ()
Read_RomCord() //读取64位序列码
CRC8() //CRC效验
if(crc==0) //CRC效验正确
{
Disp_RomCode()//显示64位序列码
beep()
}
while(!presence)
{
Init_DS18B20()
delay1(1000)
}
Error_Menu ()
do
{
Init_DS18B20()
beep()
}
while(presence)
}
}
/*******************************************************************/fsc
步骤如下:
1、首先双击运行电脑上的Steam客户端,在登录界面,输入账号密码,登录自己的账户。
2、登录之后,在首页点击需要激活的“游戏”,然后点击“激活产品”,之后点击“下一步”。
3、之后会出现用户协议的弹窗,在这里点击“我同意”。输入购买好的CDKEY,注意不要空格。
4、最后点击下一步,如果CDKEY输入没有错误的话,就会出现激活成功提示,游戏就出现在库中了。
CDKEY是大部分商业软件都需要使用序列码(或CDKEY码) 安装序列码,简称密钥。
在网络上兑换物品,一般商家会给你一串密钥,这串密钥就叫cdkey,去商家给你的网站上输入密钥选择你DNF角色所在地,即可兑换物品。
CDKEY就像钥匙,只不过这把钥匙打开的不是门,而是一个礼品兑换码。
CDKEY的组成一般是由大写或小写英文字母和阿拉伯数字组成,密钥有多少字符由官方协定,没有固定字符数量。
扩展资料:
DNF的CDKEY兑换流程:
1.在搜索引擎中搜索关键词“DNFCDK”,选择第一个官方网站。
2.在界面“奖品中心”中,在“请输入CDKEY”这一栏输入自己的礼品密钥。
3.选择自己需要领取此礼包的账号,点击选择“区服”“服务器”再选择角色。
4.最后一步输入右侧的验证码,点击界面中的“确定”即可领取礼品。
参考资料来源:百度百科—CDKEY
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)