4 #include <visp3/ustk_core/usConfig.h>
6 #if (defined(USTK_HAVE_QT5) || defined(USTK_HAVE_VTK_QT)) && (defined(VISP_HAVE_X11) || defined(VISP_HAVE_GDI)) && \
7 defined(USTK_HAVE_FFTW)
9 #include <QApplication>
10 #include <QtCore/QThread>
12 #include <visp3/ustk_core/usRFToPreScan2DConverter.h>
13 #include <visp3/ustk_elastography/usElastography.h>
14 #include <visp3/ustk_grabber/usNetworkGrabberRF2D.h>
16 #include <visp3/gui/vpDisplayGDI.h>
17 #include <visp3/gui/vpDisplayX.h>
18 #include <visp3/io/vpImageIo.h>
20 int main(
int argc,
char **argv)
23 QApplication app(argc, argv);
26 elastography->
setROI(40, 3200, 50, 500);
45 vpImage<unsigned char> strainImage;
48 #if defined(VISP_HAVE_X11)
49 vpDisplayX *displayEcho = NULL;
50 vpDisplayX *displayElas = NULL;
51 #elif defined(VISP_HAVE_GDI)
52 vpDisplayGDI *displayEcho = NULL;
53 vpDisplayGDI *displayElas = NULL;
55 bool displayInit =
false;
56 bool captureRunning =
true;
63 std::cout <<
"waiting ultrasound initialisation..." << std::endl;
68 grabbedFrame = qtGrabber->
acquire();
70 std::cout <<
"MAIN THREAD received frame No : " << grabbedFrame->
getFrameCount() << std::endl;
72 elastography->
updateRF(*grabbedFrame);
73 strainImage = elastography->
run();
75 converter.
convert(*grabbedFrame, preScanImage);
78 if (!displayInit && strainImage.getHeight() != 0 && strainImage.getWidth() != 0) {
79 #if defined(VISP_HAVE_X11)
80 displayEcho =
new vpDisplayX(preScanImage);
81 displayElas =
new vpDisplayX(strainImage);
82 #elif defined(VISP_HAVE_GDI)
83 displayEcho =
new vpDisplayGDI(preScanImage);
84 displayElas =
new vpDisplayGDI(strainImage);
91 vpDisplay::display(preScanImage);
92 vpDisplay::displayRectangle(preScanImage, 320, 40, 50, 50, vpColor::red);
93 vpDisplay::display(strainImage);
94 vpDisplay::flush(preScanImage);
95 vpDisplay::flush(strainImage);
102 }
while (captureRunning);
114 std::cout <<
"You should intall Qt5 (with wigdets and network modules), FFTW and a display graphic system (GDI or "
115 "X11) to run this tutorial"
Computation of a strain map using two sucessive RF images acquired at different compressions of the p...
vpImage< unsigned char > run()
void setROI(int tx, int ty, int tw, int th)
void updateRF(const usImageRF2D< short int > &image)
Class to store additionnal informations arriving on the network with ultrasound images grabbed,...
quint32 getFrameCount() const
Specific class to grab RF frames from the ultrasound station on the network.
bool isFirstFrameAvailable()
usFrameGrabbedInfo< usImageRF2D< short int > > * acquire()
bool initAcquisition(const usNetworkGrabber::usInitHeaderSent &header)
void setIPAddress(const std::string &s_ip)
2D conversion from RF signal to pre-scan image
void convert(const usImageRF2D< short int > &rfImage, usImagePreScan2D< unsigned char > &preScanImage)