2013-04-05 64 views
0

Ahm,嘿,大家,我只想问在我创建的程序中有什么问题。下面是摘录代码调用公共方法导致NullPointerException - Android

PlayActivity.class

//more codes here 
public void stFLabel(int numFace, Context ct) { 

    try { 
     if(numFace > 0) 
      faceLebel.setText("Face Hint : I See You Human"); 
     else 
      faceLebel.setText("Face Hint : Where Are You?"); 
    } 
    catch(NullPointerException e) 
    { 
     e.printStackTrace(); 
      Log.d(TAG, "stFLabel Has Error"); 
     } 
    } 
//more codes here 

* CameraPreview.class *

//More codes 
... 
PlayActivity pacT = new PlayActivity(); 
... 
//More Codes 
.. 
public void pausy(int numFace) { 
pacT.stFLabel(numFace, mContext); 
} 

logcat的

04-05 16:11:26.150: D/FaceDetection(27929): face detected: 1 Face 1 Location X: 65Y: -1 
04-05 16:11:26.150: W/System.err(27929): java.lang.NullPointerException 
04-05 16:11:26.150: W/System.err(27929): at com.delihente.faceplay.PlayActivity.stFLabel(PlayActivity.java:90) 
04-05 16:11:26.150: W/System.err(27929): at com.delihente.faceplay.CameraPreview.pausy(CameraPreview.java:62) 
04-05 16:11:26.150: W/System.err(27929): at com.delihente.faceplay.CameraPreview$1.onFaceDetection(CameraPreview.java:53) 
04-05 16:11:26.150: W/System.err(27929): at android.hardware.Camera$EventHandler.handleMessage(Camera.java) 
04-05 16:11:26.150: W/System.err(27929): at android.os.Handler.dispatchMessage(Handler.java) 
04-05 16:11:26.150: W/System.err(27929): at android.os.Looper.loop(Looper.java) 
04-05 16:11:26.150: W/System.err(27929): at android.app.ActivityThread.main(ActivityThread.java) 
04-05 16:11:26.150: W/System.err(27929): at java.lang.reflect.Method.invokeNative(Native Method) 
04-05 16:11:26.150: W/System.err(27929): at java.lang.reflect.Method.invoke(Method.java:511) 
04-05 16:11:26.150: W/System.err(27929): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java) 
04-05 16:11:26.150: W/System.err(27929): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java) 
04-05 16:11:26.150: W/System.err(27929): at dalvik.system.NativeStart.main(Native Method) 
04-05 16:11:26.150: D/(27929): stFLabel Has Error 

更多信息:

PlayAcvitiy.class extends Activity (Main Class) 
CameraPreview.class - The camera preview class provided by google android development 
faceLebel = TextView on PlayAcvitiy.class 
mContext = PlayActivity.class Context 

我想知道是什么原因造成的NullPointerException异常(A修复会更好), 我看了一下我的问题,近3页的谷歌搜索,但没有它具有帮助过我。 也请不要提及将方法更改为static,因为它不能因为它在CameraPreview.class检测到/未检测到面时更改TextView标签。 在此先感谢!

编辑:我也看过很多相关的问题在这里,但他们都不来帮助

编辑2:问题迎刃而解,感谢所有,特别是对PrafulBhatnagar,我已经了解到,使用方法在主要活动中需要参考其上下文。感谢大家!

+0

尝试'((PlayActivity)mContext ).stFLabel(numFace,mContext);'...假设'mContext'存储对'PlayActivity'的引用 – 2013-04-05 08:23:55

+0

你试图从一个空对象中调用/获取某些东西。当你调用setText()时,它可能是“faceLebel”。调试它 – 2013-04-05 08:24:41

+0

'faceLebel'是否正确声明?似乎它是唯一可以抛出的东西。 – Skepi 2013-04-05 08:25:54

回答

0

在Android中你不应该自己创建活动对象之前..

当你启动应用程序,从应用程序托盘中的系统,为您启动Activity创建对象并启动它。我们使用startActivity()如果我们想要去从一个屏幕到另一个,这里又系统创建的Activity对象..

所以一般系统创建对象的活动,并呼吁其生命周期方法类似onCreate(), onStart()等。而我们使用这些生命周期回调初始化/去初始化Activity的状态..

在你的代码的问题是你试图自己创建Activity对象;所以现在有两个由系统创建的实例,其中所有状态都已初始化,并且由您的代码创建一个实例,因为没有调用生命周期方法,因此类的状态尚未初始化,因此NullPointerException

您可以使用下面的代码来解决此错误:

((PlayActivity)mContext).stFLabel(numFace, mContext); ...假设mContext存储参考PlayActivity

希望它有助于..

1

NullPointerException的唯一原因是,

faceLebel内部stFLabel()方法。

只要确保您的faceLebel使用的是您当前活动布局xml具有的相同ID。

此外,请确保您已申报setContentView(<R.layout.xml_File_Name>);在活动的oncreate()super.onCreate().

更新:

我有打电话给你的方法stFLabel()CameraPreview.class的疑问。因为你不能让Activity的构造函数像,PlayActivity pacT = new PlayActivity();

你必须使用活动上下文来调用这个方法。

+0

哦,我看到了,所以这就是原因:)。 我想我真的需要做更多的自学android编程。你说的一个,“使用活动的上下文来调用这个方法”,我真的不知道该怎么做,但我想这将是@ PrafulBhatnagar的答案(如果我没有错) – 2013-04-05 08:40:17

0

检查是否faceLeble开始像下面调用设置拉布勒

faceLebel = (TextView)findViewById(R.id.txtViewId); 
相关问题