दूसरों ने पहले ही कहा है कि ऑनक्लिक में विधियाँ गतिविधियों में खोजी जाती हैं, टुकड़ों में नहीं। फिर भी, यदि आप वास्तव में चाहते हैं, तो यह संभव है।
मूल रूप से, प्रत्येक दृश्य में एक टैग (शायद अशक्त) होता है। हमने उस दृश्य को भड़काने वाले मूल दृश्य का टैग सेट किया है। फिर, देखने वाले माता-पिता की खोज करना और क्लिक किए गए बटन वाले टुकड़े को पुनः प्राप्त करना आसान है। अब, हम विधि नाम का पता लगाते हैं और उसी खंड को पुनर्प्राप्त खंड से कॉल करने के लिए प्रतिबिंब का उपयोग करते हैं। आसान!
एक कक्षा में जो फैली हुई है Fragment
:
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_id, container, false);
OnClickFragments.registerTagFragment(rootView, this); // <========== !!!!!
return rootView;
}
public void onButtonSomething(View v) {
Log.d("~~~","~~~ MyFragment.onButtonSomething");
// whatever
}
सभी गतिविधियाँ समान ButtonHandlingActivity से ली गई हैं:
public class PageListActivity extends ButtonHandlingActivity
ButtonHandlingActivity.java:
public class ButtonHandlingActivity extends Activity {
public void onButtonSomething(View v) {
OnClickFragments.invokeFragmentButtonHandlerNoExc(v);
//or, if you want to handle exceptions:
// try {
// OnClickFragments.invokeFragmentButtonHandler(v);
// } catch ...
}
}
यह सभी xml onClick हैंडलर के लिए विधियों को परिभाषित करना है।
com / उदाहरण / customandroid / OnClickFragments.java:
package com.example.customandroid;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import android.app.Fragment;
import android.view.View;
public abstract class OnClickFragments {
public static class FragmentHolder {
Fragment fragment;
public FragmentHolder(Fragment fragment) {
this.fragment = fragment;
}
}
public static Fragment getTagFragment(View view) {
for (View v = view; v != null; v = (v.getParent() instanceof View) ? (View)v.getParent() : null) {
Object tag = v.getTag();
if (tag != null && tag instanceof FragmentHolder) {
return ((FragmentHolder)tag).fragment;
}
}
return null;
}
public static String getCallingMethodName(int callsAbove) {
Exception e = new Exception();
e.fillInStackTrace();
String methodName = e.getStackTrace()[callsAbove+1].getMethodName();
return methodName;
}
public static void invokeFragmentButtonHandler(View v, int callsAbove) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException, NoSuchMethodException {
String methodName = getCallingMethodName(callsAbove+1);
Fragment f = OnClickFragments.getTagFragment(v);
Method m = f.getClass().getMethod(methodName, new Class[] { View.class });
m.invoke(f, v);
}
public static void invokeFragmentButtonHandler(View v) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException, NoSuchMethodException {
invokeFragmentButtonHandler(v,1);
}
public static void invokeFragmentButtonHandlerNoExc(View v) {
try {
invokeFragmentButtonHandler(v,1);
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
public static void registerTagFragment(View rootView, Fragment fragment) {
rootView.setTag(new FragmentHolder(fragment));
}
}
और अगले साहसिक कार्य की भविष्यवाणी की जाएगी ...
पुनश्च
यह निश्चित रूप से आप पर निर्भर है कि आप अपने एप्लिकेशन को डिजाइन करें ताकि डेटा एक्टिविटी या फ्रैगमेंट्स (जो MVC से कंट्रोलर , मॉडल-व्यू-कंट्रोलर पॉइंट ऑफ व्यू) के बजाय मॉडल में रहते हैं । देखें आप एक्सएमएल के माध्यम से क्या परिभाषित, प्लस कस्टम दृश्य वर्गों (यदि आप उन्हें परिभाषित करते हैं, अधिकांश लोग बस का पुन: उपयोग पहले से ही है क्या) है। अंगूठे का एक नियम: यदि कुछ डेटा को निश्चित रूप से स्क्रीन मोड़ से बचना चाहिए, तो वे मॉडल से संबंधित हैं ।