Что я хочу сделать
- Файл : TIFF, 2 страницы, оттенки серого, 16 бит
- OpenCV : 2x Mat, Greyscale, 16bit (CV_16UC1)
- Qt : 2x QImage, Greyscale, 8bit (Format_Greyscale8)
Я хочу прочитать 16-битный Tiff, а затем преобразовать его, чтобы показать его как 8-битный.
Чтение
void ImgProc::Load_Image_2xTiff_16bit_G(Mat *Mat_A_in, Mat *Mat_B_in, string file_name)
{
vector<Mat> vec_Mat;
vec_Mat.reserve(2);
imreadmulti(file_name, vec_Mat);
*Mat_A_in = vec_Mat[0];
*Mat_B_in = vec_Mat[1];
}
Преобразование
void ImgProc::Convert_Mat16_2_QIm8(QImage *QIm_Out, Mat *Mat_In, double scale_factor)
{
unsigned int rows = Mat_In->rows;
unsigned int cols = Mat_In->cols;
*QIm_Out = QImage(cols, rows, QImage::Format_Grayscale8);
unsigned char* line_QIm;
if (!Mat_In->data)
return;
for(unsigned int y = 0; y < rows; y++)
{
line_QIm = QIm_Out->scanLine(y);
for(unsigned int x = 0; x < cols; x++)
{
line_QIm[x] = (unsigned char)(Mat_In->at<ushort>(y, x) * scale_factor);
}
}
}
Проблема
Когда я использую Mat_In->at<ushort>(y, x)
(читай 16 бит), он падает с abort() has been called
. То же самое происходит, если я использую <short>
вместо.
Когда я использую Mat_In->at<uchar>(y, x)
(чтение 8 бит), это работает, но обрезает информацию без масштабирования. Это проявляется в виде «черных дыр» в более ярких областях изображения, вероятно, из-за переполнения.
Думаю, я должен отметить, что камера, которая делала снимки, использует только 14-битную глубину.