繁体   English   中英

C / C ++十六进制char *到字节数组

[英]C/C++ Hex char* to byte array

我一段时间以来一直在尝试如何在嵌入式C ++中执行此操作,对于RGB888中的网站,我有一个十六进制颜色,例如“#ba00ff”,我想将其转换为C ++ RGB555十六进制值,例如0x177C

目前,我已经从字符串中修剪了#,并一直坚持将其转换为可用于创建RGB555的类型

我的代码目前看起来像

 p_led_struct->color = "#ba00ff";
 char hexString[7] = {};
 memmove(hexString, p_led_struct->color+1, strlen(p_led_struct->color));
 byte colorBytes[3];
 sscanf(hexString,"%x%x%x",&colorBytes);

尽管colorBytes数组的数据不正确,hexString值仍正确变为“ ba00ff”。

我应该如何进行此转换的任何帮助都将非常棒:)

谢谢!

sscanf(hexString,"%x%x%x",&colorBytes); 是:

  1. sscanf希望您给出3个int作为参数,但只给出一个数组,而不是int
  2. 单个%x读取超过2个字符。

尝试:

int r, g, b;
if(sscanf(hexString,"%2x%2x%2x", &r, &g, &b) != 3) {
     // error
}

编辑:

关于scanf系列的非常有用的信息: http : //en.cppreference.com/w/c/io/fscanf

p_led_struct->color转换为整数

p_led_struct->color = "#ba00ff";
unsigned int colorValue = strtoul(p_led_struct->color+1, NULL, 16);

并将此RGB值转换为RGB555。 RGB整数的字段为0000.0000.rrrr.rrrr.gggg.gggg.bbbb.bbbb,而RGB555的字段为0rrr.rrgg.gggb.bbbb,因此我们只需要移位:

unsigned short rgb555 = ((colorValue & 0x00f80000) >> 9) +  // red
  ((colorValue & 0x0000f800) >> 7) +  // green
  ((colorValue & 0x000000f8) >> 3);  // blue

使用hh修饰符直接扫描到1个字节。

p_led_struct->color = "#ba00ff";
byte colorBytes[3];
int result;
result = sscanf( p_led_struct->color, "#%2hhx%2hhx%2hhx", &colorBytes[0], 
    &colorBytes[1], &colorBytes[2]);
if (result != 3) {
  ; // handle problem
}

成功扫描3个RGB 8位字节后,重新计算3x5位结果。

int r,g,b;
r = colorBytes[0] >> 3;
g = colorBytes[1] >> 3;
b = colorBytes[2] >> 3;
printf("%04X", (r << 10) | (g << 5) | (b << 0));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM