Ответ 1
Похоже, вы не можете сделать это с помощью API: событие вставки Android
Я выкопал в Android-источник TextView
(EditText
является TextView
с некоторой другой конфигурацией) и выяснил, что меню, используемое для предоставления параметров cut/copy/paste, является только измененным ContextMenu
(источник).
Что касается обычного контекстного меню, View должен создать меню (source), а затем обработать взаимодействие в обратном методе (источник).
Поскольку метод обработки public
, мы можем просто подключить его, расширив EditText
и перезаписав метод для реагирования на различные действия. Вот пример-реализация:
import android.content.Context;
import android.util.AttributeSet;
import android.widget.EditText;
import android.widget.Toast;
/**
* An EditText, which notifies when something was cut/copied/pasted inside it.
* @author Lukas Knuth
* @version 1.0
*/
public class MonitoringEditText extends EditText {
private final Context context;
/*
Just the constructors to create a new EditText...
*/
public MonitoringEditText(Context context) {
super(context);
this.context = context;
}
public MonitoringEditText(Context context, AttributeSet attrs) {
super(context, attrs);
this.context = context;
}
public MonitoringEditText(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
this.context = context;
}
/**
* <p>This is where the "magic" happens.</p>
* <p>The menu used to cut/copy/paste is a normal ContextMenu, which allows us to
* overwrite the consuming method and react on the different events.</p>
* @see <a href="http://grepcode.com/file/repository.grepcode.com/java/ext/com.google.android/android/2.3_r1/android/widget/TextView.java#TextView.onTextContextMenuItem%28int%29">Original Implementation</a>
*/
@Override
public boolean onTextContextMenuItem(int id) {
// Do your thing:
boolean consumed = super.onTextContextMenuItem(id);
// React:
switch (id){
case android.R.id.cut:
onTextCut();
break;
case android.R.id.paste:
onTextPaste();
break;
case android.R.id.copy:
onTextCopy();
}
return consumed;
}
/**
* Text was cut from this EditText.
*/
public void onTextCut(){
Toast.makeText(context, "Cut!", Toast.LENGTH_SHORT).show();
}
/**
* Text was copied from this EditText.
*/
public void onTextCopy(){
Toast.makeText(context, "Copy!", Toast.LENGTH_SHORT).show();
}
/**
* Text was pasted into the EditText.
*/
public void onTextPaste(){
Toast.makeText(context, "Paste!", Toast.LENGTH_SHORT).show();
}
}
Теперь, когда пользователь использует cut/copy/paste, отображается Toast
(конечно, вы могли бы делать и другие вещи).
Оптимальным является то, что это работает до Android 1.5, и вам не нужно повторно создавать контекстное меню (например, предложенное в вышеупомянутом связанном вопросе), который будет сохраняйте постоянный вид платформы (например, с HTC Sense).