Skip to content

Commit

Permalink
Merge pull request #2 from jrudolph/spacegaier-speed-up-volume-viewer
Browse files Browse the repository at this point in the history
reuse volume buffers for volume display to avoid extra copies and conversions
  • Loading branch information
spacegaier authored Dec 13, 2023
2 parents f9003bd + cc52b7b commit 6dbd9be
Showing 1 changed file with 10 additions and 4 deletions.
14 changes: 10 additions & 4 deletions apps/VC/CWindow.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1627,15 +1627,14 @@ void CWindow::startPrefetching(int index) {
// Open slice
void CWindow::OpenSlice(void)
{
QImage aImgQImage;
cv::Mat aImgMat;
if (fVpkg != nullptr) {
// Stop prefetching
prefetchSliceIndex = -1;
cv.notify_one();

aImgMat = currentVolume->getSliceDataCopy(fPathOnSliceIndex);
aImgMat.convertTo(aImgMat, CV_8UC1, 1.0 / 256.0);
// cvtColor(aImgMat, aImgMat, cv::COLOR_GRAY2BGR);
aImgMat = currentVolume->getSliceData(fPathOnSliceIndex);
} else {
aImgMat = cv::Mat::zeros(10, 10, CV_8UC1);
}
Expand All @@ -1655,7 +1654,14 @@ void CWindow::OpenSlice(void)
params.thickness, params.baseline);
}

auto aImgQImage = Mat2QImage(aImgMat);
if (aImgMat.isContinuous() && aImgMat.type() == CV_16U) {
// create QImage directly backed by cv::Mat buffer
aImgQImage = QImage(
aImgMat.ptr(), aImgMat.cols, aImgMat.rows, aImgMat.step,
QImage::Format_Grayscale16);
} else
aImgQImage = Mat2QImage(aImgMat);

fVolumeViewerWidget->SetImage(aImgQImage);
fVolumeViewerWidget->SetImageIndex(fPathOnSliceIndex);
}
Expand Down

0 comments on commit 6dbd9be

Please sign in to comment.