1

我有两个片段 Fragment1 和 Fragment2。当我启动应用程序时,两个片段中定义的函数都会被执行。所以启动需要很长时间(因为 XML 解析和列表视图的填充都在两个片段上执行)。我需要减少应用程序的启动时间。他们有什么方法可以在启动时执行 Fragment1,而将 Fragment2 的执行带到后台?这样用户就可以与 Fragment1 进行交互,而 Fragment2 在不打扰用户的情况下执行其功能。

这是我的代码,

片段1=>

    public class Fragment1 extends Fragment{


public static String feedurl="http://www.abcd.com/en/rssfeeds/1_2_3_5/latest/rss.xml";
static String URL = "";
static final String KEY_HEAD = "item"; // parent node
static final String KEY_DATE = "pubDate";
public static String headflag="";
int f=0;
GridView list;
HeadlinesAdapter adapter;
private TextView mMessageView;
private Button mClearButton;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) {

    View v = inflater.inflate(R.layout.first_fragment, container, false);


    return v;
}

@Override
public void onViewCreated(View view, Bundle savedInstanceState) {
    super.onViewCreated(view, savedInstanceState);



    headlines.parse();
    populate_listview();

    }


 public void populate_listview()
 {


     URL="http://www.abcd.com/en/rssfeeds/1_2_3_5/latest/rss.xml";
     ArrayList<HashMap<String, String>> newsList = new ArrayList<HashMap<String, String>>();

    XMLParser parser = new XMLParser();
    String xml = parser.getXmlFromUrl(URL);
    Document doc = parser.getDomElement(xml);
    NodeList nl = doc.getElementsByTagName(KEY_HEAD);
    NodeList itemLst = doc.getElementsByTagName("item");
    String MarqueeStr="";

    for (int i = 0; i < nl.getLength(); i++) {
        HashMap<String, String> map = new HashMap<String, String>();
        Element e = (Element) nl.item(i);
                    newsList.add(map);


 }
    list=(GridView)getActivity().findViewById(R.id.grid);
    adapter=new Adapter1(getActivity(), newsList);        
            list.setAdapter(adapter);

  }

片段2=>

    public class Fragment2 extends Fragment{


public static String feedurl="http://www.abcd.com/en/rssfeeds/1_2_3_5/latest/rss.xml";
static String URL = "";
static final String KEY_HEAD = "item"; // parent node
static final String KEY_DATE = "pubDate";
public static String headflag="";
int f=0;
GridView list;
HeadlinesAdapter adapter;
private TextView mMessageView;
private Button mClearButton;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) {

    View v = inflater.inflate(R.layout.second_fragment, container, false);


    return v;
}

@Override
public void onViewCreated(View view, Bundle savedInstanceState) {
    super.onViewCreated(view, savedInstanceState);



    sports.parse();
    populate_listview();

    }


 public void populate_listview()
 {


     URL="http://www.abcd.com/en/rssfeeds/1_2_3_5/latest/rss.xml";
     ArrayList<HashMap<String, String>> newsList = new ArrayList<HashMap<String, String>>();

    XMLParser parser = new XMLParser();
    String xml = parser.getXmlFromUrl(URL);
    Document doc = parser.getDomElement(xml);
    NodeList nl = doc.getElementsByTagName(KEY_HEAD);
    NodeList itemLst = doc.getElementsByTagName("item");
    String MarqueeStr="";

    for (int i = 0; i < nl.getLength(); i++) {
        HashMap<String, String> map = new HashMap<String, String>();
        Element e = (Element) nl.item(i);
                newsList.add(map);


 }
    list=(GridView)getActivity().findViewById(R.id.grid2);
    adapter=new HeadlinesAdapter(getActivity(), newsList);        
            list.setAdapter(adapter);

  }

主要活动=>

 public class MainActivity extends FragmentActivity {

private ViewPager mViewPager;
private MessageLoader mLoader;
private Button mSenderButton, mReceiverButton;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    // We get UI references
    mViewPager = (ViewPager) findViewById(R.id.viewPager);
    mSenderButton = (Button) findViewById(R.id.sender_button);
    mReceiverButton = (Button) findViewById(R.id.receiver_button);
    // set pager adapter
    mViewPager.setAdapter(new MyAdapter(this));
    // set receiver button listener
    mReceiverButton.setOnClickListener(new OnClickListener() {          

        public void onClick(View v) {
            mViewPager.setCurrentItem(1);
        }
    });

    mSenderButton.setOnClickListener(new OnClickListener() {            

        public void onClick(View v) {
            mViewPager.setCurrentItem(0);
        }
    });
}


private class MyAdapter extends FragmentPagerAdapter{

    private Context mContext;
    private String[] frags = {Fragment1.class.getName(), Fragment2.class.getName()};

    public MyAdapter(FragmentActivity activity) {
        super(activity.getSupportFragmentManager());
        mContext = activity;
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        Fragment frag = (Fragment) super.instantiateItem(container, position);
        if(frag instanceof MessageLoader){
            mLoader = (MessageLoader) frag;
        }
        return frag;
    }

    @Override
    public Fragment getItem(int pos) {
        return Fragment.instantiate(mContext, frags[pos]);
    }

    @Override
    public int getCount() {
        return frags.length;
    }

}
}
4

1 回答 1

1

这与您的其他问题有关:

他们有什么方法可以在应用程序启动时停止执行 Fragment2。我只有在滑动到 Fragment2 时才需要启动它

不,你不应该首先尝试这样做。ViewPager需要第二个(Fragment尚不可见)处于良好状态,以便用户可以在选择时立即滑动到它。如果这Fragment不会被构建,那么用户体验将会很差,尤其是在您从UrlUI线程上解析一些 xml 的情况下。如果您想提高应用程序的速度并避免可能的 ANR,您应该真正考虑在后台线程上进行 xml 解析。

我想在启动时调用“function1”,只有在滑动到 Fragment2 时才调用“function2”

保持Fragment1 不变(调用您希望调用的方法),然后OnPageChangeListenerViewPager. 我假设您使用自定义FragmentPagerAdapter,因此您可以获得对第二个的引用Fragment并直接调用该populate_listview()方法:

@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
      Fragment2 = (Fragment2) getSupportFragmentManager()
                    .findFragmentByTag(
                            "android:switcher:" + R.id.viewPager + ":" + 1);
      if (fragment != null) {
        fragment.populate_listview();// remove the call from onViewCreated
      }
}

但这只是一个黑客。您要做的是使用后台线程(AysncTask或普通线程)进行长时间操作。看看这个博客条目

于 2012-11-14T10:52:51.943 回答