将字节转换为int

时间:2015-11-19 00:26:48

标签: java int type-conversion byte mask

在我的项目中我需要打开SEQ文件,所以我使用FileInputStream,它需要将数据加载到字节数组。但是因为每个像素都得到错误的值(因为它们是整数)。

下面在我的代码中你可以看到我把像素放在2d数组中,为此我计算像素的每个值,在行中:

 wart =(int) (buf[offset]) +(int)(buf[offset+1]) * 255;

我知道由于字节输入格式的值是错误的(前两个像素也称为double 152,109692453756 and 152,068644316116但在我的Java函数中它们得到 - 2474, -690

我尝试使用面具:

wart =(int) (buf[offset]<< 8) & 0x0000ff00 +(int)(buf[offset+1])& 0x000000ff * 255  ;

它有点帮助(值不是负数,但它们“移位”太多(前两个像素19456, 18944) 我不知道如何解决这个问题。我知道面具应该是不同的,但我不知道如何设置它。

    public class Sekwencja2 {
    @SuppressWarnings("empty-statement")
    public double[] sekwencja2(String nazwa,int nr_klatki) throws FileNotFoundException, IOException{            
                        InputStream is = null;
                        DataInputStream dis = null;                           
                        is = new FileInputStream(nazwa);
                        dis = new DataInputStream(is);                            
                        int length = dis.available();
                        byte[] buf = new byte[length];                           
                        dis.readFully(buf);                            
                        int l_klatek = ((length-158864)/158864)+1;                            
                        int width = 320;
                        int height = 240;
                        int C1=21764040;
                        double C2=3033.3;
                        double C3=134.06;
                        int z = 0;
                        double[] oneDArray = new double[width*height];                            
                        double [][] pixels = new double[width][height];                       

                        int offset =0;
                        char type;
                        String typeText;
                        type=(char)buf[0];
                        typeText =Character.toString(type);
                        switch (typeText) {
                            case "A":
                            if(nr_klatki == 1)
                            offset= 696;
                            else 
                            offset = 158136+(nr_klatki-1)*569+(nr_klatki-2)*(320*240*2+3839);
                            break;
                            case "F":
                            offset=(nr_klatki-1)*158864 + 1373;
                            break;
                            }                          

                        int wart = 0 ;                            
                        for(int x = 0; x<320; x++){
                         for (int y = 0; y<240;y++){
                             switch (typeText){
                                 case "A":
                                     if(nr_klatki==1)
                                         wart =(int) (buf[offset]) +(int)(buf[offset+1]) * 255;
                                     else
                                         wart = (int)(buf[offset]<< 8)& 0x0000ff00 +(int)(buf[offset+1])&0xff*255   ;
                                     break;
                                 case "F":
                                     wart = (buf[offset]<< 8)& 0x0000ff00  +(buf[offset+1])& 0x000000ff * 255  ;
                                     break;
                             }


                              System.out.print(", "+wart);

                               pixels[x][y]=wart;
                                 offset = offset+2;                                      
                         }
                        }
                        for(int i = 0; i < width; i ++)
                                {
                            System.arraycopy(pixels[i], 0, oneDArray, i * height, height);
                                }                       

        return oneDArray;
    }
}

我知道这是一团糟,很多事情都被评论了:)

2 个答案:

答案 0 :(得分:0)

首先掩盖,像这样:

wart = (buf[offset] & 0xFF) | ((buf[offset+1] & 0xFF) << 8);

答案 1 :(得分:0)

255错了

它的256,你总是要乘以你操作的基数的倍数,255不是2的倍数

类似于:

以你的方式将111从基数10转换为基数10

1 * 99 + 1 * 9 + 1 = 109

所以109!= 111这是错误的,同样乘以255将改变你尝试从二进制转换为二进制的任何数字。