mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-24 10:12:25 -05:00
f87041bf3a
Resulting in a massive rename across almost everywhere! Alongside the namespace change, we now have the following names: * JS::NonnullGCPtr -> GC::Ref * JS::GCPtr -> GC::Ptr * JS::HeapFunction -> GC::Function * JS::CellImpl -> GC::Cell * JS::Handle -> GC::Root
68 lines
3 KiB
C++
68 lines
3 KiB
C++
/*
|
|
* Copyright (c) 2021, sin-ack <sin-ack@protonmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibWeb/Bindings/PlatformObject.h>
|
|
|
|
namespace Web::HTML {
|
|
|
|
class TextMetrics : public Bindings::PlatformObject {
|
|
WEB_PLATFORM_OBJECT(TextMetrics, Bindings::PlatformObject);
|
|
GC_DECLARE_ALLOCATOR(TextMetrics);
|
|
|
|
public:
|
|
[[nodiscard]] static GC::Ref<TextMetrics> create(JS::Realm&);
|
|
|
|
virtual ~TextMetrics() override;
|
|
|
|
double width() const { return m_width; }
|
|
double actual_bounding_box_left() const { return m_actual_bounding_box_left; }
|
|
double actual_bounding_box_right() const { return m_actual_bounding_box_right; }
|
|
double font_bounding_box_ascent() const { return m_font_bounding_box_ascent; }
|
|
double font_bounding_box_descent() const { return m_font_bounding_box_descent; }
|
|
double actual_bounding_box_ascent() const { return m_actual_bounding_box_ascent; }
|
|
double actual_bounding_box_descent() const { return m_actual_bounding_box_descent; }
|
|
double em_height_ascent() const { return m_em_height_ascent; }
|
|
double em_height_descent() const { return m_em_height_descent; }
|
|
double hanging_baseline() const { return m_hanging_baseline; }
|
|
double alphabetic_baseline() const { return m_alphabetic_baseline; }
|
|
double ideographic_baseline() const { return m_ideographic_baseline; }
|
|
|
|
void set_width(double width) { m_width = width; }
|
|
void set_actual_bounding_box_left(double left) { m_actual_bounding_box_left = left; }
|
|
void set_actual_bounding_box_right(double right) { m_actual_bounding_box_right = right; }
|
|
void set_font_bounding_box_ascent(double ascent) { m_font_bounding_box_ascent = ascent; }
|
|
void set_font_bounding_box_descent(double descent) { m_font_bounding_box_descent = descent; }
|
|
void set_actual_bounding_box_ascent(double ascent) { m_actual_bounding_box_ascent = ascent; }
|
|
void set_actual_bounding_box_descent(double descent) { m_actual_bounding_box_descent = descent; }
|
|
void set_em_height_ascent(double ascent) { m_em_height_ascent = ascent; }
|
|
void set_em_height_descent(double descent) { m_em_height_descent = descent; }
|
|
void set_hanging_baseline(double baseline) { m_hanging_baseline = baseline; }
|
|
void set_alphabetic_baseline(double baseline) { m_alphabetic_baseline = baseline; }
|
|
void set_ideographic_baseline(double baseline) { m_ideographic_baseline = baseline; }
|
|
|
|
private:
|
|
explicit TextMetrics(JS::Realm&);
|
|
|
|
virtual void initialize(JS::Realm&) override;
|
|
|
|
double m_width { 0 };
|
|
double m_actual_bounding_box_left { 0 };
|
|
double m_actual_bounding_box_right { 0 };
|
|
|
|
double m_font_bounding_box_ascent { 0 };
|
|
double m_font_bounding_box_descent { 0 };
|
|
double m_actual_bounding_box_ascent { 0 };
|
|
double m_actual_bounding_box_descent { 0 };
|
|
double m_em_height_ascent { 0 };
|
|
double m_em_height_descent { 0 };
|
|
double m_hanging_baseline { 0 };
|
|
double m_alphabetic_baseline { 0 };
|
|
double m_ideographic_baseline { 0 };
|
|
};
|
|
|
|
}
|