Spinnerを拡張するカスタムViewクラスがあります。ユーザーが選択したときに、アクティビティが埋め込まれているアクティビティと話す正しい方法を理解しようとしています。リスナーがアダプタへの参照を取得していることはわかりますOnItemSelected
が、このアダプタを使用してその親チェーンを何らかの方法でウォークアップする必要があるのか、それともコンテキストに直接話しかける必要があるのか(何らかの理由で)がわかりません。それが失敗する可能性のある方法を私は考えられませんが、それは安全ではありません)。
4 に答える
それを行う正しい方法は、ビューが彼のインスタンスへの参照を保持しているインターフェースを公開することによってカスタムビューを「リッスン」することであり、ホスティングアクティビティは実装する必要があります。OnItemSelectedインターフェースとまったく同じように、Androidビューが公開しているイベントが実装されます。これがオブザーバーのデザインパターンです。
例えば:
public class MyCustomSpinner extends Spinner {
public MyCustomSpinner(Context context) {
super(context);
// TODO Auto-generated constructor stub
}
public interface IMyEventListener {
public void onEventOccurred();
}
private IMyEventListener mEventListener;
public void setEventListener(IMyEventListener mEventListener) {
this.mEventListener = mEventListener;
}
protected void someMethodWhichDoingSomthingAndShouldRaiseAlsoTheEvent() {
/*
* Some Code which the function doing //more code...
*/
if (mEventListener != null) {
mEventListener.onEventOccurred();
}
}
}
これはあなたがあなたの活動からそれをどのように使うかです:
mMyCustomSpinner.setEventListener(new IMyEventListener() {
@Override
public void onEventOccurred() {
// TODO Auto-generated method stub
}
});
ユーザーが選択したときに、アクティビティが埋め込まれているアクティビティと話す正しい方法を理解しようとしています。
「埋め込まれているアクティビティと話し合う」必要はありません。を担当するコントローラーと話したいView
。今日、それはかもしれませんActivity
。明日、それはかもしれませんFragment
。
OnItemSelectedリスナーがアダプターへの参照を取得していることはわかりますが、このアダプターを使用してその親チェーンを何らかの方法でウォークアップする必要があるかどうかがわかりません。
これは、インターフェイスにメソッドがないため、View
が特定のタイプのを知っていることを意味します。さらに、それはあなたをと話すことに結びつけます、それは前述のように、現時点では良い計画ではありません。Adapter
Adapter
getContext()
Activity
個人的に、私はSpinner
そもそもカスタムサブクラスを持つことについて少し疑わしいです。しかし、それには正当な理由があると仮定して、Tal Kanelのアドバイス(私がこれを書いている間に投稿した)に従い、カスタムによって宣言されているこのカスタムイベントのカスタムリスナーインターフェイスを設計する必要がありますView
。コントローラ(Activity
または)にそのインターフェイスの実装を提供してもらいFragment
ます。これは、コントローラに直接実装することも、匿名の内部クラスとして実装することもできます(Tal Kanelの回答のように)。View
必要に応じてリスナーインターフェイス。
正しい方法は、ある種のリスナーを使用することです。直接参照できると思います。コードを別のプロジェクトで再利用することはできません...
簡単な解決策-
((ParentClass) context).functionToRun();
ここで、ParentClassはアクティビティのクラス名です。