我正在尝试创建一个包含大量高分辨率图像的应用程序,以便它们也可以在高端设备和低端设备上运行。因为现在有一些设备是现在提供 1080p 分辨率的手机。
我正在使用具有 756MB RAM、720p 屏幕和我的 VM 堆大小为 64MB 的 AVD。我的操作系统是 Windows 8。
这是我的活动文件。我暂时还没有添加任何东西
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
这是xml文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bg"
tools:context=".MainActivity" >
<ImageView
android:id="@+id/head"
android:layout_width="match_parent"
android:layout_height="100dp"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:scaleType="fitXY"
android:src="@drawable/head1" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="100dp"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:weightSum="6" >
<ImageView
android:id="@+id/logo"
android:layout_width="0dp"
android:layout_height="100dp"
android:src="@drawable/logo21"
android:layout_weight="3" />
<ImageView
android:id="@+id/knob1"
android:layout_width="0dp"
android:layout_height="100dp"
android:src="@drawable/knob1"
android:layout_weight="1" />
<ImageView
android:id="@+id/knob2"
android:layout_width="0dp"
android:layout_height="100dp"
android:src="@drawable/knob2"
android:layout_weight="1" />
<ImageView
android:id="@+id/knob3"
android:layout_width="0dp"
android:layout_height="100dp"
android:src="@drawable/knob3"
android:layout_weight="1" />
</LinearLayout>
<ImageView
android:id="@+id/bottom"
android:layout_width="match_parent"
android:layout_height="100dp"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:paddingTop="10dp"
android:src="@drawable/button" />
在运行应用程序时,我收到此消息:
“不幸的是,德国洗衣店已经停止了”
请帮我 !!
**按要求更新 我的logcat **
06-30 10:49:42.524: E/Trace(830): 打开跟踪文件时出错: 没有这样的文件或目录 (2) 06-30 10:49:43.063: D/dalvikvm(830): GC_FOR_ALLOC 释放 41K,7% 释放 2498K/2660K,暂停 88ms,总共 102ms 06-30 10:49:43.163: I/dalvikvm-heap(830): 将堆(碎片情况)增加到 7.018MB,分配 4680016 字节 06-30 10:49:43.264: D/dalvikvm(830): GC_FOR_ALLOC 释放 2K,3% 释放 7066K/7232K,暂停 98ms,总共 98ms 06-30 10:49:43.393: D/dalvikvm(830): GC_CONCURRENT 已释放 (ImageView.java:120) 06-30 10:49:45.953: I/dalvikvm(830): 在 android.widget.ImageView.(ImageView.java:110) 06-30 10:49:45.953: I/dalvikvm(830): at java.lang.reflect.Constructor.constructNative(Native Method) 06-30 10:49:45.953: I/dalvikvm(830): 在 java.lang.reflect.Constructor.newInstance(Constructor.java:417) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.createView(LayoutInflater.java:587) 06-30 10:49:45.963: I/dalvikvm(830): at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.onCreateView(LayoutInflater.java:660) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:746) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:749) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.inflate(LayoutInflater.java:489) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.inflate(LayoutInflater.java:396) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.view.LayoutInflater.inflate(LayoutInflater.java:352) 06-30 10:49:45.963: I/dalvikvm(830): at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:270) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.app.Activity.setContentView(Activity.java:1881) 06-30 10:49:45.963: I/dalvikvm(830): at com.example.germanlaundryfinal.MainActivity.onCreate(MainActivity.java:12) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.app.Activity.performCreate(Activity.java:5104) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.app.ActivityThread.access$600(ActivityThread.java:141) 06-30 10:49:45.963: I/dalvikvm(830): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 06-30 10:49:45.973: I/dalvikvm(830): 在 android.os.Handler.dispatchMessage(Handler.java:99) 06-30 10:49:45.973: I/dalvikvm(830): 在 android.os.Looper.loop(Looper.java:137) 06-30 10:49:45.973: I/dalvikvm(830): 在 android.app.ActivityThread.main(ActivityThread.java:5041) 06-30 10:49:45.973: I/dalvikvm(830): 在 java.lang.reflect.Method.invokeNative(Native Method) 06-30 10:49:45.973: I/dalvikvm(830): 在 java.lang.reflect.Method.invoke(Method.java:511) 06-30 10:49:45.973: I/dalvikvm(830): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 06-30 10:49:45.973: I/dalvikvm(830): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 06-30 10:49:45.973: I/dalvikvm(830): at dalvik.system.NativeStart.main(Native Method) 06-30 10:49:45.973: D/skia(830): --- 缩放位图分配失败 06-30 10:49:45.983: D/AndroidRuntime(830): 关闭虚拟机 06-30 10:49:45.983: W/dalvikvm(830): threadid=1: 线程以未捕获的异常退出 (group=0x40a71930) 06-30 10:49:46.043: E/AndroidRuntime(830): 致命异常: main 06-30 10:49:46.043:E/AndroidRuntime(830):java.lang.RuntimeException:无法启动活动 ComponentInfo{com.example.germanlaundryfinal/com.example.germanlaundryfinal.MainActivity}:android.view.InflateException:二进制XML 文件第 24 行:膨胀类时出错 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.ActivityThread.access$600(ActivityThread.java:141) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.os.Handler.dispatchMessage(Handler.java:99) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.os.Looper.loop(Looper.java:137) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.ActivityThread.main(ActivityThread.java:5041) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 java.lang.reflect.Method.invokeNative(Native Method) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 java.lang.reflect.Method.invoke(Method.java:511) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 06-30 10:49:46.043: E/AndroidRuntime(830): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 06-30 10:49:46.043: E/AndroidRuntime(830): at dalvik.system.NativeStart.main(Native Method) 06-30 10:49:46.043: E/AndroidRuntime(830): 由: android.view.InflateException: 二进制 XML 文件行 #24: 膨胀类错误 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.createView(LayoutInflater.java:613) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.onCreateView(LayoutInflater.java:660) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:746) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:749) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.inflate(LayoutInflater.java:489) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.inflate(LayoutInflater.java:396) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.inflate(LayoutInflater.java:352) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:270) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.Activity.setContentView(Activity.java:1881) 06-30 10:49:46.043: E/AndroidRuntime(830): at com.example.germanlaundryfinal.MainActivity.onCreate(MainActivity.java:12) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.Activity.performCreate(Activity.java:5104) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144) 06-30 10:49:46.043: E/AndroidRuntime(830): ... 11 更多 06-30 10:49:46.043:E/AndroidRuntime(830):由:java.lang.reflect.InvocationTargetException 引起 06-30 10:49:46.043: E/AndroidRuntime(830): at java.lang.reflect.Constructor.constructNative(Native Method) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 java.lang.reflect.Constructor.newInstance(Constructor.java:417) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.view.LayoutInflater.createView(LayoutInflater.java:587) 06-30 10:49:46.043: E/AndroidRuntime(830): ... 25 更多 06-30 10:49:46.043: E/AndroidRuntime(830): 引起: java.lang.OutOfMemoryError 06-30 10:49:46.043: E/AndroidRuntime(830): at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:502) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:355) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:785) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.content.res.Resources.loadDrawable(Resources.java:1965) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.content.res.TypedArray.getDrawable(TypedArray.java:601) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.widget.ImageView.(ImageView.java:120) 06-30 10:49:46.043: E/AndroidRuntime(830): 在 android.widget.ImageView.(ImageView.java:110) 06-30 10:49:46.043: E/AndroidRuntime(830): ... 还有 28 个