Во-первых, я прошу прощения за мой английский, поскольку он не очень хорош. Благодарю.
Мое приложение содержит несколько ListWiews с адаптерами. Данные для ListViews взяты из проанализированного XML-файла, расположенного в Интернете.
Теперь у меня есть один TabHost с тремя вкладками и различными ListViews в каждой вкладке.
Я хочу изменить TabHost на новый и легкий метод - индикатор ViewPager от Джейка Уортона (https://github.com/JakeWharton/Android-ViewPagerIndicator), ', потому что есть потрясающий эффект скольжения.
Я попытался включить этот код в пример проекта, и он работает хорошо.
Пока у меня есть ListView в одном фрагменте ViewPager и простой TextView в двух других фрагментах. Это работает.
Код ViewPagerAdapter показан ниже:
package com.formatbce.pager;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.content.Context;
import android.os.Parcelable;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import com.viewpagerindicator.TitleProvider;
public class ViewPagerAdapter extends PagerAdapter
implements TitleProvider
{
private int[] scrollPosition = new int[titles.length];
private static String[] titles = new String[]
{
"News",
"Bio",
"Music"
};
private final Context context;
public ViewPagerAdapter( Context context )
{
this.context = context;
for ( int i = 0; i < titles.length; i++ )
{
scrollPosition[i] = 0;
}
}
@Override
public String getTitle( int position )
{
return titles[ position ];
}
@Override
public int getCount()
{
return titles.length;
}
@Override
public Object instantiateItem( View pager, final int position )
{
if (position == 0) {
ListView v = new ListView( context );
String[] from = new String[] { "str" };
int[] to = new int[] { android.R.id.text1 };
List<Map<String, String>> items =
new ArrayList<Map<String, String>>();
for ( int i = 0; i < 20; i++ )
{
Map<String, String> map =
new HashMap<String, String>();
map.put( "str", String.format( "Item %d", i + 1 ) );
items.add( map );
}
SimpleAdapter adapter = new SimpleAdapter( context, items,
android.R.layout.simple_list_item_1, from, to );
v.setAdapter( adapter );
( (ViewPager) pager ).addView( v, 0 );
v.setOnScrollListener( new OnScrollListener()
{
@Override
public void onScroll( AbsListView view,
int firstVisibleItem,
int visibleItemCount,
int totalItemCount )
{
scrollPosition[ position ] = firstVisibleItem;
}
@Override
public void onScrollStateChanged(AbsListView view,
int scrollState) {
// TODO Auto-generated method stub
}
} );
return v;}
else {
TextView v = new TextView( context );
v.setText( titles[ position ] );
((ViewPager)pager).addView( v, 0 );
return v;
}
}
@Override
public void destroyItem( View pager, int position, Object view )
{
if (position == 0){
( (ViewPager) pager ).removeView( (ListView) view );}
else {
( (ViewPager) pager ).removeView( (TextView) view );}
}
@Override
public boolean isViewFromObject( View view, Object object )
{
return view.equals( object );
}
@Override
public void finishUpdate( View view ) {}
@Override
public void restoreState( Parcelable p, ClassLoader c ) {}
@Override
public Parcelable saveState() {
return null;
}
@Override
public void startUpdate( View view ) {}
}
Итак, с примером ListView все хорошо.
Но мои проблемы начинаются, когда я пытаюсь поместить туда свой собственный ListView. В моем старом проекте этот ListView имеет код:
package com.formatbce.mdrive;
import java.util.ArrayList;
import android.app.AlertDialog;
import android.app.ListActivity;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.widget.ListView;
public class Concerts extends ListActivity {
private ArrayList<Rss_PostItem> messages;
private Rss_PostAdapter adapter;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (savedInstanceState != null) {
messages = savedInstanceState.getParcelableArrayList("messages");
adapter = new Rss_PostAdapter(Concerts.this, R.layout.post_entry,
messages);
setListAdapter(adapter);
} else
new GetParserResult().execute();
}
@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
super.onListItemClick(l, v, position, id);
Intent postActivity = new Intent(this, Rss_PostActivity.class);
Bundle store = new Bundle();
store.putString("title", messages.get(position).title);
store.putString("description", messages.get(position).description);
store.putString("link", messages.get(position).link);
postActivity.putExtras(store);
startActivity(postActivity);
}
protected void onSaveInstanceState(Bundle savedInstanceState) {
super.onSaveInstanceState(savedInstanceState);
savedInstanceState.putParcelableArrayList("messages", messages);
}
private class GetParserResult extends
AsyncTask<Context, Integer, ArrayList<Rss_PostItem>> {
private ProgressDialog loadingDialog;
private Concerts_Parser parser;
protected void onPreExecute() {
parser = new Concerts_Parser();
loadingDialog = ProgressDialog.show(Concerts.this, "",
"Loading concerts list...", true);
}
@Override
protected ArrayList<Rss_PostItem> doInBackground(Context... arg0) {
return parser.parse();
}
protected void onPostExecute(ArrayList<Rss_PostItem> result) {
if (result == null) {
AlertDialog.Builder builder = new AlertDialog.Builder(
Concerts.this);
builder.setMessage(
"Cannot load list... \nIs Internet ON?")
.setCancelable(false)
.setPositiveButton("Ok",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int id) {
dialog.cancel();
loadingDialog.dismiss();
}
});
AlertDialog alert = builder.create();
alert.show();
} else {
messages = result;
loadingDialog.dismiss();
adapter = new Rss_PostAdapter(Concerts.this,
R.layout.post_entry, messages);
setListAdapter(adapter);
}
}
}
}
Так что я не понимаю, как правильно поставить это в коде ViewPager.
Я пытался настроить ListFragment, но для меня это довольно ново, поэтому я не могу заставить его работать.
Google тоже не может мне помочь, так же, как различные форумы разработчиков.
Действительно, вопрос в том, как получить собственный ListView для отображения в ViewPager?
Спасибо, я надеюсь на вашу помощь.
UPD:
Благодаря первому ответу я попытался преобразовать одно из моих занятий во фрагмент с помощью этого урока: http://www.e -nature.ch / tech /? P = 55 .
Прежде всего, это была одна ошибка, которую я не мог передать: эта переменная не преобразована, и я не знаю, как заставить ее работать.
dm = (DownloadManager) getSystemService(DOWNLOAD_SERVICE);
Теперь еще одна вещь: когда я пытался поместить Fragment результата в FragmentPagerAdapter - я застрял, находя правильный код здесь:
@Override
public Fragment getItem(int arg0) {
// TODO Auto-generated method stub
return ?????????;
}
Скажите, пожалуйста, что этот метод должен вернуть?
Спасибо!