/** * Copyright (C) 2010-2016 eBusiness Information, Excilys Group * * 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. */ package org.androidannotations.annotations; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * <p> * This annotation is intended to be used on methods to receive events defined * by * {@link android.widget.TextView.OnEditorActionListener#onEditorAction(android.widget.TextView, int, android.view.KeyEvent)} * when an action is performed on the editor. * </p> * <p> * The annotation value should be one or several R.id.* fields that refers to * TextView or subclasses of TextView. If not set, the method name will be used * as the R.id.* field name. * </p> * <p> * The method MAY have multiple parameter : * </p> * <ul> * <li>A {@link android.widget.TextView} (or a subclass) parameter to know which * view has targeted this event</li> * <li>An int parameter to get the actionId</li> * <li>A {@link android.view.KeyEvent} parameter</li> * </ul> * <p> * The return type of the method can be either <b>void</b> or <b>boolean</b>. In * case of <b>boolean</b>, the value returned from the annotated method will be * returned in the generated listener method (indicating event consumption). If * the annotated method is <b>void</b>, always <b>true</b> will be returned in * the listener method (so the event is consumed). * </p> * <blockquote> * * Examples : * * <pre> * @EditorAction(<b>R.id.helloTextView</b>) * void onEditorActionsOnHelloTextView(TextView hello, int actionId, KeyEvent keyEvent) { * // Something Here * } * * @EditorAction * void <b>helloTextView</b>EditorAction(TextView hello) { * // Something Here * } * * @EditorAction * void <b>helloEditText</b>EditorAction(EditText hello) { * // Something Here * } * * @EditorAction(<b>{R.id.editText, R.id.helloTextView}</b>) * void onEditorActionsOnSomeTextViews(TextView tv, int actionId) { * // Something Here * } * * @EditorAction(<b>R.id.helloTextView</b>) * void onEditorActionsOnHelloTextView() { * // Something Here * } * * @EditorAction(R.id.helloTextView) * <b>boolean</b> onEditorActionsOnHelloTextView() { * // Something Here * <b>return false;</b> * } * </pre> * * </blockquote> */ @Retention(RetentionPolicy.CLASS) @Target(ElementType.METHOD) public @interface EditorAction { /** * The R.id.* fields which refer to the TextViews. * * @return the ids of the TextViews */ int[] value() default ResId.DEFAULT_VALUE; /** * The resource names as a strings which refer to the TextViews. * * @return the resource names of the TextViews */ String[] resName() default ""; }