summaryrefslogtreecommitdiff
path: root/MenuApplets/Audio/main.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'MenuApplets/Audio/main.cpp')
-rw-r--r--MenuApplets/Audio/main.cpp120
1 files changed, 108 insertions, 12 deletions
diff --git a/MenuApplets/Audio/main.cpp b/MenuApplets/Audio/main.cpp
index 52319a6e53..42e9c92f9f 100644
--- a/MenuApplets/Audio/main.cpp
+++ b/MenuApplets/Audio/main.cpp
@@ -26,7 +26,11 @@
#include <LibAudio/ClientConnection.h>
#include <LibGUI/Application.h>
+#include <LibGUI/BoxLayout.h>
+#include <LibGUI/CheckBox.h>
+#include <LibGUI/Label.h>
#include <LibGUI/Painter.h>
+#include <LibGUI/Slider.h>
#include <LibGUI/Widget.h>
#include <LibGUI/Window.h>
#include <LibGfx/Bitmap.h>
@@ -42,6 +46,8 @@ public:
m_audio_client->on_muted_state_change = [this](bool muted) {
if (m_audio_muted == muted)
return;
+ m_mute_box->set_checked(!m_audio_muted);
+ m_slider->set_enabled(!muted);
m_audio_muted = muted;
update();
};
@@ -52,21 +58,88 @@ public:
update();
};
- m_volume_level_bitmaps.append({66, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-high.png")});
- m_volume_level_bitmaps.append({33, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-medium.png")});
- m_volume_level_bitmaps.append({1, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-low.png")});
- m_volume_level_bitmaps.append({0, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-muted.png")});
+ m_volume_level_bitmaps.append({ 66, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-high.png") });
+ m_volume_level_bitmaps.append({ 33, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-medium.png") });
+ m_volume_level_bitmaps.append({ 1, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-low.png") });
+ m_volume_level_bitmaps.append({ 0, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-zero.png") });
+ m_volume_level_bitmaps.append({ 0, Gfx::Bitmap::load_from_file("/res/icons/audio-volume-muted.png") });
+
+ m_slider_window = add<GUI::Window>(window());
+ m_slider_window->set_frameless(true);
+ m_slider_window->set_resizable(false);
+ m_slider_window->set_minimizable(false);
+ m_slider_window->on_active_input_change = [this](bool is_active_input) {
+ if (!is_active_input)
+ close();
+ };
+
+ m_root_container = m_slider_window->set_main_widget<GUI::Label>();
+ m_root_container->set_fill_with_background_color(true);
+ m_root_container->set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fill);
+ m_root_container->set_layout<GUI::VerticalBoxLayout>();
+ m_root_container->layout()->set_margins({ 0, 4, 0, 4 });
+ m_root_container->layout()->set_spacing(0);
+ m_root_container->set_frame_thickness(2);
+ m_root_container->set_frame_shape(Gfx::FrameShape::Container);
+ m_root_container->set_frame_shadow(Gfx::FrameShadow::Raised);
+
+ m_percent_box = m_root_container->add<GUI::CheckBox>("\xE2\x84\xB9");
+ m_percent_box->set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed);
+ m_percent_box->set_preferred_size(27, 16);
+ m_percent_box->set_checked(false);
+ m_percent_box->set_tooltip("Show percent");
+ m_percent_box->on_checked = [&](bool show_percent) {
+ m_show_percent = show_percent;
+ if (!m_show_percent) {
+ window()->resize(16, 16);
+ m_percent_box->set_tooltip("Show percent");
+ } else {
+ window()->resize(44, 16);
+ m_percent_box->set_tooltip("Hide percent");
+ }
+ reposition_slider_window();
+ GUI::Application::the()->hide_tooltip();
+ };
+
+ m_slider = m_root_container->add<GUI::VerticalSlider>();
+ m_slider->set_max(20);
+ m_slider->set_value(0);
+ m_slider->set_knob_size_mode(GUI::Slider::KnobSizeMode::Proportional);
+ m_slider->set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fill);
+ m_slider->on_value_changed = [&](int value) {
+ int volume = clamp((20 - value) * 5, 0, 100);
+ m_audio_client->set_main_mix_volume(volume);
+ update();
+ };
+
+ m_mute_box = m_root_container->add<GUI::CheckBox>("\xE2\x9D\x8C");
+ m_mute_box->set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed);
+ m_mute_box->set_preferred_size(27, 16);
+ m_mute_box->set_checked(false);
+ m_mute_box->set_tooltip("Mute");
+ m_mute_box->on_checked = [&](bool is_muted) {
+ m_mute_box->set_tooltip(is_muted ? "Unmute" : "Mute");
+ m_audio_client->set_muted(is_muted);
+ GUI::Application::the()->hide_tooltip();
+ };
}
- virtual ~AudioWidget() override {}
+ virtual ~AudioWidget() override { }
private:
virtual void mousedown_event(GUI::MouseEvent& event) override
{
- if (event.button() != GUI::MouseButton::Left)
+ if (event.button() == GUI::MouseButton::Left) {
+ if (!m_slider_window->is_visible())
+ open();
+ else
+ close();
return;
- m_audio_client->set_muted(!m_audio_muted);
- update();
+ }
+ if (event.button() == GUI::MouseButton::Right) {
+ m_audio_client->set_muted(!m_audio_muted);
+ update();
+ }
}
virtual void mousewheel_event(GUI::MouseEvent& event) override
@@ -75,6 +148,7 @@ private:
return;
int volume = clamp(m_audio_volume - event.wheel_delta() * 5, 0, 100);
m_audio_client->set_main_mix_volume(volume);
+ m_slider->set_value(20 - (volume / 5));
update();
}
@@ -87,8 +161,21 @@ private:
auto& audio_bitmap = choose_bitmap_from_volume();
painter.blit({}, audio_bitmap, audio_bitmap.rect());
- auto volume_text = m_audio_muted ? "Mut" : String::format("%d%%", m_audio_volume);
- painter.draw_text({16, 3, 24, 16}, volume_text, Gfx::Font::default_font(), Gfx::TextAlignment::TopLeft, palette().window_text());
+ if (m_show_percent) {
+ auto volume_text = m_audio_muted ? "mute" : String::format("%d%%", m_audio_volume);
+ painter.draw_text({ 16, 3, 24, 16 }, volume_text, Gfx::Font::default_fixed_width_font(), Gfx::TextAlignment::TopLeft, palette().window_text());
+ }
+ }
+
+ void open()
+ {
+ reposition_slider_window();
+ m_slider_window->show();
+ }
+
+ void close()
+ {
+ m_slider_window->hide();
}
Gfx::Bitmap& choose_bitmap_from_volume()
@@ -103,15 +190,24 @@ private:
ASSERT_NOT_REACHED();
}
+ void reposition_slider_window() { m_slider_window->set_rect(window()->rect_in_menubar().x() - 20, 19, 50, 100); }
+
struct VolumeBitmapPair {
int volume_threshold { 0 };
RefPtr<Gfx::Bitmap> bitmap;
};
NonnullRefPtr<Audio::ClientConnection> m_audio_client;
- Vector<VolumeBitmapPair, 4> m_volume_level_bitmaps;
+ Vector<VolumeBitmapPair, 5> m_volume_level_bitmaps;
+ bool m_show_percent { false };
bool m_audio_muted { false };
int m_audio_volume { 100 };
+
+ RefPtr<GUI::Slider> m_slider;
+ RefPtr<GUI::Window> m_slider_window;
+ RefPtr<GUI::CheckBox> m_mute_box;
+ RefPtr<GUI::CheckBox> m_percent_box;
+ RefPtr<GUI::Label> m_root_container;
};
int main(int argc, char** argv)
@@ -132,7 +228,7 @@ int main(int argc, char** argv)
window->set_has_alpha_channel(true);
window->set_title("Audio");
window->set_window_type(GUI::WindowType::MenuApplet);
- window->resize(42, 16);
+ window->resize(16, 16);
window->set_main_widget<AudioWidget>();
window->show();