原文出处:https://stackoverflow.com/questions/4801366/convert-rgb-values-to-integer
原版:
存储时:
int rgb = red;
rgb = (rgb << 8) + green;
rgb = (rgb << 8) + blue;
获得时:
int red = (rgb >> 16) & 0xFF;
int green = (rgb >> 8) & 0xFF;
int blue = rgb & 0xFF;
改良:
save R,G,B,A:
RGB最大值为225,一个需要用8位存储。A最大值为100,也算8位存储。
int rgba = r;
rgba = (rgba << 8) + g;
rgba = (rgba << 8) + b;
rgba = (rgba << 8) + a;
pixels[xc+yc*width] = rgba // 在第y行x列保存这个点
get R,G,B,A:
通过右移将要取的8位二进制放在最右边,与0xff (0000 0000 1111 1111)做“与”操作
public int getRed(int xc, int yc) {
return pixels[xc+yc*width] >> 24 & 0xFF;
}
public int getGreen(int xc, int yc) {
return pixels[xc+yc*width] >> 16 & 0xFF;
}
public int getBlue(int xc, int yc) {
return pixels[xc+yc*width] >> 8 & 0xFF;
}
public int getAlpha(int xc, int yc) {
return pixels[xc+yc*width] & 0xFF;
}
但是这个方法的alpha加上去是越界的,这是为什么呢?
int a = 0;
System.out.println("初始化:" + a);
a = (a << 8) + 255;// 8个1
System.out.println("加1个数:" + a);
a = (a << 8) + 255;// 16个1
System.out.println("加2个数:" + a);
a = (a << 8) + 255;// 24 个 1
System.out.println("加3个数:" + a);
a = (a << 8) + 255;// 32个1
System.out.println("加4个数:" + a);
为了找出哪里出问题,写了上面的代码,输出:
初始化:0
加1个数:255
加2个数:65535
加3个数:16777215
加4个数:-1
看似数据越界了,把int改成long就行了。
但有没有可能是32位最高位是符号位,最多存31个二进制的意思呢…
这一个图就是600900个long,一个long大小是64bit,8byte,
600
900*8=4320 000byte(4.12Mb)是不是太大了?