- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想创建infinie GridView,当我滚动时,如果在onScroll 方法中没有添加
adapter = new ImageAdapter();
grid.setAdapter(adapter);
我的应用崩溃了LogCat:
FATAL EXCEPTION: main
java.lang.IndexOutOfBoundsException: Invalid index 46, size is 46
at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:251)
at java.util.ArrayList.get(ArrayList.java:304)
at com.example.tectob6iu.MainActivity$ImageAdapter.getView(MainActivity.java:98)
at android.widget.AbsListView.obtainView(AbsListView.java:2143)
at android.widget.GridView.makeAndAddView(GridView.java:1341)
at android.widget.GridView.makeRow(GridView.java:341)
at android.widget.GridView.fillDown(GridView.java:283)
at android.widget.GridView.fillGap(GridView.java:243)
at android.widget.AbsListView.trackMotionScroll(AbsListView.java:4930)
at android.widget.AbsListView$FlingRunnable.run(AbsListView.java:4087)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
at android.view.Choreographer.doCallbacks(Choreographer.java:562)
at android.view.Choreographer.doFrame(Choreographer.java:531)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
at android.os.Handler.handleCallback(Handler.java:725)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5191)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
at dalvik.system.NativeStart.main(Native Method)
MainActivity.class
public class MainActivity extends Activity implements OnScrollListener{
private class ImageAdapter extends BaseAdapter {
private List<String> list;
private ImageLoader loader;
private DisplayImageOptions options;
public ImageAdapter() {
this(new ArrayList<String>());
options = new DisplayImageOptions.Builder()
.cacheInMemory()
.cacheOnDisc()
.bitmapConfig(Bitmap.Config.RGB_565)
.displayer(new FadeInBitmapDisplayer(250))
.build();
loader = ImageLoader.getInstance();
loader.init(ImageLoaderConfiguration.createDefault(MainActivity.this));
}
public void clear() {
list.clear();
notifyDataSetChanged();
}
public void add(List<String> rows) {
list.addAll(rows);
notifyDataSetChanged();
}
@Override
public int getCount() {
return list.size();
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public String getItem(int position) {
return list.get(position);
}
public View getView(int position, View view, ViewGroup container) {
if (view == null) {
view = getLayoutInflater().inflate(R.layout.grid_item, container, false);
}
ImageView image = (ImageView)view.findViewById(R.id.imageGrid);
// Bind row on your view here 97
//98
if(str.size() > 0){
loader.displayImage(str.get(position), image, options);
}
else{
image.setImageResource(R.drawable.ic_launcher);
}
return view;
}
public ImageAdapter(List<String> list) {
this.list = list;
}
}
class LoadTask extends AsyncTask<Void, Void, List<String>> {
private int page = 1;
public int addPage(int i){
return page = i;
}
@Override
protected List<String> doInBackground(Void... params) {
InputStream ips = null;
JSONObject jsonObj = null;
String json = "";
try {
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpResponse response = httpClient.execute(new HttpPost("http://iapp.gazeta.uz/fotolenta?page="+page));
ips = response.getEntity().getContent();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
try {
BufferedReader bufff = new BufferedReader(new InputStreamReader(ips, "UTF-8"));
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = bufff.readLine()) != null){
sb.append(line + "\n");
}
ips.close();
json = sb.toString();
} catch (Exception e) {
e.printStackTrace();
}
try {
jsonObj = new JSONObject(json);
} catch (JSONException e) {
e.printStackTrace();
}
JSONArray array = null;
array = jsonObj.optJSONArray("img_list");
for (int i = 0; i < array.length(); i++) {
str.add(array.optJSONObject(i).optString("thumbnail"));
}
return str;
}
@Override
protected void onPostExecute(List<String> result) {
adapter.add(result);
}
}
ArrayList<String> str = new ArrayList<String>();
private GridView grid;
private ImageAdapter adapter;
private int page;
private int mVisibleThreshold = 5;
private int mCurrentPage = 0;
private int mPreviousTotal = 0;
private boolean mLoading = true;
private boolean mLastPage = false;
public void refresh(int i){
LoadTask task = new LoadTask();
task.addPage(i);
task.execute();
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
page = 1;
refresh(page);
setContentView(R.layout.main);
grid = (GridView) findViewById(R.id.grid);
adapter = new ImageAdapter();
grid.setAdapter(adapter);
grid.setOnScrollListener(this);
}
@Override
public boolean onCreateOptionsMenu(Menu menu){
getMenuInflater().inflate(R.menu.activity_main, menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item){
page ++;
refresh(page);
adapter = new ImageAdapter();
grid.setAdapter(adapter);
return super.onOptionsItemSelected(item);
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
// TODO Auto-generated method stub
if (mLoading) {
if (totalItemCount > mPreviousTotal) {
mLoading = false;
mPreviousTotal = totalItemCount;
mCurrentPage++;
// Find your own condition in order to know when you
// have finished displaying all items
if (mCurrentPage + 1 > 50) {
mLastPage = true;
}
}
}
if (!mLastPage && !mLoading &&
(totalItemCount - visibleItemCount) <= (firstVisibleItem + mVisibleThreshold)) {
page++;
refresh(page);
adapter = new ImageAdapter();
grid.setAdapter(adapter);
mLoading = true;
}
}
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
// TODO Auto-generated method stub
}
}
否则我的应用程序可以正常工作,但是当我滚动到结束 GridView 刷新并丢失位置并且我需要再次滚动到我的最后一个位置时,如何解决这个问题?
最佳答案
尝试检查这个条件:
if(str.size() > 0 && position < str.size()){
loader.displayImage(str.get(position), image, options);
}
代替
if(str.size() > 0){
loader.displayImage(str.get(position), image, options);
}
希望对你有帮助。
谢谢。
关于安卓动态gridview,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13945941/
我想将 EditText 始终设置为 LTR,我该怎么做?android:textDirection 似乎确实是答案,我无法让项目使用该指令进行编译 最佳答案 为 editText 使用引力 andr
我希望我的应用在每次打开时都显示登录屏幕。使用 android:clearTaskOnLaunch="true" 一切正常。但是有一个错误,只有在手机关机并且应用程序首先使用小部件启动时才会发生。 I
实际上我的要求是我想将动态文件加载到像图像一样的网页中。视频,音频等,它来自 Assets 或应用程序自己的文件目录,这不是问题。 我尝试使用以下两种方式。 方式一 这是我的 html 文件在 ass
我正在触发一个 DatePickerDialog,在 api 22 (Android 5.1) 之前它一直在工作并显示良好,我在上面设置混合和最大日期(最小 = 当前日期,最大 = 从当前日期开始的
我有一个 ListView ,我在其中将标题 View 添加到该列表。一切都很好,但是当滚动列表 headerview 也随着列表移动时,所以我想避免 headerview 滚动,我的意思是当我列表到
虽然我在android上做过一些app,但我还是一头雾水。是否可以使用 SDK 4.0 中的功能,并在 android 2.1 或更低版本上运行该应用程序? 我尝试了你们提到的方法,但出现错误 - F
您好,我正在开发小型 android 应用程序,我想在其中显示带有一些元素的简单 gridview。它工作正常。唯一的问题是即使有空间,它也总是只显示两列。它平均将屏幕分成 2 列并仅显示两个元素。如
我正在使用 Android 2.3.3 API 构建一个应用程序。我需要识别方向的变化并执行一些操作。所以我在 Android Manifest 中添加了以下内容, android:configCha
我正在尝试在“点击”包含特定 MIME 类型的 nfc 标签时开始一项 Activity 。我制作了一个 mime 类型为“text/plain”的标签,并将其添加到 list 中:
我可以将一些数据保存到文件中 val byteArrayOutputStream = ByteArrayOutputStream() byteArrayOutputStream.wri
我正在尝试解析一个包含复杂阿拉伯字母的 XML 文件.. 当我在 android 2.3.7 上测试时,并不是所有的阿拉伯字母都被支持,仍然有一些复杂的显示为方 block .. 但是在 androi
我需要编写一个方法来确定设备是平板电脑还是手机。我不需要根据这个显示不同的用户界面。我只需要有关设备的信息,以便将来我可以将其发送到指标。 在互联网上,我找到了很多方法来确定设备是否是平板电脑。我已经
我正在玩文字转语音,让我的测试应用程序更有趣。它适用于模拟器,但不适用于我的手机,因为我的默认语言环境不是英语。 但是,文本是英文的,所以 tts 当然应该使用英文。据我所知,我可以实现一个自动安装,
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
这个问题在这里已经有了答案: I lost my .keystore file? (12 个回答) 4年前关闭。 当我以前的操作系统损坏并安装新的(7 月 3 日)时,以前的 android_key_
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
在我的 v27\style.xml 中,我有以下代码来设置白色导航栏: @color/colorPrimary @color/colorPrimaryDark @color/
我想通过发送电子邮件 startActivity(Intent.createChooser(new Intent(android.content.Intent.ACTION_SEND))) 我知道要将
我实现了一个自定义 ListView ,它看起来像 Twitter 时间线。 adapter = new MyClickableListAdapter(this, R.layout.timeline,
我有一个显示启动画面的自定义对话框; mSplashDialog = new Dialog(MyActivity.this,R.layout.splash); mSplashDialog.setCon
我是一名优秀的程序员,十分优秀!