• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2010 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License"); you may not
5  * use this file except in compliance with the License. You may obtain a copy of
6  * 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, WITHOUT
12  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13  * License for the specific language governing permissions and limitations under
14  * the License.
15  */
16 
17 package com.android.inputmethod.keyboard;
18 
19 public interface KeyboardActionListener {
20 
21     /**
22      * Called when the user presses a key. This is sent before the {@link #onCodeInput} is called.
23      * For keys that repeat, this is only called once.
24      *
25      * @param primaryCode the unicode of the key being pressed. If the touch is not on a valid key,
26      *            the value will be zero.
27      */
onPressKey(int primaryCode)28     public void onPressKey(int primaryCode);
29 
30     /**
31      * Called when the user releases a key. This is sent after the {@link #onCodeInput} is called.
32      * For keys that repeat, this is only called once.
33      *
34      * @param primaryCode the code of the key that was released
35      * @param withSliding true if releasing has occurred because the user slid finger from the key
36      *             to other key without releasing the finger.
37      */
onReleaseKey(int primaryCode, boolean withSliding)38     public void onReleaseKey(int primaryCode, boolean withSliding);
39 
40     /**
41      * Send a key code to the listener.
42      *
43      * @param primaryCode this is the code of the key that was pressed
44      * @param x x-coordinate pixel of touched event. If {@link #onCodeInput} is not called by
45      *            {@link PointerTracker} or so, the value should be {@link #NOT_A_TOUCH_COORDINATE}.
46      *            If it's called on insertion from the suggestion strip, it should be
47      *            {@link #SUGGESTION_STRIP_COORDINATE}.
48      * @param y y-coordinate pixel of touched event. If {@link #onCodeInput} is not called by
49      *            {@link PointerTracker} or so, the value should be {@link #NOT_A_TOUCH_COORDINATE}.
50      *            If it's called on insertion from the suggestion strip, it should be
51      *            {@link #SUGGESTION_STRIP_COORDINATE}.
52      */
onCodeInput(int primaryCode, int x, int y)53     public void onCodeInput(int primaryCode, int x, int y);
54 
55     public static final int NOT_A_TOUCH_COORDINATE = -1;
56     public static final int SUGGESTION_STRIP_COORDINATE = -2;
57     public static final int SPELL_CHECKER_COORDINATE = -3;
58 
59     /**
60      * Sends a sequence of characters to the listener.
61      *
62      * @param text the sequence of characters to be displayed.
63      */
onTextInput(CharSequence text)64     public void onTextInput(CharSequence text);
65 
66     /**
67      * Called when user released a finger outside any key.
68      */
onCancelInput()69     public void onCancelInput();
70 
71     /**
72      * Send a non-"code input" custom request to the listener.
73      * @return true if the request has been consumed, false otherwise.
74      */
onCustomRequest(int requestCode)75     public boolean onCustomRequest(int requestCode);
76 
77     public static class Adapter implements KeyboardActionListener {
78         @Override
onPressKey(int primaryCode)79         public void onPressKey(int primaryCode) {}
80         @Override
onReleaseKey(int primaryCode, boolean withSliding)81         public void onReleaseKey(int primaryCode, boolean withSliding) {}
82         @Override
onCodeInput(int primaryCode, int x, int y)83         public void onCodeInput(int primaryCode, int x, int y) {}
84         @Override
onTextInput(CharSequence text)85         public void onTextInput(CharSequence text) {}
86         @Override
onCancelInput()87         public void onCancelInput() {}
88         @Override
onCustomRequest(int requestCode)89         public boolean onCustomRequest(int requestCode) {
90             return false;
91         }
92     }
93 }
94