Може хтось допоможе мені створити призначений користувачем інтерфейс слухача з деякими фрагментами коду?
Може хтось допоможе мені створити призначений користувачем інтерфейс слухача з деякими фрагментами коду?
Відповіді:
Створіть новий файл:
MyListener.java:
public interface MyListener {
// you can define any parameter as per your requirement
public void callback(View view, String result);
}
У своїй діяльності реалізуйте інтерфейс:
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
}
}
У вашому користувальницькому класі за допомогою інтерфейсу використовуйте:
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<>в цьому випадку, але тоді ви не можете зробити слухача анонімним класом або будь-яким іншим, де у слухача немає інших посилань ... тож краще не використовувати його
будь ласка, прочитайте модель спостерігача
інтерфейс слухача
public interface OnEventListener {
void onEvent(EventResult er);
// or void onEvent(); as per your need
}
то у вашому класі скажіть Eventклас
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 :)
}
}
у вашому класі водія 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();
}
}
Я створив загальний слухач AsyncTask, який отримує результат від окремого класу AsycTask і передає його CallingActivity за допомогою зворотного зв'язку з інтерфейсом.
new GenericAsyncTask(context,new AsyncTaskCompleteListener()
{
public void onTaskComplete(String response)
{
// do your work.
}
}).execute();
Інтерфейс
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);
}
}
Погляньте на це , це питання для більш детальної інформації.
Є 4 кроки:
1.створити клас інтерфейсу (слухач)
2.використовувати інтерфейс у перегляді 1 (визначити змінну)
3.інтерфейс для перегляду 2 (перегляд 1, використаний у перегляді 2)
4.запустіть інтерфейс у перегляді 1 для перегляду 2
Приклад:
Крок 1: вам потрібно створити інтерфейс і визначити функцію
public interface onAddTextViewCustomListener {
void onAddText(String text);
}
Крок 2: використовуйте цей інтерфейс для перегляду
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");
}
}
Крок 3,4: реалізація до діяльності
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);
}
}
Створіть інтерфейс для слухачів.
public interface YourCustomListener
{
public void onCustomClick(View view);
// pass view as argument or whatever you want.
}
І створіть метод setOnCustomClick в іншій діяльності (або фрагменті), де ви хочете застосувати власний слухач ......
public void setCustomClickListener(YourCustomListener yourCustomListener)
{
this.yourCustomListener= yourCustomListener;
}
Зателефонуйте цьому методу зі своєї Першої діяльності та передайте інтерфейс слухача ...
У 2018 році немає потреби в інтерфейсах для слухачів. У вас є Android LiveData, щоб подбати про передачу бажаного результату компонентам інтерфейсу користувача.
Якщо я візьму відповідь Рупеша і налаштую її на використання LiveData, вона сподобається так:
public class Event {
public LiveData<EventResult> doEvent() {
/*
* code code code
*/
// and in the end
LiveData<EventResult> result = new MutableLiveData<>();
result.setValue(eventResult);
return result;
}
}
і тепер у вашому класі водіїв 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.
}
});
}
}
Для отримання додаткової інформації разом із зразками коду ви можете прочитати мій пост про нього, а також офіційні документи:
В Android ви можете створити інтерфейс, такий як слухач, і ваша діяльність реалізує його, але я не думаю, що це гарна ідея. якщо у нас є багато компонентів для прослуховування змін їх стану, ми можемо створити BaseListener реалізує інтерфейс Listener і використовувати тип коду для обробки. ми можемо прив’язати метод, коли створюємо XML-файл, наприклад:
<Button
android:id="@+id/button4"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Button4"
android:onClick="Btn4OnClick" />
і вихідний код:
public void Btn4OnClick(View view) {
String strTmp = "点击Button04";
tv.setText(strTmp);
}
але я не думаю, що це гарна ідея ...
Я зробив це щось на кшталт нижче, щоб надіслати свій модельний клас із другої діяльності до першої діяльності. Я використовував LiveData, щоб досягти цього, за допомогою відповідей Rupesh та TheCodeFather.
Друга діяльність
public static MutableLiveData<AudioListModel> getLiveSong() {
MutableLiveData<AudioListModel> result = new MutableLiveData<>();
result.setValue(liveSong);
return result;
}
"liveSong" - AudioListModel, оголошений у всьому світі
Викличте цей метод у першій діяльності
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());
}
}
});
Нехай це допоможе таким дослідникам, як я.
Простий метод зробити такий підхід. По-перше, реалізує OnClickListenersу вашому класі активності.
Код:
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;
}
}
}