jpegpixels
是一个具有高度、宽度和RGB大小的3D int数组(0=红色,1=绿色,2=蓝色)。pixelmatrix
是具有8x8块大小的二维int数组到目前为止,代码工作正常,因为我得到了一个结果图像。下面是将像素分组为8x8的代码的部分示例(它只显示了2行,因为代码太长)。
int [][][] jpegPixels = new int[h][w][3]; //h = height size, w = width size
int [][] pixelMatrix = new int [8][8];
for(int i=6; i<jpegPixels.length-7; i++)
{
for(int j=6; j<jpegPixels[0].length-7; j++)
{
for(int x=0; x<2; x++)
{
//************ ROW 1 ******************
//********** Pixel 1 ********************
pixelMatrix[0][0] = jpegPixels[i-1][j-1][x];
//********** Pixel 2 ********************
pixelMatrix[0][1] = jpegPixels[i-1][j][x];
//********** Pixel 3 ********************
pixelMatrix[0][2] = jpegPixels[i-1][j+1][x];
//********** Pixel 4 ********************
pixelMatrix[0][3] = jpegPixels[i-1][j+2][x];
//********** Pixel 5 ********************
pixelMatrix[0][4] = jpegPixels[i-1][j+3][x];
//********** Pixel 6 ********************
pixelMatrix[0][5] = jpegPixels[i-1][j+4][x];
//********** Pixel 7 ********************
pixelMatrix[0][6] = jpegPixels[i-1][j+5][x];
//********** Pixel 8 ********************
pixelMatrix[0][7] = jpegPixels[i-1][j+6][x];
//************ ROW 2 ******************
//********** Pixel 9 ********************
pixelMatrix[1][0] = jpegPixels[i][j-1][x];
//********** Pixel 10 ********************
pixelMatrix[1][1] = jpegPixels[i][j][x];
//********** Pixel 11 ********************
pixelMatrix[1][2] = jpegPixels[i][j+1][x];
//********** Pixel 12 ********************
pixelMatrix[1][3] = jpegPixels[i][j+2][x];
//********** Pixel 13 ********************
pixelMatrix[1][4] = jpegPixels[i][j+3][x];
//********** Pixel 14 ********************
pixelMatrix[1][5] = jpegPixels[i][j+4][x];
//********** Pixel 15 ********************
pixelMatrix[1][6] = jpegPixels[i][j+5][x];
//********** Pixel 16 ********************
pixelMatrix[1][7] = jpegPixels[i][j+6][x];
//********** Pixel 17 - 64 ********************
// ******* Too long to print the rest ********
}
}
}
有人能识别出这是正确的方法将值分组为8x8块的3D数组的h x w大小吗?原因是,当我测试打印出原始像素和结果像素的值时,我从更高的OFSET中得到结果像素的值?
希望这是清楚的。谢谢
我不确定你的像素是如何在你的例子中表示的。因此,我选择使用本教程中的BufferedImage类表示像素的方式。如果需要更改像素表示为int的方式,可以编辑getIntFromPixel方法。
private int getIntFromPixel(int[] pixel)
{
int r = pixel[0];
int g = pixel[1];
int b = pixel[2];
return (r << 16) | (g << 8) | b;
}
// Returns the sub array with upper-left corner at [start_i][start_j] with
// width sub_w and height sub_h.
public int[][] getSubArray(int[][][] pixelArray, int start_i, int start_j
, int sub_w, int sub_h)
{
int[][] subArray = new int[sub_w][sub_h];
for (int i = 0; i < sub_w; i++) {
for (int j = 0; j < sub_h ; j++) {
subArray[i][j] = getIntFromPixel(pixelArray[start_i + i][start_j + j]);
}
}
return subArray;
}
例如,现在给出一个3x3数组
pixelArray = {
{{1,1,1}, {2,2,2}, {3,3,3}},
{{4,4,4}, {5,5,5}, {6,6,6}},
{{7,7,7}, {8,8,8}, {9,9,9}}
}
如果我们想在[0][0]处获得2x2像素子阵列:
{{{1,1,1}, {2,2,2}}, {{4,4,4}, {5,5,5}}}
getSubArray(pixel, 0, 0, 2, 2);
{{65793, 131586}, {263172, 328965}}
我在下面的代码中使用了嵌套的for循环,并且我有一些条件来中断内部的for循环,这提高了代码的性能。 现在,如何使用 Java 8 流来执行相同的逻辑?我想出了下面的代码: 在这里,我不能在java流中使用< code>break语句,所以我使用了< code>return语句,但它仍然运行内部循环,因为它不会中断内部循环,所以性能没有提高。
问题内容: 我有一个大小为300000的数组,我希望它将其分成2个相等的部分。这里有什么方法可以用来实现这个目标? 它会比for循环操作更快还是对性能没有影响? 问题答案: 您可以使用。
我试图在for循环中获得for循环,因此输出如下: 我希望输出显示一个正方形 我不知道它为什么不这样做。下面是我的代码:
问题:我能否使用Java流API(即一行)实现方法。需要变量来定义字符串的长度;我尝试为每个循环,但它不工作。我需要一个循环的范围。 我的尝试:
问题内容: 我正在努力理解为什么我的代码处于一种状态而不是另一种状态。自从我讲完指针已经有一段时间了,所以我可能会生锈! 基本上,我有一个用于将对象存储在内存中的具有功能的存储库结构。 因此,它所做的全部工作就是将RW互斥锁锁定在其上,并将指针添加到由标识符引用的映射中。 然后,我得到了一个功能,该功能将基本上遍历这些对象的一部分,并将它们全部存储在存储库中。 上面的方法不起作用,看起来一开始一切
本文向大家介绍Java中break、continue、return在for循环中的使用,包括了Java中break、continue、return在for循环中的使用的使用技巧和注意事项,需要的朋友参考一下 引言:在使用循环的时候,循环里面带有break、continue、return的时候经常弄混,今天特意整理了下,以待后用... 打印结果: 打印结果: 打印结果: 内层for循环结束… 打印