Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/367.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/218.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 应用程序在添加谷歌广告后意外关闭_Java_Android_Ads - Fatal编程技术网

Java 应用程序在添加谷歌广告后意外关闭

Java 应用程序在添加谷歌广告后意外关闭,java,android,ads,Java,Android,Ads,我已经创建了一个手电筒应用程序,它运行完美,没有添加任何广告单元。 但是,在代码中添加了一个广告单元之后,当我下次运行时,应用程序在我的模拟器和android设备上意外关闭。 这是我的上述应用程序的来源。 activity\u main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xm

我已经创建了一个手电筒应用程序,它运行完美,没有添加任何广告单元。 但是,在代码中添加了一个广告单元之后,当我下次运行时,应用程序在我的模拟器和android设备上意外关闭。 这是我的上述应用程序的来源。
activity\u main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:ads="http://schemas.android.com/apk/lib/com.google.ads"
android:id="@+id/rellayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@layout/radial_background"
tools:context=".MainActivity"
tools:ignore="Overdraw" >
...
...
<com.google.ads.AdView
    android:id="@+id/adView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/textView1"
    android:layout_alignParentLeft="true"
    ads:adSize="BANNER"
    ads:adUnitId="xxxxxxx"
    ads:loadAdOnCreate="true"
    ads:testDevices="TEST_EMULATOR" >
</com.google.ads.AdView>
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.jdev.itorch"
android:versionCode="1"
android:versionName="1.1.2" android:installLocation="auto" xmlns:tools="http://schemas.android.com/tools">

<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="17" tools:ignore="OldTargetApi"/>

<uses-permission android:name="android.permission.CAMERA" />
<uses-feature android:name="android.hardware.camera" />
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity 
        android:name="com.google.ads.AdActivity"
        android:configChanges="keyboard|keyboardHidden|orientation"
        ></activity>
    <activity
        android:name="com.jdev.itorch.TorchActivity"
        android:label="@string/app_name"
        android:screenOrientation="portrait">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>
另外,代码在编译时没有显示错误。 我还检查了
logCat
,它在主活动启动时显示了一些
NullPointerException
错误。 我不知道如何处理我的代码,这就是为什么我在这里寻求帮助

这是完整的代码

import android.media.MediaPlayer;
import android.media.MediaPlayer.OnCompletionListener;
import android.os.Bundle;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.pm.PackageManager;
import android.hardware.Camera;
import android.hardware.Camera.Parameters;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.widget.ImageButton;


public class TorchActivity extends Activity {

ImageButton btnSwitch;

private Camera camera;
private boolean isFlashOn;
private boolean hasFlash;
private Parameters params;
MediaPlayer mp;


@SuppressWarnings("deprecation")
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_torch);    




    btnSwitch = (ImageButton) findViewById(R.id.btnSwitch);



    hasFlash = getApplicationContext().getPackageManager()
            .hasSystemFeature(PackageManager.FEATURE_CAMERA_FLASH);

    if (!hasFlash) {
        AlertDialog alert = new AlertDialog.Builder(TorchActivity.this)
                .create();
        alert.setTitle("Error");
        alert.setMessage("Sorry, your device doesn't support flash light!");
        alert.setButton("OK", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int which) {

                finish();
            }
        });
        alert.show();
        return;
    }


    getCamera();


    toggleButtonImage();



    btnSwitch.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            if (isFlashOn) {

                turnOffFlash();
            } else {

                turnOnFlash();
            }
        }
    });
}



private void getCamera() {
    if (camera == null) {
        try {
            camera = Camera.open();
            params = camera.getParameters();
        } catch (RuntimeException e) {
            Log.e("Camera Error. Failed to Open. Error: ", e.getMessage());
        }
    }
}



private void turnOnFlash() {
    if (!isFlashOn) {
        if (camera == null || params == null) {
            return;
        }

        playSound();

        params = camera.getParameters();
        params.setFlashMode(Parameters.FLASH_MODE_TORCH);
        camera.setParameters(params);
        camera.startPreview();
        isFlashOn = true;


        toggleButtonImage();
    }

}



private void turnOffFlash() {
    if (isFlashOn) {
        if (camera == null || params == null) {
            return;
        }

        playSound();

        params = camera.getParameters();
        params.setFlashMode(Parameters.FLASH_MODE_OFF);
        camera.setParameters(params);
        camera.stopPreview();
        isFlashOn = false;


        toggleButtonImage();
    }
}



private void playSound(){
    if(isFlashOn){
        mp = MediaPlayer.create(TorchActivity.this, R.raw.light_switch_off);
    }else{
        mp = MediaPlayer.create(TorchActivity.this, R.raw.light_switch_on);
    }
    mp.setOnCompletionListener(new OnCompletionListener() {

        @Override
        public void onCompletion(MediaPlayer mp) {
            // TODO Auto-generated method stub
            mp.release();
        }
    }); 
    mp.start();
}


private void toggleButtonImage(){
    if(isFlashOn){
        btnSwitch.setImageResource(R.drawable.btn_switch_on);
    }else{
        btnSwitch.setImageResource(R.drawable.btn_switch_off);
    }
}

@Override
protected void onDestroy() {
    super.onDestroy();
}

@Override
protected void onPause() {
    super.onPause();


    turnOffFlash();
}

@Override
protected void onRestart() {
    super.onRestart();
}

@Override
protected void onResume() {
    super.onResume();


    if(hasFlash)
        turnOnFlash();
}

@Override
protected void onStart() {
    super.onStart();


    getCamera();
}

@Override
protected void onStop() {
    super.onStop();


    if (camera != null) {
        camera.release();
        camera = null;
    }
}





@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.torch, menu);
    return true;
}

}
更新 这是
LogCat
数据

03-18 09:11:43.572: D/dalvikvm(1052): GC_FOR_ALLOC freed 80K, 5% free 3068K/3224K, paused 32ms, total 34ms
03-18 09:11:43.582: I/dalvikvm-heap(1052): Grow heap (frag case) to 3.673MB for 635812-byte allocation
03-18 09:11:43.622: D/dalvikvm(1052): GC_FOR_ALLOC freed 4K, 5% free 3684K/3848K, paused 37ms, total 37ms
03-18 09:11:43.792: D/AndroidRuntime(1052): Shutting down VM
03-18 09:11:43.792: W/dalvikvm(1052): threadid=1: thread exiting with uncaught exception (group=0xb3aa7b90)
03-18 09:11:43.832: E/AndroidRuntime(1052): FATAL EXCEPTION: main
03-18 09:11:43.832: E/AndroidRuntime(1052): Process: com.jdev.itorch, PID: 1052
03-18 09:11:43.832: E/AndroidRuntime(1052): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.jdev.itorch/com.jdev.itorch.TorchActivity}: java.lang.NullPointerException: println needs a message
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2176)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.app.ActivityThread.access$700(ActivityThread.java:135)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.os.Handler.dispatchMessage(Handler.java:102)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.os.Looper.loop(Looper.java:137)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at   android.app.ActivityThread.main(ActivityThread.java:4998)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at java.lang.reflect.Method.invokeNative(Native Method)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at java.lang.reflect.Method.invoke(Method.java:515)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at dalvik.system.NativeStart.main(Native Method)
03-18 09:11:43.832: E/AndroidRuntime(1052): Caused by: java.lang.NullPointerException: println needs a message
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.util.Log.println_native(Native Method)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.util.Log.e(Log.java:232)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at com.jdev.itorch.TorchActivity.getCamera(TorchActivity.java:91)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at com.jdev.itorch.TorchActivity.onStart(TorchActivity.java:199)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.app.Activity.performStart(Activity.java:5253)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2149)
03-18 09:11:43.832: E/AndroidRuntime(1052):     ... 11 more
03-18 09:16:44.422: I/Process(1052): Sending signal. PID: 1052 SIG: 9

LogCat中的这三条线看起来可疑:

03-18 09:11:43.832: E/AndroidRuntime(1052): Caused by: java.lang.NullPointerException: println needs a message
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.util.Log.println_native(Native Method)
03-18 09:11:43.832: E/AndroidRuntime(1052):     at android.util.Log.e(Log.java:232)
这是您唯一的
Log.e()
调用:

Log.e("Camera Error. Failed to Open. Error: ", e.getMessage());
e.getMessage()
可能是
null
。你应该检查一下


编辑:以下是一个示例:

if(e.getMessage() == null) {
    Log.e("Camera Error.  Failed to Open.",  "Error message is null");
}

else {
    Log.e("Camera Error.  Failed to Open.  Error: ", e.getMessage());
}

我想我理解@Tyler
提到的这段代码中的实际问题是什么。e.getMessage()可能为null
但他举的例子更进一步,有点出错。
我过去常常申报
public volatile String errorMessage=”“

我是这样实现的:

private void getCamera() {
    if (camera == null) {
        try {
            camera = Camera.open();
            params = camera.getParameters();
        } catch (RuntimeException e) {
            Log.e("Camera Error. Failed to Open. Error: ", e.getMessage());
            if(e.getMessage() == null) {
                errorMessage = "Camera Error.  Failed to Open.  Error message is null"; //here//
            }

            else {
                Log.e("Camera Error.  Failed to Open.  Error: ", e.getMessage());
            }
        }
    }
}
谢谢你的支持
向Jai Sharma致意。

您可能也想发布代码。好的,最后一件事,我们还需要完整的stacktrace,有日志吗?当然,只需查看下一个编辑我使用
log.e()
函数
getCamera()
在应用程序无法定位摄像头时显示错误消息,即
getCamera()
。因此,在我显示错误的方法中是否存在任何错误?您应该检查
e.getMessage()
是否为空。我将用一个例子编辑我的答案。但是在
if
条件之后,日志不适用于单个参数(字符串),
Log.e(字符串)这个怎么样?但是对于
else
语句,我们声明了两个字符串
Log.e(String,String)
@JaiSharma啊,是的,你是对的对不起,我忘了
Log.e()
需要两个参数。