mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 06:37:44 +00:00
Maps: Add custom context menu actions option to MapWidget
This commit is contained in:
parent
f18c6eb0ea
commit
54ec744398
2 changed files with 26 additions and 12 deletions
|
@ -231,35 +231,40 @@ void MapWidget::context_menu_event(GUI::ContextMenuEvent& event)
|
||||||
if (!m_context_menu_enabled)
|
if (!m_context_menu_enabled)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
LatLng latlng = { tile_y_to_latitude(latitude_to_tile_y(m_center.latitude, m_zoom) + static_cast<double>(event.position().y() - height() / 2) / TILE_SIZE, m_zoom),
|
m_context_menu_latlng = { tile_y_to_latitude(latitude_to_tile_y(m_center.latitude, m_zoom) + static_cast<double>(event.position().y() - height() / 2) / TILE_SIZE, m_zoom),
|
||||||
tile_x_to_longitude(longitude_to_tile_x(m_center.longitude, m_zoom) + static_cast<double>(event.position().x() - width() / 2) / TILE_SIZE, m_zoom) };
|
tile_x_to_longitude(longitude_to_tile_x(m_center.longitude, m_zoom) + static_cast<double>(event.position().x() - width() / 2) / TILE_SIZE, m_zoom) };
|
||||||
|
|
||||||
m_context_menu = GUI::Menu::construct();
|
m_context_menu = GUI::Menu::construct();
|
||||||
m_context_menu->add_action(GUI::Action::create(
|
m_context_menu->add_action(GUI::Action::create(
|
||||||
"&Copy Coordinates to Clipboard", MUST(Gfx::Bitmap::load_from_file("/res/icons/16x16/edit-copy.png"sv)), [latlng](auto&) {
|
"&Copy Coordinates to Clipboard", MUST(Gfx::Bitmap::load_from_file("/res/icons/16x16/edit-copy.png"sv)), [this](auto&) {
|
||||||
GUI::Clipboard::the().set_plain_text(MUST(String::formatted("{}, {}", latlng.latitude, latlng.longitude)).bytes_as_string_view());
|
GUI::Clipboard::the().set_plain_text(MUST(String::formatted("{}, {}", m_context_menu_latlng.latitude, m_context_menu_latlng.longitude)).bytes_as_string_view());
|
||||||
}));
|
}));
|
||||||
m_context_menu->add_separator();
|
m_context_menu->add_separator();
|
||||||
|
if (!m_context_menu_actions.is_empty()) {
|
||||||
|
for (auto& action : m_context_menu_actions)
|
||||||
|
m_context_menu->add_action(action);
|
||||||
|
m_context_menu->add_separator();
|
||||||
|
}
|
||||||
auto link_icon = MUST(Gfx::Bitmap::load_from_file("/res/icons/16x16/filetype-symlink.png"sv));
|
auto link_icon = MUST(Gfx::Bitmap::load_from_file("/res/icons/16x16/filetype-symlink.png"sv));
|
||||||
m_context_menu->add_action(GUI::Action::create(
|
m_context_menu->add_action(GUI::Action::create(
|
||||||
"Open in &OpenStreetMap", link_icon, [this, latlng](auto&) {
|
"Open in &OpenStreetMap", link_icon, [this](auto&) {
|
||||||
Desktop::Launcher::open(URL(MUST(String::formatted("https://www.openstreetmap.org/#map={}/{}/{}", m_zoom, latlng.latitude, latlng.longitude))));
|
Desktop::Launcher::open(URL(MUST(String::formatted("https://www.openstreetmap.org/#map={}/{}/{}", m_zoom, m_context_menu_latlng.latitude, m_context_menu_latlng.longitude))));
|
||||||
}));
|
}));
|
||||||
m_context_menu->add_action(GUI::Action::create(
|
m_context_menu->add_action(GUI::Action::create(
|
||||||
"Open in &Google Maps", link_icon, [this, latlng](auto&) {
|
"Open in &Google Maps", link_icon, [this](auto&) {
|
||||||
Desktop::Launcher::open(URL(MUST(String::formatted("https://www.google.com/maps/@{},{},{}z", latlng.latitude, latlng.longitude, m_zoom))));
|
Desktop::Launcher::open(URL(MUST(String::formatted("https://www.google.com/maps/@{},{},{}z", m_context_menu_latlng.latitude, m_context_menu_latlng.longitude, m_zoom))));
|
||||||
}));
|
}));
|
||||||
m_context_menu->add_action(GUI::Action::create(
|
m_context_menu->add_action(GUI::Action::create(
|
||||||
"Open in &Bing Maps", link_icon, [this, latlng](auto&) {
|
"Open in &Bing Maps", link_icon, [this](auto&) {
|
||||||
Desktop::Launcher::open(URL(MUST(String::formatted("https://www.bing.com/maps/?cp={}~{}&lvl={}", latlng.latitude, latlng.longitude, m_zoom))));
|
Desktop::Launcher::open(URL(MUST(String::formatted("https://www.bing.com/maps/?cp={}~{}&lvl={}", m_context_menu_latlng.latitude, m_context_menu_latlng.longitude, m_zoom))));
|
||||||
}));
|
}));
|
||||||
m_context_menu->add_action(GUI::Action::create(
|
m_context_menu->add_action(GUI::Action::create(
|
||||||
"Open in &DuckDuckGo Maps", link_icon, [latlng](auto&) {
|
"Open in &DuckDuckGo Maps", link_icon, [this](auto&) {
|
||||||
Desktop::Launcher::open(URL(MUST(String::formatted("https://duckduckgo.com/?q={},+{}&ia=web&iaxm=maps", latlng.latitude, latlng.longitude))));
|
Desktop::Launcher::open(URL(MUST(String::formatted("https://duckduckgo.com/?q={},+{}&ia=web&iaxm=maps", m_context_menu_latlng.latitude, m_context_menu_latlng.longitude))));
|
||||||
}));
|
}));
|
||||||
m_context_menu->add_separator();
|
m_context_menu->add_separator();
|
||||||
m_context_menu->add_action(GUI::Action::create(
|
m_context_menu->add_action(GUI::Action::create(
|
||||||
"Center &map here", MUST(Gfx::Bitmap::load_from_file("/res/icons/16x16/scale.png"sv)), [this, latlng](auto&) { set_center(latlng); }));
|
"Center &map here", MUST(Gfx::Bitmap::load_from_file("/res/icons/16x16/scale.png"sv)), [this](auto&) { set_center(m_context_menu_latlng); }));
|
||||||
m_context_menu->popup(event.screen_position());
|
m_context_menu->popup(event.screen_position());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include <AK/Queue.h>
|
#include <AK/Queue.h>
|
||||||
#include <LibConfig/Listener.h>
|
#include <LibConfig/Listener.h>
|
||||||
|
#include <LibGUI/Action.h>
|
||||||
#include <LibGUI/Frame.h>
|
#include <LibGUI/Frame.h>
|
||||||
#include <LibGUI/Menu.h>
|
#include <LibGUI/Menu.h>
|
||||||
#include <LibGUI/Painter.h>
|
#include <LibGUI/Painter.h>
|
||||||
|
@ -102,6 +103,12 @@ public:
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LatLng context_menu_latlng() const { return m_context_menu_latlng; }
|
||||||
|
void add_context_menu_action(NonnullRefPtr<GUI::Action> const& action)
|
||||||
|
{
|
||||||
|
m_context_menu_actions.append(action);
|
||||||
|
}
|
||||||
|
|
||||||
struct TileKey {
|
struct TileKey {
|
||||||
int x;
|
int x;
|
||||||
int y;
|
int y;
|
||||||
|
@ -174,6 +181,8 @@ private:
|
||||||
int m_zoom {};
|
int m_zoom {};
|
||||||
bool m_context_menu_enabled {};
|
bool m_context_menu_enabled {};
|
||||||
RefPtr<GUI::Menu> m_context_menu;
|
RefPtr<GUI::Menu> m_context_menu;
|
||||||
|
LatLng m_context_menu_latlng;
|
||||||
|
Vector<NonnullRefPtr<GUI::Action>> m_context_menu_actions;
|
||||||
bool m_scale_enabled {};
|
bool m_scale_enabled {};
|
||||||
int m_scale_max_width {};
|
int m_scale_max_width {};
|
||||||
bool m_attribution_enabled {};
|
bool m_attribution_enabled {};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue