[英]8bit to 16bit conversion
我有一个捕获8位的图像。 我想将8位值转换为16位。 我使用了以下内容
short temp16 = (short)val[i] << 8 ;
其中val
是8位样本的数组。
以上陈述令人吵闹。 任何人都可以建议一种8位到16位转换的方法吗?
val []是签名还是未签名8位? 把它投射到无符号(假设你有通常的惯例0 =最暗,255 =最亮)然后把它投射到签名的短(我假设你想要的,因为普通的'短'是默认签名)。
纯粹的位移不会给你纯白色。 0xff << 8 == 0xff00,而不是预期的0xffff。
一个技巧是使用val [i] << 8 + val [i]并记住正确的数据类型(大小,符号)。 这样你得到0x00 - > 0x0000和0xff - > 0xffff。
这里给出了一个很好的例子: 将两个uint8_t单词转换为uint16_t和uint16_t中的一个单词转换为两个uint8_t 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.