1 /* 2 * Copyright (c) 2024 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16 #ifndef OHOS_ABILITY_RUNTIME_WINDOW_OPTIONS_UTILS_H 17 #define OHOS_ABILITY_RUNTIME_WINDOW_OPTIONS_UTILS_H 18 19 #include "ability_info.h" 20 #include "hilog_tag_wrapper.h" 21 #include "iremote_object.h" 22 #include "start_options.h" 23 #include "string_wrapper.h" 24 #include "want.h" 25 26 namespace OHOS { 27 namespace AAFwk { 28 /** 29 * @class WindowOptionsUtils 30 * provides window options utilities. 31 */ 32 class WindowOptionsUtils final { 33 public: 34 /** 35 * SetWindowPositionAndSize, set window position and size. 36 * 37 * @param want The want param. 38 * @param callerToken The caller token. 39 * @param startOptions The start options. 40 */ 41 static void SetWindowPositionAndSize(Want& want, 42 const sptr<IRemoteObject>& callerToken, const StartOptions& startOptions); 43 44 /** 45 * WindowModeMap, get window mode map. 46 * 47 * @param windowMode The window mode. 48 * @return The pair of the window mode result and the supported window mode. 49 */ 50 static std::pair<bool, AppExecFwk::SupportWindowMode> WindowModeMap(int32_t windowMode); 51 52 /** 53 * UpdateWantToSetDisplayID, update want to set display id. 54 * 55 * @param want The want param. 56 * @param callerToken The caller token. 57 */ 58 static void UpdateWantToSetDisplayID(Want &want, const sptr<IRemoteObject> &callerToken); 59 60 /** 61 * UpdateStartOptionsToSetDisplayID, update start options to set display id. 62 * 63 * @param startOptions The start options. 64 * @param callerToken The caller token. 65 */ 66 static void UpdateStartOptionsToSetDisplayID(StartOptions &startOptions, 67 const sptr<IRemoteObject> &callerToken); 68 }; 69 } // namespace AAFwk 70 } // namespace OHOS 71 #endif // OHOS_ABILITY_RUNTIME_WINDOW_OPTIONS_UTILS_H 72