嗨,我是Android中的编码业余爱好者但我已经设法到目前为止但是已经提出了一个相对简单的问题, 第一个屏幕我插入一些文本然后打印到下一个屏幕,其中还有几个按钮,我还没有定义其中一个的意图, 它用于显示第二个活动,然后在第二个活动上单击按钮时强制关闭,但现在它甚至无法进入第二个活动。我想要的是第一个显示下一个活动的活动,按钮然后打开单独的活动可以有人告诉我哪里出错了吗?
bathactviity.java
package com.example.myapplication;
import android.os.Bundle;
import android.app.Activity;
import android.widget.Button;
public class bathactivity extends Activity {
Button button;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_bath);
button = (Button)findViewById(R.id.nextbutton);
}
}
activity_bath.xml
<LinearLayout
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
xmlns:android="http://schemas.android.com/apk/res/android">
<TextView
android:layout_width="match_parent"
android:layout_height="55dp"
android:text="@string/bath"
android:id="@+id/bath_text_View"
android:textSize="20sp"
android:gravity="center"
android:textStyle="italic" />
<ImageView
android:contentDescription="@string/bath"
android:layout_width="match_parent"
android:layout_height="404dp"
android:id="@+id/imageView"
android:layout_gravity="center"
android:src="@drawable/getdressedimg" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/next"
android:id="@+id/nextbutton"
android:textSize="20sp"
android:textStyle="bold|italic"
android:layout_gravity="center" />
</LinearLayout>
secondactivity.java
package com.example.myapplication;
import android.content.Intent;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.widget.Button;
import android.widget.TextView;
public class secondactivity extends Activity {
TextView t;
Button button;
Button button2;
Button button3;
Button button4;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);
t = (TextView)findViewById(R.id.textView3);
String n = this.getIntent().getStringExtra("NAMEDATA");
t.setText(n);
button = (Button)findViewById(R.id.button);
button2 = (Button)findViewById(R.id.button2);
button3 = (Button)findViewById(R.id.button3);
button4 = (Button)findViewById(R.id.button4);
setButtonOnClickListener();
}
private void setButtonOnClickListener(){
Intent intent = new Intent(getApplicationContext(), bathactivity.class);
startActivity(intent);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.second, menu);
return true;
}
}
不要认为这是一个明显的问题,但以防万一
android manifest
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.myapplication"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="7"
android:targetSdkVersion="18" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.myapplication.main"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name="com.example.myapplication.secondactivity"
android:label="@string/title_activity_second" >
</activity>
<activity
android:name="com.example.myapplication.bathactivity"
android:label="@string/title_activity_bath" >
</activity>
</application>
</manifest>
这不能成为你要求的logcat吗?
09-24 23:35:55.286 9460-9460/com.example.myapplication I/dalvikvm-heap﹕ Grow heap (frag case) to 10.498MB for 6860716-byte allocation
09-24 23:35:55.546 9460-9460/com.example.myapplication I/dalvikvm-heap﹕ Grow heap (frag case) to 22.127MB for 12196816-byte allocation
09-24 23:35:55.716 9460-9460/com.example.myapplication E/﹕ file /data/data/com.nvidia.NvCPLSvc/files/driverlist.txt: not found!
09-24 23:35:55.716 9460-9460/com.example.myapplication I/﹕ Attempting to load EGL implementation /system/lib//egl/libEGL_tegra_impl
09-24 23:35:55.736 9460-9460/com.example.myapplication I/﹕ Loaded EGL implementation /system/lib//egl/libEGL_tegra_impl
09-24 23:35:55.796 9460-9460/com.example.myapplication I/﹕ Loading GLESv2 implementation /system/lib//egl/libGLESv2_tegra_impl
09-24 23:36:01.116 9460-9460/com.example.myapplication W/Editor﹕ GetLabel fail! Do framework orig behavior
09-24 23:36:05.191 9460-9460/com.example.myapplication I/dalvikvm-heap﹕ Grow heap (frag case) to 38.710MB for 24023056-byte allocation
09-24 23:36:05.471 9460-9460/com.example.myapplication I/dalvikvm-heap﹕ Forcing collection of SoftReferences for 42701840-byte allocation
09-24 23:36:05.496 9460-9460/com.example.myapplication E/dalvikvm-heap﹕ Out of memory on a 42701840-byte allocation.
09-24 23:36:05.496 9460-9460/com.example.myapplication I/dalvikvm﹕ "main" prio=5 tid=1 RUNNABLE
09-24 23:36:05.496 9460-9460/com.example.myapplication I/dalvikvm﹕ | group="main" sCount=0 dsCount=0 obj=0x41bf5538 self=0x40cff010
09-24 23:36:05.496 9460-9460/com.example.myapplication I/dalvikvm﹕ | sysTid=9460 nice=0 sched=0/0 cgrp=apps handle=1075005484
09-24 23:36:05.496 9460-9460/com.example.myapplication I/dalvikvm﹕ | schedstat=( 1258665000 280174000 1050 ) utm=92 stm=33 core=3
09-24 23:36:05.496 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
09-24 23:36:05.501 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:626)
09-24 23:36:05.501 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:473)
09-24 23:36:05.506 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:781)
09-24 23:36:05.506 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.content.res.Resources.loadDrawable(Resources.java:1959)
09-24 23:36:05.506 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.content.res.TypedArray.getDrawable(TypedArray.java:601)
09-24 23:36:05.506 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.widget.ImageView.<init>(ImageView.java:120)
09-24 23:36:05.506 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.widget.ImageView.<init>(ImageView.java:110)
09-24 23:36:05.506 9460-9460/com.example.myapplication I/dalvikvm﹕ at java.lang.reflect.Constructor.constructNative(Native Method)
09-24 23:36:05.506 9460-9460/com.example.myapplication I/dalvikvm﹕ at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.view.LayoutInflater.createView(LayoutInflater.java:587)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.view.LayoutInflater.onCreateView(LayoutInflater.java:660)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
09-24 23:36:05.511 9460-9460/com.example.myapplication I/dalvikvm﹕ at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:365)
09-24 23:36:05.516 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.Activity.setContentView(Activity.java:1912)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at com.example.myapplication.bathactivity.onCreate(bathactivity.java:14)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.Activity.performCreate(Activity.java:5066)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1101)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.ActivityThread.access$600(ActivityThread.java:151)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1331)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.os.Handler.dispatchMessage(Handler.java:99)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.os.Looper.loop(Looper.java:155)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at android.app.ActivityThread.main(ActivityThread.java:5485)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at java.lang.reflect.Method.invokeNative(Native Method)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at java.lang.reflect.Method.invoke(Method.java:511)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1028)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:795)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ at dalvik.system.NativeStart.main(Native Method)
09-24 23:36:05.521 9460-9460/com.example.myapplication I/dalvikvm﹕ [ 09-24 23:36:05.521 9460: 9460 E/dalvikvm ]
Out of memory: Heap Size=47011KB, Allocated=38523KB, Limit=65536KB
09-24 23:36:05.521 9460-9460/com.example.myapplication E/dalvikvm﹕ Extra info: Footprint=46947KB, Allowed Footprint=47011KB, Trimmed=1472KB
09-24 23:36:05.521 9460-9460/com.example.myapplication D/skia﹕ --- Unable to allocate space, reportSizeToVM = true
09-24 23:36:05.526 9460-9460/com.example.myapplication W/dalvikvm﹕ threadid=1: thread exiting with uncaught exception (group=0x41bf42d0)
09-24 23:36:05.531 9460-9460/com.example.myapplication E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.myapplication/com.example.myapplication.bathactivity}: android.view.InflateException: Binary XML file line #16: Error inflating class <unknown>
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2351)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)
at android.app.ActivityThread.access$600(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1331)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:155)
at android.app.ActivityThread.main(ActivityThread.java:5485)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1028)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:795)
at dalvik.system.NativeStart.main(Native Method)
Caused by: android.view.InflateException: Binary XML file line #16: Error inflating class <unknown>
at android.view.LayoutInflater.createView(LayoutInflater.java:613)
at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
at android.view.LayoutInflater.onCreateView(LayoutInflater.java:660)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:365)
at android.app.Activity.setContentView(Activity.java:1912)
at com.example.myapplication.bathactivity.onCreate(bathactivity.java:14)
at android.app.Activity.performCreate(Activity.java:5066)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1101)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307)
... 11 more
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.constructNative(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
at android.view.LayoutInflater.createView(LayoutInflater.java:587)
... 24 more
Caused by: java.lang.OutOfMemoryError: (Heap Size=47011KB, Allocated=38523KB)
at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:626)
at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:473)
at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:781)
at android.content.res.Resources.loadDrawable(Resources.java:1959)
at android.content.res.TypedArray.getDrawable(TypedArray.java:601)
at android.widget.ImageView.<init>(ImageView.java:120)
at android.widget.ImageView.<init>(ImageView.java:110)
... 27 more
这是我的错误吗?;
D/skia﹕ --- Unable to allocate space, reportSizeToVM = true 09-24 23:36:05.526
9460-9460/com.example.myapplication W/dalvikvm﹕ threadid=1: thread exiting with uncaught exception (group=0x41bf42d0) 09-24 23:36:05.531
9460-9460/com.example.myapplication E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start activity
ComponentInfo{com.example.myapplication/com.example.myapplication.bathactivity}:
答案 0 :(得分:4)
Out of memory on a 42701840-byte allocation.
当您尝试为imageview加载android:src="@drawable/getdressedimg"
时,这看起来像内存不足问题。图像有多大?如果它太大,则需要缩小以匹配ImageView的高度和宽度。检查this page如何执行此操作。
答案 1 :(得分:0)
你没有提到默认的诅咒。像这样:
<activity
android:name=".Bathactivity"
android:label="@string/app_name"
android:screenOrientation="portrait" >
<intent-filter>
<action android:name="com.example.myapplication.BATHACTIVITY" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
只需将上述代码复制并粘贴到manifest .xml中,而不是
<activity
android:name="com.example.myapplication.secondactivity"
android:label="@string/title_activity_second" >
</activity>
<activity
android:name="com.example.myapplication.bathactivity"
android:label="@string/title_activity_bath" >
</activity>