Android App不会在模拟器中显示

时间:2011-02-25 16:26:25

标签: android android-emulator

首先,我想说的是,对于Android(或Java,就此而言)我是一个新手,所以我很可能在一个非常基本的层面上做错了 - 请保留这个记住。

我将基本上包括整个来源,因为我不知道问题所在的位置(在任何人建议我尝试使用Google之前,我已经花了最近几天这样做了。)

当我尝试运行或调试应用程序时收到以下错误消息时出现问题:

eclipse.buildId=M20100909-0800
java.version=1.6.0_24
java.vendor=Sun Microsystems Inc.
BootLoader constants: OS=win32, ARCH=x86, WS=win32, NL=en_NZ
Framework arguments:  -product org.eclipse.epp.package.java.product
Command-line arguments:  -os win32 -ws win32 -arch x86 -product org.eclipse.epp.package.java.product


Error
Fri Feb 25 15:52:44 CET 2011
No command output when running: 'am start -n com.company.android.app/com.company.android.app.Home -a android.intent.action.MAIN -c android.intent.category.LAUNCHER' on device emulator-5554

com.android.ddmlib.ShellCommandUnresponsiveException
at com.android.ddmlib.AdbHelper.executeRemoteCommand(AdbHelper.java:408)
at com.android.ddmlib.Device.executeShellCommand(Device.java:276)
at com.android.ide.eclipse.adt.internal.launch.ActivityLaunchAction.doLaunchAction(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController.launchApp(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController.simpleLaunch(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController.access$3(Unknown Source)
at com.android.ide.eclipse.adt.internal.launch.AndroidLaunchController$3.run(Unknown Source)

该应用程序是一个非常基本的东西。它有一个Activity,在视图中包含以下XML代码:

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/helloAndroid" 
    android:text="" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
/>

以下代码在Activity的* .java中:

package com.company.android.app;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.webkit.WebView;
import android.widget.TextView;

public class Home extends Activity {

    TextView helloWorld;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        helloWorld = ( TextView ) findViewById( R.id.helloAndroid );
        helloWorld.setText( "Hello Android!" );
    }
}

最后,在我的AndroidManifest.xml中:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.company.android.app"
      android:versionCode="1"
      android:versionName="1.0">
    <uses-sdk android:minSdkVersion="7" />

    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".Home"
                  android:label="@string/app_name"
                  android:theme="@android:style/Theme.NoTitleBar">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

    </application>

    <uses-permission android:name="android.permission.INTERNET" />
</manifest>

当我运行或调试应用程序时,我在控制台中看到以下内容:

[2011-02-25 16:22:52 - com.company.android.app] adb is running normally.
[2011-02-25 16:22:52 - com.company.android.app] Performing com.company.android.app.Home activity launch
[2011-02-25 16:22:52 - com.company.android.app] Automatic Target Mode: using existing emulator 'emulator-5554' running compatible AVD 'Android-2.3.3'
[2011-02-25 16:22:57 - com.company.android.app] Uploading com.company.android.app.apk onto device 'emulator-5554'
[2011-02-25 16:23:00 - com.company.android.app] Installing com.company.android.app.apk...
[2011-02-25 16:23:22 - com.company.android.app] Success!
[2011-02-25 16:23:23 - com.company.android.app] Starting activity com.company.android.app.Home on device emulator-5554

一点额外信息:

  • 模拟器打开并运行 - 但永远不会超越Android启动图像,也无法通过按钮进行交互(即“主页”不执行任何操作)。
  • 该应用针对的是Android 2.1-update1。

我想不出任何其他内容。

可能导致此问题的任何想法?

非常感谢提前。 扎克

2 个答案:

答案 0 :(得分:0)

我不明白(在eclipse中)你得到第一个错误日志。

你的代码非常正确,即使我在TextView周围没有使用任何布局(因为只是一个TextView没用),这很奇怪,在这里找到运行...

首先,您应该尝试运行“从头开始”的android项目并检查: 1.模拟器上生成的HelloWorld; 2.检查logcat视图并找到类似“ActivityManager显示的活动com.yourpackage.youractivity”的内容

如果它确实有效,请逐步使用程序化UI定义来满足您的需求。

无论如何,你应该使用“Log.i(”MyApp“,”on onCreate()“);”如果有任何异常,请检查logcat(logcat视图是你的朋友)。

雷诺

答案 1 :(得分:0)

我找到的解决方案是由@erichamion在我的问题评论中提供的。我通过AVD Manager重新启动了模拟器,并选中了“擦除用户数据”选项,并且未选中“从快照启动”选项。

我怀疑当我第一次加载模拟器时,它被我打断了,并且处于无法操作的状态。通过加载具有新状态的仿真器,清除用户数据并擦除快照克服了该问题。

感谢您的帮助...