Files
react-native/ReactCommon/fabric/core/layout/LayoutMetrics.h
David Vacca ac9195a506 Include pointScaleFactor into the equality method of LayoutMetrics
Summary:
Previously the pointScaleFactor field was not being compared properly in LayoutMetrics equality method.
This diff fixes that

Reviewed By: shergin

Differential Revision: D15303555

fbshipit-source-id: 8863e9e1fbad15b43400afc32b97bf6d252cbe55
2019-05-10 16:32:01 -07:00

67 lines
1.7 KiB
C++

/**
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#pragma once
#include <react/core/LayoutPrimitives.h>
#include <react/graphics/Geometry.h>
namespace facebook {
namespace react {
/*
* Describes results of layout process for partucular shadow node.
*/
struct LayoutMetrics {
Rect frame;
EdgeInsets contentInsets{0};
EdgeInsets borderWidth{0};
DisplayType displayType{DisplayType::Flex};
LayoutDirection layoutDirection{LayoutDirection::Undefined};
Float pointScaleFactor{1.0};
Rect getContentFrame() const {
return Rect{
Point{contentInsets.left, contentInsets.top},
Size{frame.size.width - contentInsets.left - contentInsets.right,
frame.size.height - contentInsets.top - contentInsets.bottom}};
}
bool operator==(const LayoutMetrics &rhs) const {
return std::tie(
this->frame,
this->contentInsets,
this->borderWidth,
this->displayType,
this->layoutDirection,
this->pointScaleFactor) ==
std::tie(
rhs.frame,
rhs.contentInsets,
rhs.borderWidth,
rhs.displayType,
rhs.layoutDirection,
rhs.pointScaleFactor);
}
bool operator!=(const LayoutMetrics &rhs) const {
return !(*this == rhs);
}
};
/*
* Represents some undefined, not-yet-computed or meaningless value of
* `LayoutMetrics` type.
*/
static const LayoutMetrics EmptyLayoutMetrics = {/* .frame = */ {
/* .origin = */ {0, 0},
/* .size = */ {-1, -1},
}};
} // namespace react
} // namespace facebook