diff options
Diffstat (limited to 'src/layers.cpp')
-rw-r--r-- | src/layers.cpp | 65 |
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() |