projects
/
pulseview.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Update cursor action's state whenever the cursor state changes
[pulseview.git]
/
pv
/
popups
/
channels.hpp
diff --git
a/pv/popups/channels.hpp
b/pv/popups/channels.hpp
index 6fe9159d3f854f862b989645fb6b410001a848e8..e486768f001e4ad76edef29eb1549d39cde8c79b 100644
(file)
--- a/
pv/popups/channels.hpp
+++ b/
pv/popups/channels.hpp
@@
-20,19
+20,25
@@
#ifndef PULSEVIEW_PV_POPUPS_CHANNELS_HPP
#define PULSEVIEW_PV_POPUPS_CHANNELS_HPP
#ifndef PULSEVIEW_PV_POPUPS_CHANNELS_HPP
#define PULSEVIEW_PV_POPUPS_CHANNELS_HPP
+#include <functional>
#include <map>
#include <memory>
#include <vector>
#include <map>
#include <memory>
#include <vector>
+#include <QCheckBox>
#include <QFormLayout>
#include <QFormLayout>
+#include <QGridLayout>
#include <QHBoxLayout>
#include <QHBoxLayout>
+#include <QLabel>
#include <QPushButton>
#include <QSignalMapper>
#include <pv/widgets/popup.hpp>
#include <QPushButton>
#include <QSignalMapper>
#include <pv/widgets/popup.hpp>
-class QCheckBox;
-class QGridLayout;
+using std::function;
+using std::map;
+using std::shared_ptr;
+using std::vector;
namespace sigrok {
class ChannelGroup;
namespace sigrok {
class ChannelGroup;
@@
-65,12
+71,14
@@
public:
private:
void set_all_channels(bool set);
private:
void set_all_channels(bool set);
+ void set_all_channels_conditionally(
+ function<bool (const shared_ptr<data::SignalBase>)> cond_func);
- void populate_group(s
td::s
hared_ptr<sigrok::ChannelGroup> group,
- const
std::vector< std::
shared_ptr<pv::data::SignalBase> > sigs);
+ void populate_group(shared_ptr<sigrok::ChannelGroup> group,
+ const
vector<
shared_ptr<pv::data::SignalBase> > sigs);
QGridLayout* create_channel_group_grid(
QGridLayout* create_channel_group_grid(
- const
std::vector< std::
shared_ptr<pv::data::SignalBase> > sigs);
+ const
vector<
shared_ptr<pv::data::SignalBase> > sigs);
private:
void showEvent(QShowEvent *event);
private:
void showEvent(QShowEvent *event);
@@
-80,6
+88,10
@@
private Q_SLOTS:
void enable_all_channels();
void disable_all_channels();
void enable_all_channels();
void disable_all_channels();
+ void enable_all_logic_channels();
+ void enable_all_analog_channels();
+ void enable_all_named_channels();
+ void enable_all_changing_channels();
private:
pv::Session &session_;
private:
pv::Session &session_;
@@
-88,19
+100,20
@@
private:
bool updating_channels_;
bool updating_channels_;
- std::vector< std::shared_ptr<pv::binding::Device> >
- group_bindings_;
- std::map< QCheckBox*, std::shared_ptr<pv::data::SignalBase> >
+ vector< shared_ptr<pv::binding::Device> > group_bindings_;
+ map< QCheckBox*, shared_ptr<pv::data::SignalBase> >
check_box_signal_map_;
check_box_signal_map_;
+ map< shared_ptr<sigrok::ChannelGroup>, QLabel*> group_label_map_;
QHBoxLayout buttons_bar_;
QHBoxLayout buttons_bar_;
- QPushButton enable_all_channels_;
- QPushButton disable_all_channels_;
+ QPushButton enable_all_channels_, disable_all_channels_;
+ QPushButton enable_all_logic_channels_, enable_all_analog_channels_;
+ QPushButton enable_all_named_channels_, enable_all_changing_channels_;
QSignalMapper check_box_mapper_;
};
QSignalMapper check_box_mapper_;
};
-}
//
popups
-}
//
pv
+}
// namespace
popups
+}
// namespace
pv
#endif // PULSEVIEW_PV_POPUPS_CHANNELS_HPP
#endif // PULSEVIEW_PV_POPUPS_CHANNELS_HPP