1e0dac50fSopenharmony_ci/* 2e0dac50fSopenharmony_ci * Copyright (c) 2021-2022 Huawei Device Co., Ltd. 3e0dac50fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4e0dac50fSopenharmony_ci * you may not use this file except in compliance with the License. 5e0dac50fSopenharmony_ci * You may obtain a copy of the License at 6e0dac50fSopenharmony_ci * 7e0dac50fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8e0dac50fSopenharmony_ci * 9e0dac50fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10e0dac50fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11e0dac50fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12e0dac50fSopenharmony_ci * See the License for the specific language governing permissions and 13e0dac50fSopenharmony_ci * limitations under the License. 14e0dac50fSopenharmony_ci */ 15e0dac50fSopenharmony_ci 16e0dac50fSopenharmony_ci#include "screen_info.h" 17e0dac50fSopenharmony_ci 18e0dac50fSopenharmony_cinamespace OHOS::Rosen { 19e0dac50fSopenharmony_cibool ScreenInfo::Marshalling(Parcel &parcel) const 20e0dac50fSopenharmony_ci{ 21e0dac50fSopenharmony_ci bool res = parcel.WriteString(name_) && parcel.WriteUint64(id_) && 22e0dac50fSopenharmony_ci parcel.WriteUint32(virtualWidth_) && parcel.WriteUint32(virtualHeight_) && 23e0dac50fSopenharmony_ci parcel.WriteFloat(virtualPixelRatio_) && parcel.WriteUint64(lastParent_) && parcel.WriteUint64(parent_) && 24e0dac50fSopenharmony_ci parcel.WriteBool(isScreenGroup_) && parcel.WriteUint32(static_cast<uint32_t>(rotation_)) && 25e0dac50fSopenharmony_ci parcel.WriteUint32(static_cast<uint32_t>(orientation_)) && 26e0dac50fSopenharmony_ci parcel.WriteUint32(static_cast<uint32_t>(sourceMode_)) && 27e0dac50fSopenharmony_ci parcel.WriteUint32(static_cast<uint32_t>(type_)) && 28e0dac50fSopenharmony_ci parcel.WriteUint32(modeId_) && parcel.WriteUint32(static_cast<uint32_t>(modes_.size())) && 29e0dac50fSopenharmony_ci parcel.WriteBool(isExtend_); 30e0dac50fSopenharmony_ci if (!res) { 31e0dac50fSopenharmony_ci return false; 32e0dac50fSopenharmony_ci } 33e0dac50fSopenharmony_ci if (modes_.size() > MAX_SUPPORTED_SCREEN_MODES_SIZE) { 34e0dac50fSopenharmony_ci return false; 35e0dac50fSopenharmony_ci } 36e0dac50fSopenharmony_ci for (uint32_t modeIndex = 0; modeIndex < modes_.size(); modeIndex++) { 37e0dac50fSopenharmony_ci if (parcel.WriteUint32(modes_[modeIndex]->id_) && 38e0dac50fSopenharmony_ci parcel.WriteUint32(modes_[modeIndex]->height_) && 39e0dac50fSopenharmony_ci parcel.WriteUint32(modes_[modeIndex]->width_) && 40e0dac50fSopenharmony_ci parcel.WriteUint32(modes_[modeIndex]->refreshRate_)) { 41e0dac50fSopenharmony_ci continue; 42e0dac50fSopenharmony_ci } 43e0dac50fSopenharmony_ci return false; 44e0dac50fSopenharmony_ci } 45e0dac50fSopenharmony_ci return true; 46e0dac50fSopenharmony_ci} 47e0dac50fSopenharmony_ci 48e0dac50fSopenharmony_ciScreenInfo* ScreenInfo::Unmarshalling(Parcel &parcel) 49e0dac50fSopenharmony_ci{ 50e0dac50fSopenharmony_ci ScreenInfo* info = new(std::nothrow) ScreenInfo(); 51e0dac50fSopenharmony_ci if (info == nullptr) { 52e0dac50fSopenharmony_ci return info; 53e0dac50fSopenharmony_ci } 54e0dac50fSopenharmony_ci bool res = info->InnerUnmarshalling(parcel); 55e0dac50fSopenharmony_ci if (res) { 56e0dac50fSopenharmony_ci return info; 57e0dac50fSopenharmony_ci } 58e0dac50fSopenharmony_ci delete info; 59e0dac50fSopenharmony_ci return nullptr; 60e0dac50fSopenharmony_ci} 61e0dac50fSopenharmony_ci 62e0dac50fSopenharmony_cibool ScreenInfo::InnerUnmarshalling(Parcel& parcel) 63e0dac50fSopenharmony_ci{ 64e0dac50fSopenharmony_ci uint32_t size = 0; 65e0dac50fSopenharmony_ci uint32_t rotation; 66e0dac50fSopenharmony_ci uint32_t orientation; 67e0dac50fSopenharmony_ci uint32_t sourceMode; 68e0dac50fSopenharmony_ci uint32_t type; 69e0dac50fSopenharmony_ci name_ = parcel.ReadString(); 70e0dac50fSopenharmony_ci bool res1 = parcel.ReadUint64(id_) && 71e0dac50fSopenharmony_ci parcel.ReadUint32(virtualWidth_) && parcel.ReadUint32(virtualHeight_) && 72e0dac50fSopenharmony_ci parcel.ReadFloat(virtualPixelRatio_) && parcel.ReadUint64(lastParent_) && parcel.ReadUint64(parent_) && 73e0dac50fSopenharmony_ci parcel.ReadBool(isScreenGroup_) && parcel.ReadUint32(rotation) && 74e0dac50fSopenharmony_ci parcel.ReadUint32(orientation) && parcel.ReadUint32(sourceMode) && parcel.ReadUint32(type) && 75e0dac50fSopenharmony_ci parcel.ReadUint32(modeId_) && parcel.ReadUint32(size) && 76e0dac50fSopenharmony_ci parcel.ReadBool(isExtend_); 77e0dac50fSopenharmony_ci if (!res1) { 78e0dac50fSopenharmony_ci return false; 79e0dac50fSopenharmony_ci } 80e0dac50fSopenharmony_ci if (size > MAX_SUPPORTED_SCREEN_MODES_SIZE) { 81e0dac50fSopenharmony_ci return false; 82e0dac50fSopenharmony_ci } 83e0dac50fSopenharmony_ci modes_.clear(); 84e0dac50fSopenharmony_ci for (uint32_t modeIndex = 0; modeIndex < size; modeIndex++) { 85e0dac50fSopenharmony_ci sptr<SupportedScreenModes> mode = new(std::nothrow) SupportedScreenModes(); 86e0dac50fSopenharmony_ci if (mode == nullptr) { 87e0dac50fSopenharmony_ci return false; 88e0dac50fSopenharmony_ci } 89e0dac50fSopenharmony_ci if (parcel.ReadUint32(mode->id_) && 90e0dac50fSopenharmony_ci parcel.ReadUint32(mode->height_) && 91e0dac50fSopenharmony_ci parcel.ReadUint32(mode->width_) && 92e0dac50fSopenharmony_ci parcel.ReadUint32(mode->refreshRate_)) { 93e0dac50fSopenharmony_ci modes_.push_back(mode); 94e0dac50fSopenharmony_ci } else { 95e0dac50fSopenharmony_ci return false; 96e0dac50fSopenharmony_ci } 97e0dac50fSopenharmony_ci } 98e0dac50fSopenharmony_ci rotation_ = static_cast<Rotation>(rotation); 99e0dac50fSopenharmony_ci orientation_ = static_cast<Orientation>(orientation); 100e0dac50fSopenharmony_ci sourceMode_ = static_cast<ScreenSourceMode>(sourceMode); 101e0dac50fSopenharmony_ci type_ = static_cast<ScreenType>(type); 102e0dac50fSopenharmony_ci return true; 103e0dac50fSopenharmony_ci} 104e0dac50fSopenharmony_ci} // namespace OHOS::Rosen