【发布时间】:2025-12-18 17:45:02
【问题描述】:
您好,我的教授无法解决这个问题,所以我想我会在这里发帖。我正在尝试制作一个显示温度的应用程序,当搜索栏达到某个温度时,我希望在 imageView 中显示不同的图像。当我测试应用程序并且搜索栏超过 40 时,应用程序取消抵押品赎回权。谁能告诉我这是为什么?
SeekBar seekBar;
TextView f, c;
ImageView i;
int progress_value;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_tempature);
seekBar = (SeekBar)findViewById(R.id.seekBar);
seekBar.setMax(200);
f = (TextView)findViewById(R.id.f);
c = (TextView)findViewById(R.id.c);
i = (ImageView)findViewById(R.id.imageView);
seekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {
@Override
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
progress_value = progress;
f.setText(" " + progress_value);
c.setText(" " + .55 * (progress_value - 32));
if (progress_value <= 40){
i.setImageResource(R.drawable.cold);
}
else if (progress_value > 40 && progress_value < 90){
i.setImageResource(R.drawable.justright);
}
else{
i.setImageResource(R.drawable.hot);
}
}
@Override
public void onStartTrackingTouch(SeekBar seekBar) {
}
@Override
public void onStopTrackingTouch(SeekBar seekBar) {
}
});
}
}
09/26 23:21:56:启动应用程序 $ adb push C:\Users\aniel\AndroidStudioProjects\HomeWork#2\app\build\outputs\apk\app-debug.apk /data/local/tmp/com.example.aniel.homework2 $ adb shell pm install -r "/data/local/tmp/com.example.aniel.homework2" 成功
$ adb shell am start -n "com.example.aniel.homework2/com.example.aniel.homework2.Tempature" -a android.intent.action.MAIN -c android.intent.category.LAUNCHER 客户尚未准备好..等待进程上线 等待进程上线 等待进程上线 等待进程上线 等待进程上线 连接到设备 emulator-5554 上的进程 2373 W/gralloc_ranchu: Gralloc 管道失败
[ 09-26 23:22:05.204 2373: 2373 D/ ]
HostConnection::get() New Host Connection established 0x982851c0, tid 2373
I/OpenGLRenderer:初始化的 EGL,版本 1.4 D/OpenGLRenderer:交换行为 1 D/AndroidRuntime: 关闭虚拟机
--------- beginning of crash
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.aniel.homework2, PID: 2373
java.lang.RuntimeException: Canvas: trying to draw too large(241864000bytes) bitmap.
at android.view.DisplayListCanvas.throwIfCannotDraw(DisplayListCanvas.java:260)
at android.graphics.Canvas.drawBitmap(Canvas.java:1415)
at android.graphics.drawable.BitmapDrawable.draw(BitmapDrawable.java:545)
at android.widget.ImageView.onDraw(ImageView.java:1286)
at android.view.View.draw(View.java:17068)
at android.view.View.updateDisplayListIfDirty(View.java:16050)
at android.view.View.draw(View.java:16834)
at android.view.ViewGroup.drawChild(ViewGroup.java:3764)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3550)
at android.view.View.updateDisplayListIfDirty(View.java:16045)
at android.view.View.draw(View.java:16834)
at android.view.ViewGroup.drawChild(ViewGroup.java:3764)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3550)
at android.view.View.updateDisplayListIfDirty(View.java:16045)
at android.view.View.draw(View.java:16834)
at android.view.ViewGroup.drawChild(ViewGroup.java:3764)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3550)
at android.view.View.updateDisplayListIfDirty(View.java:16045)
at android.view.View.draw(View.java:16834)
at android.view.ViewGroup.drawChild(ViewGroup.java:3764)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3550)
at android.view.View.updateDisplayListIfDirty(View.java:16045)
at android.view.View.draw(View.java:16834)
at android.view.ViewGroup.drawChild(ViewGroup.java:3764)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3550)
at android.view.View.updateDisplayListIfDirty(View.java:16045)
at android.view.View.draw(View.java:16834)
at android.view.ViewGroup.drawChild(ViewGroup.java:3764)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3550)
at android.view.View.draw(View.java:17071)
at com.android.internal.policy.DecorView.draw(DecorView.java:751)
at android.view.View.updateDisplayListIfDirty(View.java:16050)
at android.view.ThreadedRenderer.updateViewTreeDisplayList(ThreadedRenderer.java:656)
at android.view.ThreadedRenderer.updateRootDisplayList(ThreadedRenderer.java:662)
at android.view.ThreadedRenderer.draw(ThreadedRenderer.java:770)
at android.view.ViewRootImpl.draw(ViewRootImpl.java:2796)
at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2604)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2211)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1246)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6301)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:871)
at android.view.Choreographer.doCallbacks(Choreographer.java:683)
at android.view.Choreographer.doFrame(Choreographer.java:619)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:857)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
Application terminated.
【问题讨论】:
-
你能分享你的日志信息吗?你得到的例外是什么?
-
可以分享一下日志吗?
-
请粘贴异常还是您的应用程序进入后台很长时间?
-
对不起,我是新手,如何在 * 中分享我的日志?
-
发布的 logcat 的第一行中明确提到了该问题。所以请阅读它们。