這主要是在列印中有需求
示例1
這個寫的有點傻,總之還是需要逐一去判斷,然後将一個byte資料按照4bit拆開,再轉成ASCII碼顯示
#define OTP_SIZE (255)
char tmp_opt[OTP_SIZE*2+1]={0};
for(int i=0;i
{
if((sd->otp_data[i] >> 4)<=0x09)
{
tmp_opt[2*i] = (sd->otp_data[i] >> 4) + '0';
}
else if((sd->otp_data[i] >> 4)<=0x0F)
{
tmp_opt[2*i] = (sd->otp_data[i] >> 4)+ 'A' - 9;
}
if((sd->otp_data[i] & 0x0F)<=0x09)
{
tmp_opt[2*i+1] = (sd->otp_data[i] & 0x0F) + '0';
}
else if((sd->otp_data[i] & 0x0F)<=0x0F)
{
tmp_opt[2*i+1] = (sd->otp_data[i] & 0x0F) + 'A' - 9;
}
}
LOGD("opt: %s\n",tmp_opt);
示例2
這是個進階的版本
int HextoChar(uint8_t *u8, uint8_t len, char *ch)
{
uint8_t tmp = 0x00;
for (int i = 0; i < len; i++)
{
for (int j = 0; j < 2; j++)
{
tmp = (*(u8 + i) >> 4) * (1 - j) + (*(u8 + i) & 0x0F) * j;
if (tmp >= 0 && tmp <= 9)
{
ch[2 * i + j] = tmp + '0';
}
else if (tmp >= 0x0A && tmp <= 0x0F)
{
ch[2 * i + j] = tmp - 0x0A + 'A';
}
}
}
return 0;
}