Mar*_*rio 5 java debugging android android-studio
几周前我开始使用 Android Studio。我开发了一个具有正常登录屏幕的应用程序,并且在模拟器上一切正常。但如果我尝试在 Samsung Galaxy S7 Edge (Android 7.0) 上运行该应用程序,该应用程序会立即崩溃。
我已经模拟了具有 API 23 的 Nexus 5,当我尝试使用具有 API 24 的模拟 Pixel 时,模拟器也会崩溃。所以我猜这个问题取决于Android版本?
Logcat(我优化了我正在使用的所有图像,现在这是我的新 Logcat):
03-30 15:53:13.841 31645-31645/de.mm.uchron E/AndroidRuntime: FATAL EXCEPTION: main
Process: de.mm.uchron, PID: 31645
java.lang.OutOfMemoryError: Failed to allocate a 3686412 byte allocation with 2474312 free bytes and 2MB until OOM
at dalvik.system.VMRuntime.newNonMovableArray(Native Method)
at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:700)
at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:535)
at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:1179)
at android.content.res.ResourcesImpl.loadDrawableForCookie(ResourcesImpl.java:770)
at android.content.res.ResourcesImpl.loadDrawable(ResourcesImpl.java:621)
at android.content.res.Resources.loadDrawable(Resources.java:1727)
at android.content.res.TypedArray.getDrawable(TypedArray.java:945)
at android.widget.ImageView.<init>(ImageView.java:157)
at android.widget.ImageButton.<init>(ImageButton.java:85)
at android.widget.ImageButton.<init>(ImageButton.java:81)
at android.support.v7.widget.AppCompatImageButton.<init>(AppCompatImageButton.java:60)
at android.support.v7.widget.AppCompatImageButton.<init>(AppCompatImageButton.java:56)
at android.support.v7.app.AppCompatViewInflater.createView(AppCompatViewInflater.java:118)
at android.support.v7.app.AppCompatDelegateImplV9.createView(AppCompatDelegateImplV9.java:1029)
at android.support.v7.app.AppCompatDelegateImplV9.onCreateView(AppCompatDelegateImplV9.java:1087)
at android.support.v4.view.LayoutInflaterCompatHC$FactoryWrapperHC.onCreateView(LayoutInflaterCompatHC.java:47)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:776)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:734)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:865)
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:828)
at android.view.LayoutInflater.inflate(LayoutInflater.java:525)
at android.view.LayoutInflater.inflate(LayoutInflater.java:427)
at android.view.LayoutInflater.inflate(LayoutInflater.java:378)
at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:292)
at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140)
at de.mm.uchron.LoginActivity.onCreate(LoginActivity.java:32)
at android.app.Activity.performCreate(Activity.java:6912)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1126)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2900)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3008)
at android.app.ActivityThread.-wrap14(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1650)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6688)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358)
03-30 15:53:20.016 31645-31656/de.mm.uchron I/art: Clamp target GC heap from 261MB to 256MB
Run Code Online (Sandbox Code Playgroud)
我还用我的另一台真实设备(带有 Android 5.1.1、API 22 的三星 GT-I9300)进行了尝试。MainActivity 加载,但没有背景图像,如果我尝试登录,应用程序就会崩溃。
我的SDK工具都是最新版本
Android Emulator: 26.0.0
Android SDK Platform-Tools: 25.0.4
Android SDK Tools: 26.0.0
Google Play services, rev 39: 39.0.0
Google USB Driver, rev 11: 11.0.0
Google Web driver: 2
Intel x86 Emulator Accelerator (HAXM installer): 6.0.5
Run Code Online (Sandbox Code Playgroud)
MainActivity (LoginActivity) 的 xml 文件:
<?xml version="1.0" encoding="utf-8"?>
<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:padding="16dp"
android:background="@drawable/loginbg">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:id="@+id/rect"
android:layout_alignParentTop="true"
android:layout_alignParentStart="true">
</LinearLayout>
<android.support.design.widget.TextInputLayout
android:id="@+id/signup_input_layout_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="300dp"
android:layout_marginLeft="30dp">
<EditText
android:id="@+id/etUsername"
android:layout_width="222dp"
android:layout_height="wrap_content"
android:ems="10"
android:textColor="#000"
android:fontFamily="Montserrat"
android:textSize="16dp"
android:hint="BENUTZERNAME" />
</android.support.design.widget.TextInputLayout>
<android.support.design.widget.TextInputLayout
android:id="@+id/signup_input_layout_pass"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="30dp"
android:layout_below="@id/signup_input_layout_name">
<EditText
android:id="@+id/etPassword"
android:layout_width="223dp"
android:layout_height="wrap_content"
android:ems="10"
android:fontFamily="Montserrat"
android:hint="PASSWORT"
android:inputType="textPassword"
android:textColor="#000"
android:textSize="16dp" />
</android.support.design.widget.TextInputLayout>
<ImageButton
android:id="@+id/bSignIn"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_alignParentBottom="true"
android:background="@null"
android:layout_marginBottom="60dp"
android:layout_marginLeft="260dp"
android:fontFamily="Montserrat"
android:scaleType="fitXY"
android:src="@drawable/loginbutton"
android:text="Login" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceLarge"
android:text="NEUER ACCOUNT"
android:id="@+id/tvRegisterLink"
android:textSize="12sp"
android:textColor="#B2B2B2"
android:fontFamily="Montserrat"
android:layout_alignParentBottom="true"
android:layout_marginBottom="20dp"
android:layout_alignStart="@+id/signup_input_layout_pass" />
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
就像我说的,我是 Android Studio 的新手,我对这个问题感到恼火。
提前致谢!
已解决:调整图像大小解决了问题。我使用此链接中的建议来降低背景文件的分辨率。现在一切都像魅力一样!
您在此评论中提到您正在使用尺寸为 1500 x 2668 的图像。如 logcat 中所示,Android 使用BitmapFactory该图像来膨胀,并且位图根据图像尺寸占用内存。在您的情况下,这是大量内存,超过了设备可用于您的应用程序的内存,因此OutOfMemoryException.
@drawable/loginbg在不影响质量的情况下,尽可能缩小尺寸。我建议阅读有关如何使用不同尺寸的图像支持多种屏幕尺寸的信息:https://developer.android.com/guide/practices/screens_support.html
| 归档时间: |
|
| 查看次数: |
15696 次 |
| 最近记录: |