Line data Source code
1 : /** 2 : Copyright (c) 2023 Stappler LLC <admin@stappler.dev> 3 : 4 : Permission is hereby granted, free of charge, to any person obtaining a copy 5 : of this software and associated documentation files (the "Software"), to deal 6 : in the Software without restriction, including without limitation the rights 7 : to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 8 : copies of the Software, and to permit persons to whom the Software is 9 : furnished to do so, subject to the following conditions: 10 : 11 : The above copyright notice and this permission notice shall be included in 12 : all copies or substantial portions of the Software. 13 : 14 : THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15 : IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 : FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 17 : AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 18 : LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 19 : OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 20 : THE SOFTWARE. 21 : **/ 22 : 23 : #include "MaterialDataScrollHandlerFixed.h" 24 : 25 : namespace STAPPLER_VERSIONIZED stappler::xenolith::material2d { 26 : 27 0 : bool DataScrollHandlerFixed::init(DataScroll *s, float size) { 28 0 : if (!Handler::init(s)) { 29 0 : return false; 30 : } 31 : 32 0 : _dataSize = size; 33 : 34 0 : return true; 35 : } 36 : 37 0 : DataScroll::ItemMap DataScrollHandlerFixed::run(Request t, DataMap &&data) { 38 0 : DataScroll::ItemMap ret; 39 0 : Size2 size = (_layout == DataScroll::Layout::Vertical)?Size2(_size.width, _dataSize):Size2(_dataSize, _size.height); 40 0 : for (auto &it : data) { 41 0 : Vec2 origin = (_layout == DataScroll::Layout::Vertical) 42 0 : ?Vec2(0.0f, it.first.get() * _dataSize) 43 0 : :Vec2(it.first.get() * _dataSize, 0.0f); 44 : 45 0 : auto item = Rc<DataScroll::Item>::create(std::move(it.second), origin, size); 46 0 : ret.insert(std::make_pair(it.first, item)); 47 0 : } 48 0 : return ret; 49 0 : } 50 : 51 : }