1 /*
2 * Copyright (c) 2021-2023 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 #include <cstdint>
17 #include <fstream>
18 #include <iostream>
19 #include <sstream>
20 #include <thread>
21
22 #include "jsapp/rich/external/EventHandler.h"
23 #include "previewer/include/window.h"
24
25 #include "adapter/preview/entrance/ace_ability.h"
26 #include "adapter/preview/entrance/ace_run_args.h"
27 #include "adapter/preview/entrance/samples/event_adapter.h"
28 #include "base/log/log.h"
29 #include "base/utils/device_config.h"
30 #include "base/utils/utils.h"
31 #include "adapter/preview/entrance/ace_preview_helper.h"
32
33 namespace {
34
35 constexpr char ACE_VERSION_2[] = "2.0";
36 constexpr char MAX_ARGS_COUNT = 2;
37 #ifdef MAC_PLATFORM
38 const std::string assetPathJs = "/Volumes/SSD2T/daily-test/preview/js/default";
39 const std::string assetPathEts = "/Volumes/SSD2T/daily-test/preview/js/default_2.0";
40 #elif WINDOWS_PLATFORM
41 const std::string assetPathJs = "D:\\Workspace\\preview\\js\\default";
42 const std::string assetPathEts = "D:\\Workspace\\preview\\js\\default_2.0";
43 #else
44 const std::string assetPathJs = "/home/ubuntu/demo/preview/js/default";
45 const std::string assetPathEts = "/home/ubuntu/demo/preview/js/default_2.0";
46 #endif
47
__anon636415c70202(const void*, const size_t bufferSize, const int32_t width, const int32_t height) 48 auto&& renderCallback = [](const void*, const size_t bufferSize, const int32_t width, const int32_t height) -> bool {
49 LOGI("OnRender: bufferSize = %{public}zu, [width, height] = [%{public}d, %{public}d]", bufferSize, width, height);
50 return true;
51 };
52
__anon636415c70302(const std::string currentPagePath) 53 auto&& pageCallback = [](const std::string currentPagePath) -> bool {
54 LOGI("OnRouterChange: current page: %s", currentPagePath.c_str());
55 return true;
56 };
57
58 } // namespace
59
main(int argc,const char * argv[])60 int main(int argc, const char* argv[])
61 {
62 OHOS::Ace::Platform::AceRunArgs args = {
63 .assetPath = assetPathJs,
64 .deviceConfig.density = 2.0,
65 .deviceConfig.deviceType = OHOS::Ace::DeviceType::WATCH,
66 .windowTitle = "ACE wearable",
67 .isRound = true,
68 .deviceWidth = 466,
69 .deviceHeight = 466,
70 .onRender = std::move(renderCallback),
71 .onRouterChange = std::move(pageCallback),
72 };
73
74 if (argc == MAX_ARGS_COUNT && !std::strcmp(argv[1], ACE_VERSION_2)) {
75 args.assetPath = assetPathEts;
76 args.aceVersion = OHOS::Ace::Platform::AceVersion::ACE_2_0;
77 }
78
79 // Initialize and create the glfw window.
80 auto ctx = OHOS::Rosen::GlfwRenderContext::GetGlobal();
81 if (!ctx->Init()) {
82 LOGI("Failed to initialize the glfw.");
83 return -1;
84 }
85 ctx->CreateGlfwWindow(args.deviceWidth, args.deviceHeight, true);
86 OHOS::Ace::Sample::EventAdapter::GetInstance().Initialize(ctx);
87 OHOS::Ace::Platform::AcePreviewHelper::GetInstance()->
88 SetCallbackOfPostTask(OHOS::AppExecFwk::EventHandler::PostTask);
89 OHOS::Ace::Platform::AcePreviewHelper::GetInstance()->
90 SetCallbackOfIsCurrentRunnerThread(OHOS::AppExecFwk::EventHandler::IsCurrentRunnerThread);
91 // Create the ace ability
92 auto ability = OHOS::Ace::Platform::AceAbility::CreateInstance(args);
93 CHECK_NULL_RETURN(ability, -1);
94
95 auto&& keyEventCallback = [&ability](
96 const std::shared_ptr<KeyEvent>& keyEvent) { ability->OnInputEvent(keyEvent); };
97 OHOS::Ace::Sample::EventAdapter::GetInstance().RegisterKeyEventCallback(keyEventCallback);
98
99 auto&& pointerEventCallback = [&ability](const std::shared_ptr<PointerEvent>& pointerEvent) {
100 ability->OnInputEvent(pointerEvent);
101 };
102 OHOS::Ace::Sample::EventAdapter::GetInstance().RegisterPointerEventCallback(pointerEventCallback);
103
104 auto&& inspectorCallback = [&ability]() {
105 constexpr char FILE_NAME[] = "InspectorTree.json";
106 std::string jsonTreeStr = ability->GetJSONTree();
107 std::ofstream fileCleaner(FILE_NAME, std::ios_base::out);
108 std::ofstream fileWriter(FILE_NAME, std::ofstream::app);
109 fileWriter << jsonTreeStr;
110 fileWriter << std::endl;
111 fileWriter.close();
112 };
113 OHOS::Ace::Sample::EventAdapter::GetInstance().RegisterInspectorCallback(inspectorCallback);
114
115 OHOS::Rosen::WMError errCode;
116 OHOS::sptr<OHOS::Rosen::WindowOption> sp = nullptr;
117 auto window = OHOS::Rosen::Window::Create("previewer", sp, nullptr, errCode);
118 window->CreateSurfaceNode("preview_surface", args.onRender);
119 ability->SetWindow(window);
120
121 ability->InitEnv();
122 LOGI("Ace initialize done. run event loop now");
123 while (!ctx->WindowShouldClose()) {
124 OHOS::AppExecFwk::EventHandler::Run();
125 ctx->PollEvents();
126 std::this_thread::sleep_for(std::chrono::milliseconds(1));
127 }
128
129 LOGI("Successfully exit the application.");
130 return 0;
131 }
132