- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是这个网站的新手,我来这里是因为我在其他任何地方都找不到这个答案,所以我想看看我是否能得到一些帮助!
我的项目中有一个 GridView 以及一个图像适配器。我需要以下代码的帮助:
package com.humanoid.sigma;
import android.app.Activity;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public Integer[] Tattoos = {
R.drawable.tattoo1, R.drawable.tattoo2,
R.drawable.tattoo3, R.drawable.tattoo4,
R.drawable.tattoo5, /*R.drawable.tattoo6,
R.drawable.tattoo7, R.drawable.tattoo8,
R.drawable.tattoo9, R.drawable.tattoo10,
R.drawable.tattoo11, R.drawable.tattoo12,
R.drawable.tattoo13, R.drawable.tattoo14,
R.drawable.tattoo15, R.drawable.tattoo16,
R.drawable.tattoo17, R.drawable.tattoo18,
R.drawable.tattoo19, R.drawable.tattoo20,
R.drawable.tattoo21, R.drawable.tattoo22,
R.drawable.tattoo23, R.drawable.tattoo24,
R.drawable.tattoo25, R.drawable.tattoo26,
R.drawable.tattoo27, R.drawable.tattoo28,
R.drawable.tattoo29, R.drawable.tattoo30,
R.drawable.tattoo31, R.drawable.tattoo32,
R.drawable.tattoo33, R.drawable.tattoo34,
R.drawable.tattoo35, R.drawable.tattoo36,
R.drawable.tattoo37, R.drawable.tattoo38,
R.drawable.tattoo39, R.drawable.tattoo40,
R.drawable.tattoo41, R.drawable.tattoo42,
R.drawable.tattoo43, R.drawable.tattoo44,
R.drawable.tattoo45, R.drawable.tattoo46,
R.drawable.tattoo47, R.drawable.tattoo48,
R.drawable.tattoo49, R.drawable.tattoo50,
R.drawable.tattoo51, R.drawable.tattoo52,
R.drawable.tattoo53, R.drawable.tattoo54,
R.drawable.tattoo55, R.drawable.tattoo56,
R.drawable.tattoo57, R.drawable.tattoo58,
R.drawable.tattoo59, R.drawable.tattoo60,
R.drawable.tattoo61, R.drawable.tattoo62,
R.drawable.tattoo63, R.drawable.tattoo64,
R.drawable.tattoo65, R.drawable.tattoo66,
R.drawable.tattoo67, R.drawable.tattoo68,
R.drawable.tattoo69, R.drawable.tattoo70,
R.drawable.tattoo71, R.drawable.tattoo72,
R.drawable.tattoo73, R.drawable.tattoo74,
R.drawable.tattoo75, R.drawable.tattoo76,
R.drawable.tattoo77, R.drawable.tattoo78,
R.drawable.tattoo79, R.drawable.tattoo80,
R.drawable.tattoo81, R.drawable.tattoo82,*/
};
// Constructor
public ImageAdapter(Context c){
mContext = c;
}
public int getCount() {
return Tattoos.length;
}
public Object getItem(int position) {
return Tattoos[position];
}
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ImageView imageView = new ImageView(mContext);
imageView.setImageResource(Tattoos[position]);
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
imageView.setLayoutParams(new GridView.LayoutParams(100, 70));
return imageView;
}
}
Logcat 堆栈跟踪:
06-28 17:51:14.104: E/AndroidRuntime(818): FATAL EXCEPTION: main 06-28 17:51:14.104: E/AndroidRuntime(818):
java.lang.OutOfMemoryError 06-28 17:51:14.104: E/AndroidRuntime(818): at
android.graphics.BitmapFactory.nativeDecodeAsset(Native Method) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:502) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:355) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:785) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.content.res.Resources.loadDrawable(Resources.java:1965) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.content.res.Resources.getDrawable(Resources.java:660) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.ImageView.resolveUri(ImageView.java:616) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.ImageView.setImageResource(ImageView.java:349) 06-28 17:51:14.104: E/AndroidRuntime(818): at com.humanoid.sigma.ImageAdapter.getView(ImageAdapter.java:80) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.AbsListView.obtainView(AbsListView.java:2143) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.GridView.makeAndAddView(GridView.java:1341) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.GridView.makeRow(GridView.java:341) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.GridView.fillDown(GridView.java:283) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.GridView.fillFromTop(GridView.java:417) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.GridView.layoutChildren(GridView.java:1229) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.AbsListView.onLayout(AbsListView.java:1994) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.View.layout(View.java:14003) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewGroup.layout(ViewGroup.java:4375) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.RelativeLayout.onLayout(RelativeLayout.java:985) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.View.layout(View.java:14003) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewGroup.layout(ViewGroup.java:4375) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.FrameLayout.onLayout(FrameLayout.java:448) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.View.layout(View.java:14003) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewGroup.layout(ViewGroup.java:4375) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1663) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1521) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.LinearLayout.onLayout(LinearLayout.java:1434) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.View.layout(View.java:14003) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewGroup.layout(ViewGroup.java:4375) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.widget.FrameLayout.onLayout(FrameLayout.java:448) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.View.layout(View.java:14003) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewGroup.layout(ViewGroup.java:4375) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1892) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1711) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:989) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4351) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.Choreographer.doCallbacks(Choreographer.java:562) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.Choreographer.doFrame(Choreographer.java:532) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.os.Handler.handleCallback(Handler.java:725) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.os.Handler.dispatchMessage(Handler.java:92) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.os.Looper.loop(Looper.java:137) 06-28 17:51:14.104: E/AndroidRuntime(818): at android.app.ActivityThread.main(ActivityThread.java:5039) 06-28 17:51:14.104: E/AndroidRuntime(818): at java.lang.reflect.Method.invokeNative(Native Method) 06-28 17:51:14.104: E/AndroidRuntime(818): at java.lang.reflect.Method.invoke(Method.java:511) 06-28 17:51:14.104: E/AndroidRuntime(818): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 06-28 17:51:14.104: E/AndroidRuntime(818): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 06-28 17:51:14.104: E/AndroidRuntime(818): at dalvik.system.NativeStart.main(Native Method)
Gallery.Java代码:
package com.humanoid.sigma;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
public class Gallery extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.gallery);
GridView gridView = (GridView) findViewById(R.id.photos);
// Instance of ImageAdapter Class
gridView.setAdapter(new ImageAdapter(this));
gridView.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View v,
int position, long id) {
// Sending image id to FullScreenActivity
Intent i = new Intent(getApplicationContext(), FullScreen.class);
// passing array index
i.putExtra("id", position);
startActivity(i);
}
});
}
}
正如您从上面看到的,我已经注释掉了对我不起作用的部分。不知道是不是因为这个 GridView 的图片太多了,但是挺烦人的。一旦我将这些图像注释掉,程序运行正常,但如果我删除/* 并运行程序并选择图库,它只会显示黑屏。不久之后它就会崩溃。
请帮我解决我一直在搜索但找不到任何帮助的代码。
最佳答案
您的问题是由于分配可绘制资源时堆大小耗尽而引起的(这是一个常见问题,因为这种操作需要大量内存)。
当我尝试你的代码时,我得到了 java.lang.OutOfMemoryError: bitmap size exceeds VM budget
。这是一个简单明了的错误消息。
然后我进行了一些研究,并在官方 Android 开发网站上发现了一个“本地”线程:http://developer.android.com/training/displaying-bitmaps/index.html关于如何在应用程序中进行高效资源分配的位图和示例。
所以我尝试了它并结合了您的代码,这就是我得到的:
ImageAdapter.java :
package com.humanoid.sigma;
import android.app.Activity;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public Integer[] Tattoos = {
R.drawable.tattoo1, R.drawable.tattoo2,
R.drawable.tattoo3, R.drawable.tattoo4,
R.drawable.tattoo5, R.drawable.tattoo6,
R.drawable.tattoo7, R.drawable.tattoo8,
R.drawable.tattoo9, R.drawable.tattoo10,
R.drawable.tattoo11, R.drawable.tattoo12,
R.drawable.tattoo13, R.drawable.tattoo14,
R.drawable.tattoo15, R.drawable.tattoo16,
R.drawable.tattoo17, R.drawable.tattoo18,
R.drawable.tattoo19, R.drawable.tattoo20,
R.drawable.tattoo21, R.drawable.tattoo22,
R.drawable.tattoo23, R.drawable.tattoo24,
R.drawable.tattoo25, R.drawable.tattoo26,
R.drawable.tattoo27, R.drawable.tattoo28,
R.drawable.tattoo29, R.drawable.tattoo30,
R.drawable.tattoo31, R.drawable.tattoo32,
R.drawable.tattoo33, R.drawable.tattoo34,
R.drawable.tattoo35, R.drawable.tattoo36,
R.drawable.tattoo37, R.drawable.tattoo38,
R.drawable.tattoo39, R.drawable.tattoo40,
R.drawable.tattoo41, R.drawable.tattoo42,
R.drawable.tattoo43, R.drawable.tattoo44,
R.drawable.tattoo45, R.drawable.tattoo46,
R.drawable.tattoo47, R.drawable.tattoo48,
R.drawable.tattoo49, R.drawable.tattoo50,
R.drawable.tattoo51, R.drawable.tattoo52,
R.drawable.tattoo53, R.drawable.tattoo54,
R.drawable.tattoo55, R.drawable.tattoo56,
R.drawable.tattoo57, R.drawable.tattoo58,
R.drawable.tattoo59, R.drawable.tattoo60,
R.drawable.tattoo61, R.drawable.tattoo62,
R.drawable.tattoo63, R.drawable.tattoo64,
R.drawable.tattoo65, R.drawable.tattoo66,
R.drawable.tattoo67, R.drawable.tattoo68,
R.drawable.tattoo69, R.drawable.tattoo70,
R.drawable.tattoo71, R.drawable.tattoo72,
R.drawable.tattoo73, R.drawable.tattoo74,
R.drawable.tattoo75, R.drawable.tattoo76,
R.drawable.tattoo77, R.drawable.tattoo78,
R.drawable.tattoo79, R.drawable.tattoo80,
R.drawable.tattoo81, R.drawable.tattoo82
};
// Constructor
public ImageAdapter(Context c){
mContext = c;
}
public int getCount() {
return Tattoos.length;
}
public Object getItem(int position) {
return Tattoos[position];
}
public long getItemId(int position) {
return 0;
}
public View getView(int position, View convertView, ViewGroup parent) {
//This actually is a bad solution, because every time convertView is reused, you will still initialize new ImageView, which is wrong
//ImageView imageView = new ImageView(this.mContext);
//new BitmapWorkerTask(imageView).execute(Tattoos[position]);
//return imageView;
//Better solution
ImageView imageView = null;
if (convertView == null) {
imageView = new ImageView(this.mContext);
new BitmapWorkerTask(imageView).execute(Tattoos[position]);
//create new ImageView if it is not present and populate it with some image
} else {
imageView = (ImageView) convertView;
//re-use ImageView that already exists in memory
}
return imageView;
}
class BitmapWorkerTask extends AsyncTask<Integer, Void, Bitmap> {
private final WeakReference<ImageView> imageViewReference;
private int data = 0;
public BitmapWorkerTask(ImageView imageView) {
// Use a WeakReference to ensure the ImageView can be garbage collected
imageViewReference = new WeakReference<ImageView>(imageView);
}
// Decode image in background.
@Override
protected Bitmap doInBackground(Integer... params) {
data = params[0];
return decodeSampledBitmapFromResource(ImageAdapter.this.mContext.getResources(), data, 100, 100);
}
// Once complete, see if ImageView is still around and set bitmap.
@Override
protected void onPostExecute(Bitmap bitmap) {
if (imageViewReference != null && bitmap != null) {
final ImageView imageView = imageViewReference.get();
if (imageView != null) {
imageView.setImageBitmap(bitmap);
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
imageView.setLayoutParams(new GridView.LayoutParams(100, 70));
}
}
}
}
public static Bitmap decodeSampledBitmapFromResource(Resources res, int resId,
int reqWidth, int reqHeight) {
// First decode with inJustDecodeBounds=true to check dimensions
final BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
BitmapFactory.decodeResource(res, resId, options);
// Calculate inSampleSize
options.inSampleSize = calculateInSampleSize(options, reqWidth, reqHeight);
// Decode bitmap with inSampleSize set
options.inJustDecodeBounds = false;
return BitmapFactory.decodeResource(res, resId, options);
}
public static int calculateInSampleSize(
BitmapFactory.Options options, int reqWidth, int reqHeight) {
// Raw height and width of image
final int height = options.outHeight;
final int width = options.outWidth;
int inSampleSize = 1;
if (height > reqHeight || width > reqWidth) {
// Calculate ratios of height and width to requested height and width
final int heightRatio = Math.round((float) height / (float) reqHeight);
final int widthRatio = Math.round((float) width / (float) reqWidth);
// Choose the smallest ratio as inSampleSize value, this will guarantee
// a final image with both dimensions larger than or equal to the
// requested height and width.
inSampleSize = heightRatio < widthRatio ? heightRatio : widthRatio;
}
return inSampleSize;
}
}
它异步加载图像并对加载的资源执行一些额外的操作。
这个解决方案对我来说效果很好,当你运行你的代码时,你实际上可以看到一次加载一个图像,从一个重量较轻的图像开始,然后向上,我猜,因为对于每个 ImageView
会有一个单独的 worker Thread
,它将加载和转换资源,然后将其应用到 ImageView
。
证明:
关于java - 在 GridView 组件中显示多个图像时,Android 应用程序崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17370142/
我正在通过 labrepl 工作,我看到了一些遵循此模式的代码: ;; Pattern (apply #(apply f %&) coll) ;; Concrete example user=> (a
我从未向应用商店提交过应用,但我会在不久的将来提交。 到目前为止,我对为 iPhone 而非 iPad 进行设计感到很自在。 我了解,通过将通用PAID 应用放到应用商店,客户只需支付一次就可以同时使
我有一个应用程序,它使用不同的 Facebook 应用程序(2 个不同的 AppID)在 Facebook 上发布并显示它是“通过 iPhone”/“通过 iPad”。 当 Facebook 应用程序
我有一个要求,我们必须通过将网站源文件保存在本地 iOS 应用程序中来在 iOS 应用程序 Webview 中运行网站。 Angular 需要服务器来运行应用程序,但由于我们将文件保存在本地,我们无法
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
假设我有一个安装在用户设备上的 Android 应用程序 A,我的应用程序有一个 AppWidget,我们可以让其他 Android 开发人员在其中以每次安装成本为基础发布他们的应用程序推广广告。因此
Secrets of the JavaScript Ninja中有一个例子它提供了以下代码来绕过 JavaScript 的 Math.min() 函数,该函数需要一个可变长度列表。 Example:
当我分别将数组和对象传递给 function.apply() 时,我得到 NaN 的 o/p,但是当我传递对象和数组时,我得到一个数字。为什么会发生这种情况? 由于数组也被视为对象,为什么我无法使用它
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章ASP转换格林威治时间函数DateDiff()应用由作者收集整理,如果你
我正在将列表传递给 map并且想要返回一个带有合并名称的 data.frame 对象。 例如: library(tidyverse) library(broom) mtcars %>% spl
我有一个非常基本的问题,但我不知道如何实现它:我有一个返回数据框,其中每个工具的返回值是按行排列的: tmp<-as.data.frame(t(data.frame(a=rnorm(250,0,1)
我正在使用我的 FB 应用创建群组并邀请用户加入我的应用群组,第一次一切正常。当我尝试创建另一个组时,出现以下错误: {"(OAuthException - #4009) (#4009) 在有更多用户
我们正在开发一款类似于“会说话的本”应用程序的 child 应用程序。它包含大量用于交互式动画的 JPEG 图像序列。 问题是动画在 iPad Air 上播放正常,但在 iPad 2 上播放缓慢或滞后
我关注 clojure 一段时间了,它的一些功能非常令人兴奋(持久数据结构、函数式方法、不可变状态)。然而,由于我仍在学习,我想了解如何在实际场景中应用,证明其好处,然后演化并应用于更复杂的问题。即,
我开发了一个仅使用挪威语的应用程序。该应用程序不使用本地化,因为它应该仅以一种语言(挪威语)显示。但是,我已在 Info.plist 文件中将“本地化 native 开发区域”设置为“no”。我还使用
读完 Anthony's response 后上a style-related parser question ,我试图说服自己编写单体解析器仍然可以相当紧凑。 所以而不是 reference ::
multicore 库中是否有类似 sapply 的东西?还是我必须 unlist(mclapply(..)) 才能实现这一点? 如果它不存在:推理是什么? 提前致谢,如果这是一个愚蠢的问题,我们深表
我喜欢在窗口中弹出结果,以便更容易查看和查找(例如,它们不会随着控制台继续滚动而丢失)。一种方法是使用 sink() 和 file.show()。例如: y <- rnorm(100); x <- r
我有一个如下所示的 spring mvc Controller @RequestMapping(value="/new", method=RequestMethod.POST) public Stri
我正在阅读 StructureMap关于依赖注入(inject),首先有两部分初始化映射,具体类类型的接口(interface),另一部分只是实例化(请求实例)。 第一部分需要配置和设置,这是在 Bo
我是一名优秀的程序员,十分优秀!