1 /*
2  * Copyright (C) 2020 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.systemui.accessibility;
18 
19 import android.graphics.Rect;
20 
21 /**
22  * A callback to inform {@link com.android.server.accessibility.AccessibilityManagerService} about
23  * the UI state change or the user interaction.
24  */
25 interface WindowMagnifierCallback {
26     /**
27      * Called when the bounds of window magnifier is changed.
28      * @param displayId The logical display id.
29      * @param bounds The bounds of window magnifier on the screen.
30      */
onWindowMagnifierBoundsChanged(int displayId, Rect bounds)31     void onWindowMagnifierBoundsChanged(int displayId, Rect bounds);
32 
33     /**
34      * Called when the magnified bounds is changed.
35      *
36      * @param displayId The logical display id.
37      * @param sourceBounds The magnified bounds in screen coordinates.
38      */
onSourceBoundsChanged(int displayId, Rect sourceBounds)39     void onSourceBoundsChanged(int displayId, Rect sourceBounds);
40 
41     /**
42      * Called when the accessibility action of scale requests to be performed.
43      * It is invoked from System UI. And the action is provided by the mirror window.
44      *
45      * @param displayId The logical display id.
46      * @param scale the target scale, or {@link Float#NaN} to leave unchanged
47      * @param updatePersistence whether the scale should be persisted
48      */
onPerformScaleAction(int displayId, float scale, boolean updatePersistence)49     void onPerformScaleAction(int displayId, float scale, boolean updatePersistence);
50 
51     /**
52      * Called when the accessibility action is performed.
53      *
54      * @param displayId The logical display id.
55      */
onAccessibilityActionPerformed(int displayId)56     void onAccessibilityActionPerformed(int displayId);
57 
58     /**
59      * Called when the user is performing a move action.
60      *
61      * @param displayId The logical display id.
62      */
onMove(int displayId)63     void onMove(int displayId);
64 
65     /**
66      * Called when magnification settings button clicked.
67      *
68      * @param displayId The logical display id.
69      */
onClickSettingsButton(int displayId)70     void onClickSettingsButton(int displayId);
71 }
72