/* * Copyright (C) 2022 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef MOCK_ACCESSIBILITY_ELEMENT_OPERATOR_PROXY_H #define MOCK_ACCESSIBILITY_ELEMENT_OPERATOR_PROXY_H #include "accessibility_ipc_interface_code.h" #include "i_accessibility_element_operator.h" #include "iremote_proxy.h" namespace OHOS { namespace Accessibility { /* * The class define the interface for UI to implement. * It triggered by ABMS when AA to request the accessibility information. */ class MockAccessibilityElementOperatorProxy : public IRemoteProxy { public: /** * @brief construct function * @param object The object of IPC */ explicit MockAccessibilityElementOperatorProxy(const sptr& object); /** * @brief destruct function */ virtual ~MockAccessibilityElementOperatorProxy() = default; /** * @brief Make the node information by accessibility ID and set the result by callback. * @param elementId: The unique id of the component ID. * @param requestId Matched the request and response. It needn't cared by ACE, transfer it by callback only. * @param callback To transfer the node info to ASAC and it defined by ASAC. * @param mode PREFETCH_PREDECESSORS: Need to make the parent node info also. * PREFETCH_SIBLINGS: Need to make the sister/brothers node info also. * PREFETCH_CHILDREN: Need to make the child node info also. * otherwise: Make the node information by elementId only. * @sysCap Accessibility */ void SearchElementInfoByAccessibilityId(const int64_t elementId, const int32_t requestId, const sptr& callback, const int32_t mode, bool isFilter) override; /** * @brief Make the child node information by accessibility ID and filtered by text and set the result by callback. * @param elementId: The unique id of the component ID. * @param requestId Matched the request and response. It needn't cared by ACE, transfer it by callback only. * @param callback To transfer the node info to ASAC and it defined by ASAC. * @param text Filter for the child components to matched with the text */ void SearchElementInfosByText(const int64_t elementId, const std::string& text, const int32_t requestId, const sptr& callback) override; /** * @brief Make the node information of the component focused by the focus type specified. * @param elementId: The unique id of the component ID. * @param requestId Matched the request and response. It needn't cared by ACE, transfer it by callback only. * @param callback To transfer the node info to ASAC and it defined by ASAC. * @param focusType FOCUS_TYPE_ACCESSIBILITY: accessibility focus * FOCUS_TYPE_INPUT: text input focus */ void FindFocusedElementInfo(const int64_t elementId, const int32_t focusType, const int32_t requestId, const sptr& callback) override; /** * @brief Make the node info by current focus move direction. * @param elementId: The unique id of the component ID. * @param requestId Matched the request and response. It needn't cared by ACE, transfer it by callback only. * @param callback To transfer the node info to ASAC and it defined by ASAC. * @param direction Refer to AccessibilityElementInfo.FocusMoveDirection(UP/DOWN/LEFT/RIGHT/FORWARD/BACKWARD) */ void FocusMoveSearch(const int64_t elementId, const int32_t direction, const int32_t requestId, const sptr& callback) override; /** * @brief To return the result of perform action. * @param elementId: The unique id of the component ID. * @param requestId Matched the request and response. It needn't cared by ACE, transfer it by callback only. * @param callback To transfer the node info to ASAC and it defined by ASAC. * @param action Refer to [AccessibilityElementInfo.ActionType] * @param actionArguments The parameter for action type. such as: * action: ACCESSIBILITY_ACTION_NEXT_HTML_ITEM, * actionArguments(ACTION_ARGU_HTML_ELEMENT,HtmlItemType) * action: ACCESSIBILITY_ACTION_PREVIOUS_HTML_ITEM, * actionArguments(ACTION_ARGU_HTML_ELEMENT,HtmlItemType) * action: ACCESSIBILITY_ACTION_NEXT_TEXT, * actionArguments(ACTION_ARGU_MOVE_UNIT,MOVE_UNIT_XXX) * action: ACCESSIBILITY_ACTION_PREVIOUS_TEXT, * actionArguments(ACTION_ARGU_MOVE_UNIT,MOVE_UNIT_XXX) * action: ACCESSIBILITY_ACTION_SET_SELECTION, * actionArguments({ACTION_ARGU_SELECT_TEXT_START,"1"(start location)}, * {ACTION_ARGU_SELECT_TEXT_END,"10"(end location)}) * action: ACCESSIBILITY_ACTION_SET_TEXT, * actionArguments(ACTION_ARGU_SET_TEXT,"the text of setted") */ void ExecuteAction(const int64_t elementId, const int32_t action, const std::map &actionArguments, int32_t requestId, const sptr& callback) override; /** * @brief To return the result of cursor position. * @param elementId: The unique id of the component ID. * @param requestId Matched the request and response. It needn't cared by ACE, transfer it by callback only. * @param callback To transfer the node info to ASAC and it defined by ASAC. **/ void GetCursorPosition(const int64_t elementId, int32_t requestId, const sptr& callback) override; /** * @brief The function is called while accessibility System check the id of window is not equal * to the id of active window when sendAccessibility. */ void ClearFocus() override; /** * @brief the low layer is notified by the function called while accessibility system execute * the function of executeAction from AS to check the all low windows cared the outside event. * Example: PopupWindow receive the OUTSIDE_EVENT to close itself. */ void OutsideTouch() override; /** * @brief To return the result of elementId, treeId, childWindowId. * @param elementId: The element Id. * @param treeId: The tree Id. * @param childWindowId The childwindow Id. */ void SetChildTreeIdAndWinId(const int64_t elementId, const int32_t treeId, const int32_t childWindowId) override; /** * @brief To return the result of treeId * @param treeId: The tree Id. */ void SetBelongTreeId(const int32_t treeId) override; /** * @brief To return the result of parentWindowId * @param parentWindowId: The parentWindow Id. */ void SetParentWindowId(const int32_t parentWindowId) override; int64_t testElementId_ = -1; int32_t testClearFocus_ = -1; int32_t testOutsideTouch_ = -1; int64_t testChannelElementId_ = -1; int32_t testChannelRequestId_ = -1; int32_t testChannelMode_ = -1; std::string testText_ = ""; int32_t testFocusType_ = 0; int32_t testDirection_ = 0; int32_t testAction_ = 0; int32_t testTreeId_ = -1; int32_t testChildWindowId_ = -1; int32_t testParentWindowId_ = -1; std::map testActionArguments_; bool isFilter_ = false; private: /** * @brief Write the descriptor of IPC. * @param data It is include the descriptor of IPC. * @return true: Write the descriptor successfully; otherwise is not. */ bool WriteInterfaceToken(MessageParcel& data); /** * @brief Send the command data from proxy to stub in IPC mechanism. * @param code The code matched the function called. * @param data Serializable data * @param reply The response of IPC * @param option The option parameter of IPC,such as: async,sync * @return true: Write the descriptor successfully; otherwise is not. */ bool SendTransactCmd( AccessibilityInterfaceCode code, MessageParcel& data, MessageParcel& reply, MessageOption& option); static inline BrokerDelegator delegator; }; } // namespace Accessibility } // namespace OHOS #endif // MOCK_ACCESSIBILITY_ELEMENT_OPERATOR_PROXY_H