mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 11:12:45 +00:00 
			
		
		
		
	 f391ccfe53
			
		
	
	
		f391ccfe53
		
	
	
	
	
		
			
			Previously, calling `.right()` on a `Gfx::Rect` would return the last column's coordinate still inside the rectangle, or `left + width - 1`. This is called 'endpoint inclusive' and does not make a lot of sense for `Gfx::Rect<float>` where a rectangle of width 5 at position (0, 0) would return 4 as its right side. This same problem exists for `.bottom()`. This changes `Gfx::Rect` to be endpoint exclusive, which gives us the nice property that `width = right - left` and `height = bottom - top`. It enables us to treat `Gfx::Rect<int>` and `Gfx::Rect<float>` exactly the same. All users of `Gfx::Rect` have been updated accordingly.
		
			
				
	
	
		
			71 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
 | |
|  * Copyright (c) 2022, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include "TimelineHeader.h"
 | |
| #include "Process.h"
 | |
| #include "Profile.h"
 | |
| #include <AK/LexicalPath.h>
 | |
| #include <LibGUI/FileIconProvider.h>
 | |
| #include <LibGUI/Painter.h>
 | |
| #include <LibGfx/Palette.h>
 | |
| 
 | |
| namespace Profiler {
 | |
| 
 | |
| TimelineHeader::TimelineHeader(Profile& profile, Process const& process)
 | |
|     : m_profile(profile)
 | |
|     , m_process(process)
 | |
| {
 | |
|     set_frame_style(Gfx::FrameStyle::RaisedPanel);
 | |
|     set_fixed_size(200, 40);
 | |
|     update_selection();
 | |
| 
 | |
|     m_icon = GUI::FileIconProvider::icon_for_executable(m_process.executable).bitmap_for_size(32);
 | |
|     m_text = DeprecatedString::formatted("{} ({})", LexicalPath::basename(m_process.executable), m_process.pid);
 | |
| }
 | |
| 
 | |
| void TimelineHeader::paint_event(GUI::PaintEvent& event)
 | |
| {
 | |
|     GUI::Frame::paint_event(event);
 | |
|     GUI::Painter painter(*this);
 | |
|     painter.add_clip_rect(event.rect());
 | |
| 
 | |
|     painter.fill_rect(frame_inner_rect(), m_selected ? palette().selection() : palette().button());
 | |
| 
 | |
|     Gfx::IntRect icon_rect { frame_thickness() + 2, 0, 32, 32 };
 | |
|     icon_rect.center_vertically_within(frame_inner_rect());
 | |
| 
 | |
|     if (m_icon)
 | |
|         painter.blit(icon_rect.location(), *m_icon, m_icon->rect());
 | |
| 
 | |
|     Gfx::IntRect text_rect {
 | |
|         icon_rect.right() + 5,
 | |
|         icon_rect.y(),
 | |
|         width() - 32,
 | |
|         32
 | |
|     };
 | |
|     text_rect.center_vertically_within(frame_inner_rect());
 | |
| 
 | |
|     auto const& font = m_selected ? painter.font().bold_variant() : painter.font();
 | |
|     auto color = m_selected ? palette().selection_text() : palette().button_text();
 | |
|     painter.draw_text(text_rect, m_text, font, Gfx::TextAlignment::CenterLeft, color);
 | |
| }
 | |
| 
 | |
| void TimelineHeader::update_selection()
 | |
| {
 | |
|     m_selected = m_profile.has_process_filter() && m_profile.process_filter_contains(m_process.pid, m_process.start_valid);
 | |
|     update();
 | |
| }
 | |
| 
 | |
| void TimelineHeader::mousedown_event(GUI::MouseEvent& event)
 | |
| {
 | |
|     if (event.button() != GUI::MouseButton::Primary)
 | |
|         return;
 | |
|     m_selected = !m_selected;
 | |
|     on_selection_change(m_selected);
 | |
| }
 | |
| 
 | |
| }
 |