Fix loading FITS
This commit is contained in:
+22
-15
@@ -111,20 +111,19 @@ bool loadFITS(QString path, ImageInfoData &info, RawImageAbs **image, QImage *qi
|
|||||||
long naxes[2];
|
long naxes[2];
|
||||||
fits_get_img_param(file, 2, &imgtype, &naxis, naxes, &status);
|
fits_get_img_param(file, 2, &imgtype, &naxis, naxes, &status);
|
||||||
|
|
||||||
if(naxis == 2 && status == 0)
|
if(naxis >= 2 && naxis <= 3 && status == 0)
|
||||||
{
|
{
|
||||||
std::vector<uint8_t> bits8;
|
std::vector<uint8_t> bits8;
|
||||||
std::vector<uint16_t> bits16;
|
std::vector<uint16_t> bits16;
|
||||||
std::vector<uint32_t> bits32;
|
std::vector<uint32_t> bits32;
|
||||||
long fpixel[2] = {1,1};
|
long fpixel[3] = {1,1,1};
|
||||||
|
|
||||||
size_t size = naxes[0]*naxes[1];
|
size_t size = naxes[0]*naxes[1];
|
||||||
uchar *data = nullptr;
|
size_t w = naxes[0];
|
||||||
|
size_t h = naxes[1];
|
||||||
if(qimage)
|
if(qimage)
|
||||||
{
|
|
||||||
*qimage = QImage(naxes[0], naxes[1], QImage::Format_Grayscale8);
|
*qimage = QImage(naxes[0], naxes[1], QImage::Format_Grayscale8);
|
||||||
data = qimage->bits();
|
|
||||||
}
|
|
||||||
info.append(StringPair(QObject::tr("Width"), QString::number(naxes[0])));
|
info.append(StringPair(QObject::tr("Width"), QString::number(naxes[0])));
|
||||||
info.append(StringPair(QObject::tr("Height"), QString::number(naxes[1])));
|
info.append(StringPair(QObject::tr("Height"), QString::number(naxes[1])));
|
||||||
|
|
||||||
@@ -134,10 +133,10 @@ bool loadFITS(QString path, ImageInfoData &info, RawImageAbs **image, QImage *qi
|
|||||||
bits8.resize(size);
|
bits8.resize(size);
|
||||||
fits_read_pix(file, TBYTE, fpixel, size, NULL, &bits8[0], NULL, &status);
|
fits_read_pix(file, TBYTE, fpixel, size, NULL, &bits8[0], NULL, &status);
|
||||||
if(status)break;
|
if(status)break;
|
||||||
if(data)
|
if(qimage)
|
||||||
{
|
{
|
||||||
for(size_t i=0; i<size; i++)
|
for(size_t i=0; i<h; i++)
|
||||||
data[i] = bits8[i];
|
memcpy(qimage->scanLine(i), &bits8[i*w], w*sizeof(uint8_t));
|
||||||
}
|
}
|
||||||
if(image)*image = new RawImage<uint8_t>(naxes[0], naxes[1], bits8);
|
if(image)*image = new RawImage<uint8_t>(naxes[0], naxes[1], bits8);
|
||||||
break;
|
break;
|
||||||
@@ -145,10 +144,14 @@ bool loadFITS(QString path, ImageInfoData &info, RawImageAbs **image, QImage *qi
|
|||||||
bits16.resize(size);
|
bits16.resize(size);
|
||||||
fits_read_pix(file, TUSHORT, fpixel, size, NULL, &bits16[0], NULL, &status);
|
fits_read_pix(file, TUSHORT, fpixel, size, NULL, &bits16[0], NULL, &status);
|
||||||
if(status)break;
|
if(status)break;
|
||||||
if(data)
|
if(qimage)
|
||||||
{
|
{
|
||||||
for(size_t i=0; i<size; i++)
|
for(size_t i=0; i<h; i++)
|
||||||
data[i] = bits16[i] >> 8;
|
{
|
||||||
|
uchar *scanline = qimage->scanLine(i);
|
||||||
|
for(size_t o=0;o<w;o++)
|
||||||
|
scanline[o] = bits16[i*w+o] >> 8;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if(image)*image = new RawImage<uint16_t>(naxes[0], naxes[1], bits16);
|
if(image)*image = new RawImage<uint16_t>(naxes[0], naxes[1], bits16);
|
||||||
break;
|
break;
|
||||||
@@ -156,10 +159,14 @@ bool loadFITS(QString path, ImageInfoData &info, RawImageAbs **image, QImage *qi
|
|||||||
bits32.resize(size);
|
bits32.resize(size);
|
||||||
fits_read_pix(file, TUINT, fpixel, size, NULL, &bits32[0], NULL, &status);
|
fits_read_pix(file, TUINT, fpixel, size, NULL, &bits32[0], NULL, &status);
|
||||||
if(status)break;
|
if(status)break;
|
||||||
if(data)
|
if(qimage)
|
||||||
{
|
{
|
||||||
for(size_t i=0; i<size; i++)
|
for(size_t i=0; i<h; i++)
|
||||||
data[i] = bits32[i] >> 24;
|
{
|
||||||
|
uchar *scanline = qimage->scanLine(i);
|
||||||
|
for(size_t o=0;o<w;o++)
|
||||||
|
scanline[o] = bits32[i*w+o] >> 24;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if(image)*image = new RawImage<uint32_t>(naxes[0], naxes[1], bits32);
|
if(image)*image = new RawImage<uint32_t>(naxes[0], naxes[1], bits32);
|
||||||
break;
|
break;
|
||||||
|
|||||||
Reference in New Issue
Block a user