ConicGradientStyleValue.cpp 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
  3. * Copyright (c) 2021, Tobias Christiansen <tobyase@serenityos.org>
  4. * Copyright (c) 2021-2023, Sam Atkins <atkinssj@serenityos.org>
  5. * Copyright (c) 2022-2023, MacDue <macdue@dueutil.tech>
  6. *
  7. * SPDX-License-Identifier: BSD-2-Clause
  8. */
  9. #include "ConicGradientStyleValue.h"
  10. namespace Web::CSS {
  11. ErrorOr<String> ConicGradientStyleValue::to_string() const
  12. {
  13. StringBuilder builder;
  14. if (is_repeating())
  15. TRY(builder.try_append("repeating-"sv));
  16. TRY(builder.try_append("conic-gradient("sv));
  17. bool has_from_angle = false;
  18. bool has_at_position = false;
  19. if ((has_from_angle = m_properties.from_angle.to_degrees() != 0))
  20. TRY(builder.try_appendff("from {}", TRY(m_properties.from_angle.to_string())));
  21. if ((has_at_position = m_properties.position != PositionValue::center())) {
  22. if (has_from_angle)
  23. TRY(builder.try_append(' '));
  24. TRY(builder.try_appendff("at "sv));
  25. TRY(m_properties.position.serialize(builder));
  26. }
  27. if (has_from_angle || has_at_position)
  28. TRY(builder.try_append(", "sv));
  29. TRY(serialize_color_stop_list(builder, m_properties.color_stop_list));
  30. TRY(builder.try_append(')'));
  31. return builder.to_string();
  32. }
  33. void ConicGradientStyleValue::resolve_for_size(Layout::Node const& node, CSSPixelSize size) const
  34. {
  35. if (!m_resolved.has_value())
  36. m_resolved = ResolvedData { Painting::resolve_conic_gradient_data(node, *this), {} };
  37. m_resolved->position = m_properties.position.resolved(node, CSSPixelRect { { 0, 0 }, size });
  38. }
  39. void ConicGradientStyleValue::paint(PaintContext& context, DevicePixelRect const& dest_rect, CSS::ImageRendering) const
  40. {
  41. VERIFY(m_resolved.has_value());
  42. Painting::paint_conic_gradient(context, dest_rect, m_resolved->data, context.rounded_device_point(m_resolved->position));
  43. }
  44. bool ConicGradientStyleValue::equals(StyleValue const& other) const
  45. {
  46. if (type() != other.type())
  47. return false;
  48. auto& other_gradient = other.as_conic_gradient();
  49. return m_properties == other_gradient.m_properties;
  50. }
  51. float ConicGradientStyleValue::angle_degrees() const
  52. {
  53. return m_properties.from_angle.to_degrees();
  54. }
  55. }