现在差不多2个月了,特别是在java,android编码。 我遇到了一个问题,现在我已经挣扎了两天多了。
基本上,我有一个充满字符串(url)的数据库。 我正在尝试构建一个应用程序,我将所选的(通过我的查询)Urls传递到Universal Image Loader,最终得到一个Viewpager,其中包含从UIL下载的所有图像。
我已经构建了自己的适配器(为了将它用于ViewPager)但我不知道如何使用Universal Image Loader并创建ViewPager。
这是我的代码: 的 MenuImages.java
public class Menu_images extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.menu_gallery);
Bundle map = getIntent().getExtras();
String rest_name=map.getString("key");
String area=map.getString("key2");
loadGalleryImages(rest_name, area);
}
private void loadGalleryImages(String rest_name, String area) {
DatabaseHandler db = new DatabaseHandler(getApplicationContext());
List<String> images_url = db.getImagesUrl(rest_name, area);
MyPagerAdapter adapter = new MyPagerAdapter();
ViewPager myPager = (ViewPager) findViewById(R.id.myfivepanelpager);
myPager.setAdapter(adapter);
myPager.setCurrentItem(0);
}
MyPagerAdapter.java
public class MyPagerAdapter extends PagerAdapter {
Context context;
private Integer[] Imgid = {
R.drawable.gallery_photo_1, R.drawable.gallery_photo_3, R.drawable.gallery_photo_1
};
public MyPagerAdapter(List<String> images_url) {
// TODO Auto-generated constructor stub
}
public int getCount() {
return Imgid.length;
}
public Object instantiateItem(View collection, int position) {
ImageView img = new ImageView(collection.getContext());
int resId = 0;
switch (position) {
case 0:
resId = Imgid[0];
break;
case 1:
resId = Imgid[1];
break;
case 2:
resId = Imgid[2];
break;
}
img.setImageResource(resId);
((ViewPager) collection).addView(img, 0);
return img;
}
public void destroyItem(View arg0, int arg1, Object arg2) {
((ViewPager) arg0).removeView((View) arg2);
}
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == ((View) arg1);
}
public Parcelable saveState() {
return null;
}
}
DataBaseHandler.java
public List<String> getImagesUrl(String rest_name, String area) {
List<String> images_url = new ArrayList<String>();
// Select All Query
String selectQuery = "a query goes here";
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
// looping through all rows and adding to list
if (cursor.moveToFirst()) {
do {
images_url.add(cursor.getString(cursor.getColumnIndex("_images")));
} while (cursor.moveToNext());
}
// closing connection
cursor.close();
db.close();
return images_url;
}
正如您所看到的,我从DataBaseHandler获取一个包含所有String(url)的List。 我实际上需要从我的MyPagerAdapter中删除数组Interger []并使用我从DataBaseHandler(带有URL的那个)检索的List动态替换它。
总而言之,我正在尝试使Universal Image Loader使用我传递给它的所有URL并创建一个包含这些URL的viewpager。
如果你能帮我一把,我会永远感激,因为我开始吓坏了。我花了很多天在这个部分,寻找几个小时,但没有找到适合我的东西。
提前致谢并对此长谈感到抱歉, 哈里斯。
答案 0 :(得分:0)
这对你来说是完美的example。下载右上角的源代码,然后运行该应用程序。您可以学习源代码,它拥有您所需要的一切。它有点进步,不要惊慌失措。如果您有任何问题,请发布问题。