summaryrefslogtreecommitdiffstats
path: root/src/layers.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/layers.cpp')
-rw-r--r--src/layers.cpp65
1 files changed, 17 insertions, 48 deletions
diff --git a/src/layers.cpp b/src/layers.cpp
index b961157..bbe7c09 100644
--- a/src/layers.cpp
+++ b/src/layers.cpp
@@ -181,60 +181,29 @@ json layer_map::to_json() const
return j;
}
-compositor::rect layer_map::getAreaSize(const std::string &area)
-{
- return area2size[area];
-}
-
-const compositor::rect layer_map::getScaleDestRect(
- int to_w, int to_h, const std::string &aspect_setting)
+void layer_map::setupArea(double scaling)
{
compositor::rect rct;
- rct.x = 0;
- rct.y = 0;
- rct.w = to_w;
- rct.h = to_h;
- HMI_NOTICE("wm:lm",
- "Scaling:'%s'. Check 'fullscreen' is set.", aspect_setting.c_str());
- // Base is "fullscreen". Crash me if "fullscreen" is not set
- compositor::rect base = this->area2size.at("fullscreen");
- HMI_DEBUG("wm:lm", "Output size, width: %d, height: %d / fullscreen width: %d, height: %d",
- to_w, to_h, base.w, base.h);
- // If full_rct.w or full_rct.h == 0, crash me on purpose
- double scale_rate_w = double(to_w) / double(base.w);
- double scale_rate_h = double(to_h) / double(base.h);
- double scale;
- if (scale_rate_h < scale_rate_w)
- {
- scale = scale_rate_h;
- }
- else
- {
- scale = scale_rate_w;
- }
- HMI_DEBUG("wm", "set scale: %5.2f", scale);
- // Scaling
- if (aspect_setting == "aspect_fit")
- {
- // offset
- rct.x = (to_w - scale * base.w) / 2;
- rct.y = (to_h - scale * base.h) / 2;
+ rct = this->area2size["normal.full"];
+ this->area2size["normalfull"] = rct;
+ this->area2size["normal"] = rct;
- // scaling
- rct.w = base.w * scale;
- rct.h = base.h * scale;
- }
- else if (aspect_setting == "display_fit")
+ for (auto &i : this->area2size)
{
- // offset is none
- // scaling
- rct.w = base.w * scale_rate_w;
- rct.h = base.h * scale_rate_h;
+ i.second.x = static_cast<int>(scaling * i.second.x + 0.5);
+ i.second.y = static_cast<int>(scaling * i.second.y + 0.5);
+ i.second.w = static_cast<int>(scaling * i.second.w + 0.5);
+ i.second.h = static_cast<int>(scaling * i.second.h + 0.5);
+
+ HMI_DEBUG("wm:lm", "area:%s size(after) : x:%d y:%d w:%d h:%d",
+ i.first.c_str(), i.second.x, i.second.y, i.second.w, i.second.h);
}
- HMI_DEBUG("wm:lm", "offset x: %d, y: %d", rct.x, rct.y);
- HMI_DEBUG("wm:lm", "after scaling w: %d, h: %d", rct.w, rct.h);
- return rct;
+}
+
+compositor::rect layer_map::getAreaSize(const std::string &area)
+{
+ return area2size[area];
}
int layer_map::loadAreaDb()