原文出处: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)是不是太大了?

08-31 08:46