mirror of
https://github.com/eried/portapack-mayhem.git
synced 2025-01-12 07:49:32 -05:00
Extract AISRecentEntries from AISView.
This commit is contained in:
parent
01741f3c7c
commit
2888257167
@ -99,55 +99,21 @@ void AISLogger::on_packet(const ais::Packet& packet) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace ui {
|
void AISRecentEntries::on_packet(const ais::Packet& packet) {
|
||||||
|
|
||||||
AISView::AISView() {
|
|
||||||
flags.focusable = true;
|
|
||||||
|
|
||||||
EventDispatcher::message_map().register_handler(Message::ID::AISPacket,
|
|
||||||
[this](Message* const p) {
|
|
||||||
const auto message = static_cast<const AISPacketMessage*>(p);
|
|
||||||
const ais::Packet packet { message->packet };
|
|
||||||
if( packet.is_valid() ) {
|
|
||||||
this->logger.on_packet(packet);
|
|
||||||
this->on_packet(packet);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
receiver_model.set_baseband_configuration({
|
|
||||||
.mode = 3,
|
|
||||||
.sampling_rate = 2457600,
|
|
||||||
.decimation_factor = 1,
|
|
||||||
});
|
|
||||||
receiver_model.set_baseband_bandwidth(1750000);
|
|
||||||
}
|
|
||||||
|
|
||||||
AISView::~AISView() {
|
|
||||||
EventDispatcher::message_map().unregister_handler(Message::ID::AISPacket);
|
|
||||||
}
|
|
||||||
|
|
||||||
void AISView::truncate_entries() {
|
|
||||||
while(recent.size() > 64) {
|
|
||||||
recent.pop_back();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void AISView::on_packet(const ais::Packet& packet) {
|
|
||||||
const auto source_id = packet.source_id();
|
const auto source_id = packet.source_id();
|
||||||
auto matching_recent = std::find_if(recent.begin(), recent.end(),
|
auto matching_recent = std::find_if(entries.begin(), entries.end(),
|
||||||
[source_id](const AISRecentEntry& entry) { return entry.mmsi == source_id; }
|
[source_id](const AISRecentEntry& entry) { return entry.mmsi == source_id; }
|
||||||
);
|
);
|
||||||
if( matching_recent != recent.end() ) {
|
if( matching_recent != entries.end() ) {
|
||||||
// Found within. Move to front of list, increment counter.
|
// Found within. Move to front of list, increment counter.
|
||||||
recent.push_front(*matching_recent);
|
entries.push_front(*matching_recent);
|
||||||
recent.erase(matching_recent);
|
entries.erase(matching_recent);
|
||||||
} else {
|
} else {
|
||||||
recent.emplace_front(source_id);
|
entries.emplace_front(source_id);
|
||||||
truncate_entries();
|
truncate_entries();
|
||||||
}
|
}
|
||||||
|
|
||||||
auto& entry = recent.front();
|
auto& entry = entries.front();
|
||||||
entry.received_count++;
|
entry.received_count++;
|
||||||
|
|
||||||
switch(packet.message_id()) {
|
switch(packet.message_id()) {
|
||||||
@ -183,6 +149,51 @@ void AISView::on_packet(const ais::Packet& packet) {
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AISRecentEntries::ContainerType::const_iterator AISRecentEntries::find(const ais::MMSI key) const {
|
||||||
|
return std::find_if(
|
||||||
|
begin(), end(),
|
||||||
|
[key](const AISRecentEntry& e) { return e.mmsi == key; }
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
void AISRecentEntries::truncate_entries() {
|
||||||
|
while(entries.size() > entries_max) {
|
||||||
|
entries.pop_back();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace ui {
|
||||||
|
|
||||||
|
AISView::AISView() {
|
||||||
|
flags.focusable = true;
|
||||||
|
|
||||||
|
EventDispatcher::message_map().register_handler(Message::ID::AISPacket,
|
||||||
|
[this](Message* const p) {
|
||||||
|
const auto message = static_cast<const AISPacketMessage*>(p);
|
||||||
|
const ais::Packet packet { message->packet };
|
||||||
|
if( packet.is_valid() ) {
|
||||||
|
this->logger.on_packet(packet);
|
||||||
|
this->on_packet(packet);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
receiver_model.set_baseband_configuration({
|
||||||
|
.mode = 3,
|
||||||
|
.sampling_rate = 2457600,
|
||||||
|
.decimation_factor = 1,
|
||||||
|
});
|
||||||
|
receiver_model.set_baseband_bandwidth(1750000);
|
||||||
|
}
|
||||||
|
|
||||||
|
AISView::~AISView() {
|
||||||
|
EventDispatcher::message_map().unregister_handler(Message::ID::AISPacket);
|
||||||
|
}
|
||||||
|
|
||||||
|
void AISView::on_packet(const ais::Packet& packet) {
|
||||||
|
recent.on_packet(packet);
|
||||||
|
|
||||||
set_dirty();
|
set_dirty();
|
||||||
}
|
}
|
||||||
@ -229,13 +240,13 @@ void AISView::paint(Painter& painter) {
|
|||||||
Rect target_rect { r.pos, { r.width(), s.font.line_height() }};
|
Rect target_rect { r.pos, { r.width(), s.font.line_height() }};
|
||||||
const size_t visible_item_count = r.height() / s.font.line_height();
|
const size_t visible_item_count = r.height() / s.font.line_height();
|
||||||
|
|
||||||
auto selected = selected_entry();
|
auto selected = recent.find(selected_key);
|
||||||
if( selected == std::end(recent) ) {
|
if( selected == std::end(recent) ) {
|
||||||
selected = std::begin(recent);
|
selected = std::begin(recent);
|
||||||
}
|
}
|
||||||
|
|
||||||
RecentEntries::iterator start = selected;
|
auto start = selected;
|
||||||
RecentEntries::iterator end = selected;
|
auto end = selected;
|
||||||
size_t i = 0;
|
size_t i = 0;
|
||||||
|
|
||||||
// Move start iterator toward first entry.
|
// Move start iterator toward first entry.
|
||||||
@ -258,13 +269,8 @@ void AISView::paint(Painter& painter) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AISView::RecentEntries::iterator AISView::selected_entry() {
|
|
||||||
const auto key = selected_key;
|
|
||||||
return std::find_if(std::begin(recent), std::end(recent), [key](const AISRecentEntry& e) { return e.mmsi == key; });
|
|
||||||
}
|
|
||||||
|
|
||||||
void AISView::advance(const int32_t amount) {
|
void AISView::advance(const int32_t amount) {
|
||||||
auto selected = selected_entry();
|
auto selected = recent.find(selected_key);
|
||||||
if( selected == std::end(recent) ) {
|
if( selected == std::end(recent) ) {
|
||||||
if( recent.empty() ) {
|
if( recent.empty() ) {
|
||||||
selected_key = invalid_key;
|
selected_key = invalid_key;
|
||||||
|
@ -63,6 +63,37 @@ struct AISRecentEntry {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class AISRecentEntries {
|
||||||
|
public:
|
||||||
|
using ContainerType = std::list<AISRecentEntry>;
|
||||||
|
|
||||||
|
void on_packet(const ais::Packet& packet);
|
||||||
|
|
||||||
|
ContainerType::const_reference front() const {
|
||||||
|
return entries.front();
|
||||||
|
}
|
||||||
|
|
||||||
|
ContainerType::const_iterator find(const ais::MMSI key) const;
|
||||||
|
|
||||||
|
ContainerType::const_iterator begin() const {
|
||||||
|
return entries.begin();
|
||||||
|
}
|
||||||
|
|
||||||
|
ContainerType::const_iterator end() const {
|
||||||
|
return entries.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool empty() const {
|
||||||
|
return entries.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
ContainerType entries;
|
||||||
|
const size_t entries_max = 64;
|
||||||
|
|
||||||
|
void truncate_entries();
|
||||||
|
};
|
||||||
|
|
||||||
class AISLogger {
|
class AISLogger {
|
||||||
public:
|
public:
|
||||||
AISLogger();
|
AISLogger();
|
||||||
@ -96,15 +127,10 @@ private:
|
|||||||
|
|
||||||
bool has_focus = false;
|
bool has_focus = false;
|
||||||
|
|
||||||
using RecentEntries = std::list<AISRecentEntry>;
|
AISRecentEntries recent;
|
||||||
RecentEntries recent;
|
|
||||||
|
|
||||||
void on_packet(const ais::Packet& packet);
|
void on_packet(const ais::Packet& packet);
|
||||||
|
|
||||||
void truncate_entries();
|
|
||||||
|
|
||||||
RecentEntries::iterator selected_entry();
|
|
||||||
|
|
||||||
void advance(const int32_t amount);
|
void advance(const int32_t amount);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user