其实个人感觉还是代码重要,因为不读卡,哪里来的防冲突,其实防冲突讲了这么多实现起来也就是一个函数
status = PcdRequest(PICC_REQALL, g_ucTempbuf);
//PICC_REQALL他是个宏定义 意思是寻找天线内的所有卡片,
// g_ucTempbuf 是个数组,在这里函数读取卡内的前两位放在数组中
status = PcdAnticoll(g_ucTempbuf);//防冲突
这里有点意思的是,有的时候要实行判断卡的种类,这里有个片段,应该可以用到程序上去
判断卡的种类,判断读卡的时候返回的第一位数据,其他的函数用的是12864的,这里大家不必去深究
//有卡则判断是什么卡,然后显示在液晶上
// 0x4400 = Mifare_UltraLight
// 0x0400 = Mifare_One(S50)
// 0x0200 = Mifare_One(S70)
// 0x0800 = Mifare_Pro(X)
// 0x4403 = Mifare_DESFire
switch(g_ucTempbuf[0])
{
case 0x44:
ck12864_com(0x93);
for(i=0;i《10;i++)
{
ck12864_data(leixing1[i]);
}
break;
case 0x02:
ck12864_com(0x93);
for(i=0;i《8;i++)
{
ck12864_data(leixing2[i]);
}
break;
case 0x04:
ck12864_com(0x93);
for(i=0;i《8;i++)
{
ck12864_data(leixing3[i]);
}
break;
case 0x08:
ck12864_com(0x93);
for(i=0;i《6;i++)
{
ck12864_data(leixing4[i]);
}
break;
}
接下来就是流程3,选中卡片,对卡片进行操作,根据datasheet,被选中的卡的序列码,并同时返回卡的容量:
代码实现:
status = PcdSelect(g_ucTempbuf);
流程4,也就是对选中的卡片进行操作,首先进行密码的核实,这里包括读写操作
代码的实现,也是两句话:
status = PcdAuthState(PICC_AUTHENT1A, 5, DefaultKey, g_ucTempbuf);