我有一些使用新Palette
课程的代码,而且我在Crashlytics上收到了width and height must be > 0
这些崩溃报告。奇怪的是,这就是我调用调色板代码的方式:
if( bitmap == null || bitmap.getHeight() <= 0 || bitmap.getWidth() <= 0){
//do something
}else{
Palette.Builder(bitmap).generate(new Palette.PaletteAsyncListener() {
.....
}
所以我只是不确定突然的位图是否有可能没有正确的高度或宽度。我不知道异常来自哪部分代码,因为报告只包含调色板类中的内容。
以下是例外:
java.lang.RuntimeException: An error occured while executing doInBackground()
at android.os.AsyncTask$3.done(AsyncTask.java:300)
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
at java.util.concurrent.FutureTask.run(FutureTask.java:242)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)
Caused by: java.lang.IllegalArgumentException: width and height must be > 0
at android.graphics.Bitmap.createBitmap(Bitmap.java:815)
at android.graphics.Bitmap.createBitmap(Bitmap.java:794)
at android.graphics.Bitmap.createBitmap(Bitmap.java:725)
at android.graphics.Bitmap.createScaledBitmap(Bitmap.java:601)
at android.support.v7.graphics.Palette.scaleBitmapDown(Palette.java:282)
at android.support.v7.graphics.Palette.access$100(Palette.java:67)
at android.support.v7.graphics.Palette$Builder.generate(Palette.java:557)
at android.support.v7.graphics.Palette$Builder$1.doInBackground(Palette.java:623)
at android.support.v7.graphics.Palette$Builder$1.doInBackground(Palette.java:620)
at android.os.AsyncTask$2.call(AsyncTask.java:288)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)
我正在使用com.android.support:palette-v7:23+
任何可能出错的想法?
答案 0 :(得分:0)
在将UI元素实际添加到布局之前,您可能正在尝试访问UI元素的宽度和高度。
这就是为什么你的宽度和高度等于0,因为元素实际上并不存在。
使用ViewTreeObserver
http://developer.android.com/reference/android/view/ViewTreeObserver.html
myView.getViewTreeObserver().addOnPreDrawListener(
new ViewTreeObserver.OnPreDrawListener() {
public boolean onPreDraw() {
int finalHeight = myView.getMeasuredHeight();
int finalWidth = myView.getMeasuredWidth();
// Do your work here
return true;
}
});
myView
将是您的位图
答案 1 :(得分:0)
我认为您的代码没有任何问题。我在看你发布的StackTrace。
at android.graphics.Bitmap.createScaledBitmap(Bitmap.java:601)
at android.support.v7.graphics.Palette.scaleBitmapDown(Palette.java:282)
如果查看Palette.java的源代码,您会发现用方法scaleBitmapDown(Bitmap bitmap)
编写的缩放逻辑。如果你的位图&#39;小于100px,则不进行缩放。但是,如果你的位图&#39;大于100px,然后调用Bitmap.createScaledBitmap()
。现在,如果宽度或高度<1,则此方法抛出IllegalArgumentException
。 0;
因此,您传递的位图的宽度不为零,因为如果是这种情况,您根本就不会达到Bitmap.createScaledBitmap()
方法。话虽如此,我不确定真正的原因是什么。尝试浏览您正在使用的确切Palette.java
的源代码。
答案 2 :(得分:0)
问题与并发问题有关:因为您在&#39; 异步&#39;中使用了Palette
。方式,当你调用
Palette.Builder(bitmap).generate(new Palette.PaletteAsyncListener()
您的位图有效,但当Palette
在其自己的异步逻辑中使用位图时,位图可能为空或不再有效(由于并发操作)。
可以轻松解决此问题:由于您不需要高分辨率图像来提取关键颜色,因此只需提供从原始图像创建的低分辨率位图:
if( bitmap == null || bitmap.getHeight() <= 0 || bitmap.getWidth() <= 0){
//do something
}else{
//This resized bitmap is just an example: you should keep your bitmap
//aspect ratio, and keep width and height < 100
Bitmap resizedBitmap = Bitmap.createScaledBitmap(myBitmap, 100, 100, false);
Palette.Builder(resizedBitmap).generate(new Palette.PaletteAsyncListener() {
.....
}