我正在開發Android應用程序,我想在水平列表視圖中顯示從Web服務檢索到的json格式文本和圖像。我存儲JSON格式化數據到ArrayList中如何在水平列表視圖中顯示從Web服務檢索到的Json文本和圖像?
1
A
回答
1
的第一件事是如何顯示水平的ListView。我想推薦你使用RecyclerView
來獲得更順暢的listView顯示。那麼如何在Horizontal中顯示recyclerView?這是我的教程一步一步。
首先,在XML文件應該是這樣的:
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_alignParentBottom="true"
android:scrollbars="vertical" />
其次,在活動的onCreate
應該是這樣的:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
recyclerViewItem = (RecyclerView) findViewById(R.id.recyclerView);
LinearLayoutManager itemslayoutManager = new LinearLayoutManager(getApplicationContext());
itemslayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
recyclerViewItem.setLayoutManager(itemslayoutManager);
SampleAdapter sampleAdapter = new SampleAdapter(List<SampleData>);
recyclerViewItem.setAdapter(sampleAdapter);
return true;
}
爲了解析JSON你應該使用庫調用:Retrofit
代替AsyncTask
試試這個: Retrofit
0
activity_main.xml中
<android.support.v4.view.ViewPager
android:layout_width="match_parent"
android:layout_height="match_parent"
android:numColumns="auto_fit"
android:horizontalSpacing="4dp"
android:stretchMode="columnWidth"
android:id="@+id/gallery_child_list"
android:background="#E4E4E4"
android:verticalSpacing="4dp" />
Mainactivity
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Get the view from activity_main.xml
setContentView(R.layout.activity_main);
// Execute DownloadJSON AsyncTask
new DownloadJSON().execute();
}
// DownloadJSON AsyncTask
private class DownloadJSON extends AsyncTask<Void, Void, Void> {
@Override
protected void onPreExecute() {
super.onPreExecute();
// Create a progressdialog
mProgressDialog = new ProgressDialog(MainActivity.this);
// Set progressdialog message
mProgressDialog.setMessage("Loading...");
mProgressDialog.setIndeterminate(false);
// Show progressdialog
mProgressDialog.show();
}
@Override
protected Void doInBackground(Void... params) {
// Create an array
arraylist = new ArrayList<HashMap<String, String>>();
// Retrieve JSON Objects from the given URL address
try {
HttpClient client = new DefaultHttpClient();
HttpPost httppost = new HttpPost("YOUR_URL");
HttpResponse response = client.execute(httppost);
HttpEntity resEntity = response.getEntity();
String json = EntityUtils.toString(resEntity);
JSONObject jObject = new JSONObject(json);
// Locate the array name in JSON
HashMap<String, String> map = new HashMap<String, String>();
JSONObject jsonobject = jObject.optJSONObject("online");
for (int i = 0; i < jObject.length(); i++) {
map.put("date", jsonobject.getString("men"));
map.put("flag", jsonobject.getString("kids"));
map.put("flag", jsonobject.getString("women"));
// Set the JSON Objects into the array
arraylist.add(map);
}
} catch (Exception e1) {
e1.printStackTrace();
}
return null;
}
@Override
protected void onPostExecute(Void args) {
viewPager = (ViewPager) findViewById(R.id.pager);
adapter = new ViewPagerAdapter(MainActivity.this, arraylist);
viewPager.setAdapter(adapter);
// Close the progressdialog
mProgressDialog.dismiss();
adapter.notifyDataSetChanged();
}
}
viewpageradapter
public class ViewPagerAdapter extends PagerAdapter {
// Declare Variables
Context context;
LayoutInflater inflater;
ArrayList<HashMap<String, String>> data;
ImageLoader imageLoader;
HashMap<String, String> resultp = new HashMap<String, String>();
public ViewPagerAdapter(Context context, ArrayList<HashMap<String, String>> arraylist) {
this.context = context;
data = arraylist;
imageLoader = new ImageLoader(context);
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == ((RelativeLayout) object);
}
@Override
public int getCount() {
return data.size();
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
// Declare Variables
ImageView imgflag;
inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View itemView = inflater.inflate(R.layout.viewpager_item, container,false);
// Locate the ImageView in viewpager_item.xml
imgflag = (ImageView) itemView.findViewById(R.id.flag);
// Capture position
resultp = data.get(position);
// Capture position and set results to the ImageView
// Passes flag images URL into ImageLoader.class
imageLoader.DisplayImage(resultp.get(MainActivity.FLAG), imgflag);
// Add viewpager_item.xml to ViewPager
((ViewPager) container).addView(itemView);
return itemView;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
// Remove viewpager_item.xml from ViewPager
((ViewPager) container).removeView((RelativeLayout) object);
}
}
相關問題
- 1. 使用json在列表視圖中顯示圖像和文本
- 2. 不在水平列表視圖中顯示圖像上的圖像
- 3. 如何從SQLiteDB中檢索圖像和文本以在列表視圖中顯示
- 4. 顯示列表視圖水平
- 5. 水平顯示兩個圖像視圖
- 6. 如何在TableViewCell中顯示圖像(從JSON服務動態檢索)
- 7. 在列表視圖中顯示圖像和文本
- 8. 水平滾動圖像視圖列表
- 9. 如何在水平滾動視圖下顯示圖像
- 10. Android/Java - 如何從Web服務中檢索圖像並將其顯示出來
- 11. 如何從列表視圖中檢索Firebase中的圖像
- 12. 如何通過解碼來自web服務器的圖像在列表視圖中顯示圖像?
- 13. 如何從Web服務器url路徑檢索圖像到angularJS
- 14. 從垂直到水平(圖像列表)
- 15. 來自服務器的圖像不顯示在列表視圖
- 16. 如何從sqlite檢索數據顯示在文本視圖
- 17. 如何在水平列表視圖
- 18. 如何使用xamarin Android的web服務和顯示在列表視圖
- 19. 如何從服務器檢索圖像並使用json解析顯示?
- 20. css水平顯示圖像
- 21. 水平顯示圖像CSS
- 22. 水平顯示圖像
- 23. 顯示圖像水平
- 24. 在列表視圖中顯示圖像
- 25. 在列表視圖中顯示圖像
- 26. 如何水平顯示圖像
- 27. 如何水平顯示兩個圖像?
- 28. 如何使圖像水平顯示
- 29. 在列表視圖中顯示圖像而不是文本
- 30. 如何在網格視圖中顯示來自Web服務的圖像
獲取JSON數據基於您的JSON網址。 如果你沒有JSON數組,這個JSON將工作。 –