summaryrefslogtreecommitdiff
path: root/gr-qtgui/lib/freq_sink_c_impl.cc
diff options
context:
space:
mode:
Diffstat (limited to 'gr-qtgui/lib/freq_sink_c_impl.cc')
-rw-r--r--gr-qtgui/lib/freq_sink_c_impl.cc34
1 files changed, 34 insertions, 0 deletions
diff --git a/gr-qtgui/lib/freq_sink_c_impl.cc b/gr-qtgui/lib/freq_sink_c_impl.cc
index ff40ff3f43..a95814eb9a 100644
--- a/gr-qtgui/lib/freq_sink_c_impl.cc
+++ b/gr-qtgui/lib/freq_sink_c_impl.cc
@@ -69,6 +69,13 @@ namespace gr {
d_argv = new char;
d_argv[0] = '\0';
+ // setup output message port to post frequency when display is
+ // double-clicked
+ message_port_register_out(pmt::mp("freq"));
+ message_port_register_in(pmt::mp("freq"));
+ set_msg_handler(pmt::mp("freq"),
+ boost::bind(&freq_sink_c_impl::handle_set_freq, this, _1));
+
d_main_gui = NULL;
// Perform fftshift operation;
@@ -444,6 +451,32 @@ namespace gr {
}
}
+ void
+ freq_sink_c_impl::check_clicked()
+ {
+ if(d_main_gui->checkClicked()) {
+ d_center_freq = d_main_gui->getClickedFreq();
+ double norm_freq = d_center_freq / d_bandwidth;
+ message_port_pub(pmt::mp("freq"),
+ pmt::cons(pmt::mp("freq"),
+ pmt::from_double(norm_freq)));
+ }
+ }
+
+ void
+ freq_sink_c_impl::handle_set_freq(pmt::pmt_t msg)
+ {
+ if(pmt::is_pair(msg)) {
+ pmt::pmt_t x = pmt::cdr(msg);
+ if(pmt::is_real(x)) {
+ double freq = pmt::to_double(x);
+ d_center_freq = freq*d_bandwidth;
+ d_qApplication->postEvent(d_main_gui,
+ new SetFreqEvent(d_center_freq, d_bandwidth));
+ }
+ }
+ }
+
int
freq_sink_c_impl::work(int noutput_items,
gr_vector_const_void_star &input_items,
@@ -455,6 +488,7 @@ namespace gr {
// Update the FFT size from the application
fftresize();
windowreset();
+ check_clicked();
for(int i=0; i < noutput_items; i+=d_fftsize) {
unsigned int datasize = noutput_items - i;