Alguém poderia me ajudar a criar uma interface de ouvinte definida pelo usuário com alguns trechos de código?
Alguém poderia me ajudar a criar uma interface de ouvinte definida pelo usuário com alguns trechos de código?
Respostas:
Crie um novo arquivo:
MyListener.java:
public interface MyListener {
// you can define any parameter as per your requirement
public void callback(View view, String result);
}
Na sua atividade, implemente a interface:
MyActivity.java:
public class MyActivity extends Activity implements MyListener {
@override
public void onCreate(){
MyButton m = new MyButton(this);
}
// method is invoked when MyButton is clicked
@override
public void callback(View view, String result) {
// do your stuff here
}
}
Na sua classe personalizada, chame a interface quando necessário:
MyButton.java:
public class MyButton {
MyListener ml;
// constructor
MyButton(MyListener ml) {
//Setting the listener
this.ml = ml;
}
public void MyLogicToIntimateOthers() {
//Invoke the interface
ml.callback(this, "success");
}
}
WeakReference<>neste caso, mas então você não pode fazer o ouvinte uma classe anônima ou qualquer coisa onde o ouvinte não tem outras referências ... então seria preferível não usá-lo
leia o padrão de observador
interface do ouvinte
public interface OnEventListener {
void onEvent(EventResult er);
// or void onEvent(); as per your need
}
então na sua classe diga Eventclasse
public class Event {
private OnEventListener mOnEventListener;
public void setOnEventListener(OnEventListener listener) {
mOnEventListener = listener;
}
public void doEvent() {
/*
* code code code
*/
// and in the end
if (mOnEventListener != null)
mOnEventListener.onEvent(eventResult); // event result object :)
}
}
na sua classe de motorista MyTestDriver
public class MyTestDriver {
public static void main(String[] args) {
Event e = new Event();
e.setOnEventListener(new OnEventListener() {
public void onEvent(EventResult er) {
// do your work.
}
});
e.doEvent();
}
}
Eu criei um ouvinte genérico do AsyncTask que obtém resultado da classe separada do AsycTask e o fornece a CallingActivity usando o retorno de chamada da interface.
new GenericAsyncTask(context,new AsyncTaskCompleteListener()
{
public void onTaskComplete(String response)
{
// do your work.
}
}).execute();
Interface
interface AsyncTaskCompleteListener<T> {
public void onTaskComplete(T result);
}
GenericAsyncTask
class GenericAsyncTask extends AsyncTask<String, Void, String>
{
private AsyncTaskCompleteListener<String> callback;
public A(Context context, AsyncTaskCompleteListener<String> cb) {
this.context = context;
this.callback = cb;
}
protected void onPostExecute(String result) {
finalResult = result;
callback.onTaskComplete(result);
}
}
Dê uma olhada nisso , esta pergunta para mais detalhes.
Existem 4 etapas:
1.criar classe de interface (ouvinte)
2.usar interface na visualização 1 (definir variável)
Interface 3.implements para visualizar 2 (vista 1 usada na vista 2)
Interface 4.pass na vista 1 para ver 2
Exemplo:
Etapa 1: você precisa criar interface e função definida
public interface onAddTextViewCustomListener {
void onAddText(String text);
}
Etapa 2: use esta interface na exibição
public class CTextView extends TextView {
onAddTextViewCustomListener onAddTextViewCustomListener; //listener custom
public CTextView(Context context, onAddTextViewCustomListener onAddTextViewCustomListener) {
super(context);
this.onAddTextViewCustomListener = onAddTextViewCustomListener;
init(context, null);
}
public CTextView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
init(context, attrs);
}
public CTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context, attrs);
}
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
public CTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
init(context, attrs);
}
public void init(Context context, @Nullable AttributeSet attrs) {
if (isInEditMode())
return;
//call listener
onAddTextViewCustomListener.onAddText("this TextView added");
}
}
Etapa 3,4: implementa a atividade
public class MainActivity extends AppCompatActivity implements onAddTextViewCustomListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//get main view from layout
RelativeLayout mainView = (RelativeLayout)findViewById(R.id.mainView);
//create new CTextView and set listener
CTextView cTextView = new CTextView(getApplicationContext(), this);
//add cTextView to mainView
mainView.addView(cTextView);
}
@Override
public void onAddText(String text) {
Log.i("Message ", text);
}
}
Crie interface de ouvinte.
public interface YourCustomListener
{
public void onCustomClick(View view);
// pass view as argument or whatever you want.
}
E crie o método setOnCustomClick em outra atividade (ou fragmento), onde você deseja aplicar seu ouvinte personalizado ......
public void setCustomClickListener(YourCustomListener yourCustomListener)
{
this.yourCustomListener= yourCustomListener;
}
Chame esse método da sua primeira atividade e passe a interface do ouvinte ...
No ano de 2018, não há necessidade de interfaces de ouvintes. Você tem o Android LiveData para passar o resultado desejado de volta aos componentes da interface do usuário.
Se eu pegar a resposta de Rupesh e ajustá-la para usar o LiveData, será assim:
public class Event {
public LiveData<EventResult> doEvent() {
/*
* code code code
*/
// and in the end
LiveData<EventResult> result = new MutableLiveData<>();
result.setValue(eventResult);
return result;
}
}
e agora na sua classe de driver MyTestDriver:
public class MyTestDriver {
public static void main(String[] args) {
Event e = new Event();
e.doEvent().observe(this, new Observer<EventResult>() {
@Override
public void onChanged(final EventResult er) {
// do your work.
}
});
}
}
Para obter mais informações, juntamente com exemplos de código, você pode ler minha postagem sobre ele, bem como os documentos oficiais:
No Android, você pode criar uma interface como o Ouvinte, e sua Atividade a implementa, mas não acho que seja uma boa ideia. se tivermos muitos componentes para escutar as alterações de seu estado, podemos criar uma baseListener implementa a interface Listener e usar o código de tipo para lidar com eles. podemos ligar o método quando criamos um arquivo XML, por exemplo:
<Button
android:id="@+id/button4"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Button4"
android:onClick="Btn4OnClick" />
e o código fonte:
public void Btn4OnClick(View view) {
String strTmp = "点击Button04";
tv.setText(strTmp);
}
mas não acho que seja uma boa ideia ...
Eu fiz algo como abaixo para enviar minha classe de modelo da Segunda Atividade para a Primeira Atividade. Eu usei o LiveData para conseguir isso, com a ajuda de respostas de Rupesh e TheCodeFather.
Segunda atividade
public static MutableLiveData<AudioListModel> getLiveSong() {
MutableLiveData<AudioListModel> result = new MutableLiveData<>();
result.setValue(liveSong);
return result;
}
"liveSong" é AudioListModel declarado globalmente
Chame esse método na Primeira atividade
PlayerActivity.getLiveSong().observe(this, new Observer<AudioListModel>() {
@Override
public void onChanged(AudioListModel audioListModel) {
if (PlayerActivity.mediaPlayer != null && PlayerActivity.mediaPlayer.isPlaying()) {
Log.d("LiveSong--->Changes-->", audioListModel.getSongName());
}
}
});
Que isso ajude para novos exploradores como eu.
Método simples para fazer essa abordagem. Em primeiro lugar, implementa o OnClickListenersna sua classe Activity.
Código:
class MainActivity extends Activity implements OnClickListeners{
protected void OnCreate(Bundle bundle)
{
super.onCreate(bundle);
setContentView(R.layout.activity_main.xml);
Button b1=(Button)findViewById(R.id.sipsi);
Button b2=(Button)findViewById(R.id.pipsi);
b1.SetOnClickListener(this);
b2.SetOnClickListener(this);
}
public void OnClick(View V)
{
int i=v.getId();
switch(i)
{
case R.id.sipsi:
{
//you can do anything from this button
break;
}
case R.id.pipsi:
{
//you can do anything from this button
break;
}
}
}