草庐IT

android - 带有自定义 ListView 的 ViewPager Indicator

coder 2023-12-22 原文

首先,我为我的英语道歉,因为它不是很好。谢谢。 我的应用程序包含几个带有适配器的 ListWiews。 ListView 的数据取自位于 Internet 上的经过解析的 XML 文件。 现在我有一个 TabHost,其中包含三个选项卡,每个选项卡中都有不同的 ListView。 我想将 TabHost 更改为新的和轻微的方法 - Jake Wharton (https://github.com/JakeWharton/Android-ViewPagerIndicator) 的 ViewPager Indicator,因为它有很棒的滑动效果。

我尝试将这段代码包含在一个示例项目中,它运行良好。 现在,我在 ViewPager 的一个 fragment 中有一个 ListView,在另外两个 fragment 中有一个简单的 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 中?

谢谢,希望对您有所帮助。

更新:

感谢第一个回答,我尝试使用本教程将我的一个 Activity 转换为 fragment :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 ?????????;
}

请告诉我,这个方法必须返回什么? 谢谢!

最佳答案

你说

i have one TabHost with three tabs, and different ListView in each tab

我假设您有三个不同的 listActivity 并将其传递给 tabHost。所以将三个activity转化为三个Fragments。

基于以下示例代码更改您的 ViewPagerAdapter

class GoogleMusicAdapter extends FragmentPagerAdapter implements
        TitleProvider {
    public GoogleMusicAdapter(FragmentManager fm) {
        super(fm);
    }

    @Override
    public Fragment getItem(int position) {
                    if(position ==0 )
        // return your Fragment1 
                    else if(position==1)
                    // return your Fragment2
                    else
                    // return fragment3
    }

    @Override
    public int getCount() {
        return 3;
    }

    @Override
    public String getTitle(int position) {
        if(position ==0 )
                    return "One"
                    else if(position ==1)
                    return "two"
                    else
                    return "three"
    }
}

关于android - 带有自定义 ListView 的 ViewPager Indicator,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9632723/

有关android - 带有自定义 ListView 的 ViewPager Indicator的更多相关文章

  1. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  2. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  3. ruby-on-rails - form_for 中不在模型中的自定义字段 - 2

    我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢

  4. ruby - 主要 :Object when running build from sublime 的未定义方法 `require_relative' - 2

    我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby​​1.9+ 关于ruby-主要:Objectwhenrun

  5. ruby - 在 Ruby 中有条件地定义函数 - 2

    我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin

  6. ruby - 定义方法参数的条件 - 2

    我有一个只接受一个参数的方法:defmy_method(number)end如果使用number调用方法,我该如何引发错误??通常,我如何定义方法参数的条件?比如我想在调用的时候报错:my_method(1) 最佳答案 您可以添加guard在函数的开头,如果参数无效则引发异常。例如:defmy_method(number)failArgumentError,"Inputshouldbegreaterthanorequalto2"ifnumbereputse.messageend#=>Inputshouldbegreaterthano

  7. ruby - 如何在 Grape 中定义哈希数组? - 2

    我使用Ember作为我的前端和GrapeAPI来为我的API提供服务。前端发送类似:{"service"=>{"name"=>"Name","duration"=>"30","user"=>nil,"organization"=>"org","category"=>nil,"description"=>"description","disabled"=>true,"color"=>nil,"availabilities"=>[{"day"=>"Saturday","enabled"=>false,"timeSlots"=>[{"startAt"=>"09:00AM","endAt"=>

  8. ruby - 获取模块中定义的所有常量的值 - 2

    我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c

  9. ruby - 这两个 Ruby 类初始化定义有什么区别? - 2

    我正在阅读一本关于Ruby的书,作者在编写类初始化定义时使用的形式与他在本书前几节中使用的形式略有不同。它看起来像这样:classTicketattr_accessor:venue,:datedefinitialize(venue,date)self.venue=venueself.date=dateendend在本书的前几节中,它的定义如下:classTicketattr_accessor:venue,:datedefinitialize(venue,date)@venue=venue@date=dateendend在第一个示例中使用setter方法与在第二个示例中使用实例变量之间是

  10. ruby-on-rails - 如何生成传递一些自定义参数的 `link_to` URL? - 2

    我正在使用RubyonRails3.0.9,我想生成一个传递一些自定义参数的link_toURL。也就是说,有一个articles_path(www.my_web_site_name.com/articles)我想生成如下内容:link_to'Samplelinktitle',...#HereIshouldimplementthecode#=>'http://www.my_web_site_name.com/articles?param1=value1¶m2=value2&...我如何编写link_to语句“alàRubyonRailsWay”以实现该目的?如果我想通过传递一些

随机推荐