2016-01-10 4 views
0

Это мой код для создания приложения, которое отображает следующее изображение при нажатии. У меня возникли проблемы с созданием динамического дисплея, он падает при нажатии на изображение.Использование отображения динамического изображения onclicklistener

<ImageView 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:id="@+id/imageView" 
    android:layout_alignParentBottom="true" 
    android:layout_alignParentLeft="true" 
    android:layout_alignParentStart="true" 
    /> 

Java файл:

public class MainActivity extends AppCompatActivity { 

private ImageView im1; 


@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    im1 = (ImageView) findViewById(R.id.imageView); 
    im1.setImageResource(R.drawable.l); 
    im1.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      im1.setImageResource(R.drawable.m); 
     } 
    }); 
} 

} 

PS: изначально в моем файле XML я использую android:background="@drawable/l" установить мое изображение при запуске

log: 01-10 19:07:09.912 5465-5465/experiment.com.example.anurag.imageswap2 E/AndroidRuntime: FATAL EXCEPTION: main Process: experiment.com.example.anurag.imageswap2, PID: 5465 java.lang.OutOfMemoryError: Failed to allocate a 74649612 byte allocation with 4194304 free bytes and 28MB until OOM at dalvik.system.VMRuntime.newNonMovableArray(Native Method) at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method) at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:609) at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:444) at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:1080) at android.content.res.Resources.loadDrawableForCookie(Resources.java:2635) at android.content.res.Resources.loadDrawable(Resources.java:2540) at android.content.res.Resources.getDrawable(Resources.java:806) at android.content.Context.getDrawable(Context.java:458) at android.support.v4.content.ContextCompatApi21.getDrawable(ContextCompatApi21.java:26) at android.support.v4.content.ContextCompat.getDrawable(ContextCompat.java:321) at android.support.v7.widget.TintManager.getDrawable(TintManager.java:175) at android.support.v7.widget.TintManager.getDrawable(TintManager.java:168) at android.support.v7.widget.AppCompatImageHelper.setImageResource(AppCompatImageHelper.java:51) at android.support.v7.widget.AppCompatImageView.setImageResource(AppCompatImageView.java:72) at experiment.com.example.anurag.imageswap2.MainActivity$1.onClick(MainActivity.java:24) at android.view.View.performClick(View.java:5198) at android.view.View$PerformClick.run(View.java:21147) at android.os.Handler.handleCallback(Handler.java:739) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:148) at android.app.ActivityThread.main(ActivityThread.java:5417) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

+0

угождать бы обеспечить LogCat? –

+0

Проблема не в памяти, похоже, что ваше изображение было 74 мегабайта, почему бы вам не изменить размер изображения, а затем повторить попытку? –

ответ

1

Попробуйте переместить ваш вводимый коэффициент от более низкого MPI до HDPI или до еще более крупных папок, таких как XHDPI d придумывая ваше решение.

+0

спасибо mate, точно не знал, что размер, разрешенный, будет держать это в голове – anurag145

+0

Попытайтесь узнать больше об исключении OutOfMemory, и я уверен, что вы найдете свой выход. Добро пожаловать. – Kristo

0

Это позволит повысить производительность и избежать из памяти

<application  
android:hardwareAccelerated="false" 
android:largeHeap="true"> 

Добавить эти строки в манифесте

Смежные вопросы