1

При запуске моего приложения в Android Studio я получаю NullPointerException на линии 30, которая заключается в следующем:NullPointerException: SetOnClickListener (это) - Android

llTheory.setOnClickListener(this); 

, который всегда работал для меня .. Я реализую View.OnClickListener и есть метод коррекции здесь:

@Override 
public void onClick(View v) { 
    .... 
} 

Мой LinearLayout объявлен перед setOnClickListener здесь:

LinearLayout llTheory = (LinearLayout) findViewById(R.id.llTheory); 

так что происходит не так? Вот мой выход LogCat:

10-20 21:09:24.045 14625-14625/com.timmo.applauncher E/AndroidRuntime﹕ FATAL EXCEPTION: main 
    Process: com.timmo.applauncher, PID: 14625 
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.timmo.applauncher/com.timmo.timmoapplauncher.Main}: java.lang.NullPointerException 
      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2224) 
      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2283) 
      at android.app.ActivityThread.access$800(ActivityThread.java:144) 
      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1205) 
      at android.os.Handler.dispatchMessage(Handler.java:102) 
      at android.os.Looper.loop(Looper.java:136) 
      at android.app.ActivityThread.main(ActivityThread.java:5153) 
      at java.lang.reflect.Method.invokeNative(Native Method) 
      at java.lang.reflect.Method.invoke(Method.java:515) 
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796) 
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612) 
      at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132) 
      at dalvik.system.NativeStart.main(Native Method) 
    Caused by: java.lang.NullPointerException 
      at com.timmo.timmoapplauncher.Main.Init(Main.java:30) 
      at com.timmo.timmoapplauncher.Main.onCreate(Main.java:78) 
      at android.app.Activity.performCreate(Activity.java:5312) 
      at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 
      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2181) 
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2283) 
            at android.app.ActivityThread.access$800(ActivityThread.java:144) 
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1205) 
            at android.os.Handler.dispatchMessage(Handler.java:102) 
            at android.os.Looper.loop(Looper.java:136) 
            at android.app.ActivityThread.main(ActivityThread.java:5153) 
            at java.lang.reflect.Method.invokeNative(Native Method) 
            at java.lang.reflect.Method.invoke(Method.java:515) 
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796) 
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612) 
            at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132) 
            at dalvik.system.NativeStart.main(Native Method) 
+0

Вы используете фрагменты? – SeahawksRdaBest

+0

Да @SeahawksRdaBest Первый раз, так что я, вероятно, что-то делаю неправильно – Timmo

+0

- это свойство вашего макета, доступное в true для вашего xml-файла – vembutech

ответ

1

Фрагменты работают немного по-другому.

Вы должны использовать концепцию rootview при работе с ними. В противном случае вы обнаружите, что всегда встречаете страшное исключение «NULL POINTER».

Вот как это сделать.

Определите корень, когда вы надуваете каждый вид для каждого фрагмента, а затем вызываете функциональность onClick.

public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState){ 
    View rootview = inflater.inflate(R.layout.xml_you_want_to_inflate, container,false);   
    // Now call rootview and the onclick fuction, presumably for a list or button 
    rootview.findViewById(R.id.your_button/list_id_here).setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
     // Do stuff. 
     } 
    }); 

Другой альтернативой является использование getView, которая всегда возвращает rootview. Попробуйте это вместо

LinearLayout llTheory = (LinearLayout) getView().findViewById(R.id.llTheory); 

Этот link объясняет подобную проблему.

Первый способ, однако, является правильным способом, поскольку вы изолируете свои фрагменты друг от друга и правильно понимаете иерархию представлений. Я бы читал this. Поверьте мне, что время, затрачиваемое на чтение инвестиций, стоит того, чтобы потратить время, потраченное на то, чтобы разобраться с идеями о том, как работать с уловкой.

+0

Спасибо за информацию. Мне определенно придется читать на фрагментах спасибо. – Timmo

0

findViewByIdreturns a null value когда запрашиваемый вид не может быть найден.

  • Проверьте в вашем соответствующем XML, что вид действительно объявлен с идентификатором @id/llTheory
  • standard Java best practice будет проверять с приведением элемента перед его использованием.
0

У вас есть

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.layout_with_R_id_llTheory); 
... 

в вашей деятельности? Ваша деятельность (или фрагмент, размещенный по активности) должна иметь макет с R.id.llTheory.

Смежные вопросы