【问题标题】:Error: The constructor MainActivity.ScreenSlidePagerAdapter(FragmentManager) is undefined错误:构造函数 MainActivity.ScreenSlidePagerAdapter(FragmentManager) 未定义
【发布时间】:2013-02-19 05:58:03
【问题描述】:

我尝试在http://developer.android.com/training/animation/screen-slide.html 中实现一个 android 项目,但在一个类中出现错误

import android.os.Bundle;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentManager;
import android.content.Intent;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.support.v4.app.NavUtils;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;

public class MainActivity extends FragmentActivity {
 private static final int NUM_PAGES = 5;
 private ViewPager mPager;
 private PagerAdapter mPagerAdapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mPager = (ViewPager) findViewById(R.id.pager);
    mPagerAdapter = new ScreenSlidePagerAdapter(getFragmentManager());
    mPager.setAdapter(mPagerAdapter);
    mPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
        @Override
        public void onPageSelected(int position) {
            // When changing pages, reset the action bar actions since they are dependent
            // on which page is currently active. An alternative approach is to have each
            // fragment expose actions itself (rather than the activity exposing actions),
            // but for simplicity, the activity provides the actions in this sample.
            invalidateOptionsMenu();
        }
    });
}
@SuppressLint("NewApi")
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    super.onCreateOptionsMenu(menu);
    getMenuInflater().inflate(R.menu.activity_main, menu);

    menu.findItem(R.id.action_previous).setEnabled(mPager.getCurrentItem() > 0);

    // Add either a "next" or "finish" button to the action bar, depending on which       page
    // is currently selected.
    MenuItem item = menu.add(Menu.NONE, R.id.action_next, Menu.NONE,
            (mPager.getCurrentItem() == mPagerAdapter.getCount() - 1)
                    ? R.string.action_finish
                    : R.string.action_next);
    item.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM | MenuItem.SHOW_AS_ACTION_WITH_TEXT);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
        case android.R.id.home:
            // Navigate "up" the demo structure to the launchpad activity.
            // See http://developer.android.com/design/patterns/navigation.html for more.
            NavUtils.navigateUpTo(this, new Intent(this, MainActivity.class));
            return true;

        case R.id.action_previous:
            // Go to the previous step in the wizard. If there is no previous step,
            // setCurrentItem will do nothing.
            mPager.setCurrentItem(mPager.getCurrentItem() - 1);
            return true;

        case R.id.action_next:
            // Advance to the next step in the wizard. If there is no next step, setCurrentItem
            // will do nothing.
            mPager.setCurrentItem(mPager.getCurrentItem() + 1);
            return true;
    }

    return super.onOptionsItemSelected(item);
}


     private class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
      public ScreenSlidePagerAdapter(FragmentManager fm) {
         super(fm);
     }

 public Fragment getItem(int position) {
        return ScreenSlidePageFragment.create(position);
    }


    public int getCount() {
        return NUM_PAGES;
    }
}
    }

我正在 android 4.2 中构建项目。

编辑:我已将代码更改为

private class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
    public ScreenSlidePagerAdapter(android.support.v4.app.FragmentManager fm) {
        super(fm);
    }

 @Override
    public android.support.v4.app.Fragment getItem(int position) {
        return Firstframe.create(position);
    }

然后发生错误

mPagerAdapter = new ScreenSlidePagerAdapter(getFragmentManager());

错误:The constructor MainActivity.ScreenSlidePagerAdapter(FragmentManager) is undefined

【问题讨论】:

  • V4完整代码参考我的回答:link

标签: java android android-viewpager


【解决方案1】:

而不是这个:

mPagerAdapter = new ScreenSlidePagerAdapter(getFragmentManager());

这样做:

mPagerAdapter = new ScreenSlidePagerAdapter(getSupportFragmentManager());

因为

getFragmentManager()import android.app.FragmentManager 一起使用

getSupportFragmentManager()android.support.v4.app.FragmentManager 一起使用

【讨论】:

  • 我已经更新了库,但仍然出现同样的错误...minSDK verison = 18..任何建议。
【解决方案2】:

将您的 FragmentManager 更改为 android.support.v4.app.FragmentManager。 导入

android.support.v4.app.FragmentStatePagerAdapter; ScreenSlideActivity.java 的以下代码:

公共类 ScreenSlideActivity 扩展 FragmentActivity {

private static final int NUM_PAGES = 5;

private ViewPager mPager;


private PagerAdapter mPagerAdapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_screen_slide);

    // Instantiate a ViewPager and a PagerAdapter.
    mPager = (ViewPager) findViewById(R.id.pager);
    mPagerAdapter = new ScreenSlidePagerAdapter(getSupportFragmentManager());
    mPager.setAdapter(mPagerAdapter);
    mPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
        @Override
        public void onPageSelected(int position) {

            invalidateOptionsMenu();
        }
    });
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    super.onCreateOptionsMenu(menu);
    getMenuInflater().inflate(R.menu.activity_screen_slide, menu);

    menu.findItem(R.id.action_previous).setEnabled(mPager.getCurrentItem() > 0);


    MenuItem item = menu.add(Menu.NONE, R.id.action_next, Menu.NONE,
            (mPager.getCurrentItem() == mPagerAdapter.getCount() - 1)
                    ? R.string.action_finish
                    : R.string.action_next);
    item.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM | MenuItem.SHOW_AS_ACTION_WITH_TEXT);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
        case android.R.id.home:

            NavUtils.navigateUpTo(this, new Intent(this, MainActivity.class));
            return true;

        case R.id.action_previous:

            mPager.setCurrentItem(mPager.getCurrentItem() - 1);
            return true;

        case R.id.action_next:

            mPager.setCurrentItem(mPager.getCurrentItem() + 1);
            return true;
    }

    return super.onOptionsItemSelected(item);
}


private class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
    public ScreenSlidePagerAdapter(android.support.v4.app.FragmentManager fm) {
        super(fm);
    }

    @Override
    public android.support.v4.app.Fragment getItem(int position) {
        return ScreenSlidePageFragment.create(position);
    }

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

ScreenSlidePageFragment.java 的以下代码:

公共类 ScreenSlidePageFragment 扩展片段 {

public static final String ARG_PAGE = "page";


private int mPageNumber;


public static android.support.v4.app.Fragment create(int pageNumber) {
    android.support.v4.app.Fragment fragment = new android.support.v4.app.Fragment();
    Bundle args = new Bundle();
    args.putInt(ARG_PAGE, pageNumber);
    fragment.setArguments(args);
    return fragment;
}

public ScreenSlidePageFragment() {
}

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    mPageNumber = getArguments().getInt(ARG_PAGE);
}

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

    ViewGroup rootView = (ViewGroup) inflater
            .inflate(R.layout.fragment_screen_slide_page, container, false);

    // Set the title view to show the page number.
    ((TextView) rootView.findViewById(android.R.id.text1)).setText(
            getString(R.string.title_template_step, mPageNumber + 1));

    return rootView;
}



public int getPageNumber() {
    return mPageNumber;
}}

【讨论】:

    【解决方案3】:

    当我看穿你的代码时,我发现构造函数中的 FragmentManager 类与你在代码中导入的 import android.app.FragmentManagerandroid.support.v4.app.FragmentManager 类不兼容

    只需检查在这种情况下您真正想使用哪个FragmentManager 类,您的问题就应该得到解决。谢谢。

    即根据您的决定选择:

    public ScreenSlidePagerAdapter(android.app.FragmentManager fm) {
            super(fm);
        }
    

    public ScreenSlidePagerAdapter(android.support.v4.app.FragmentManager fm) {
            super(fm);
        }
    

    并使用正确的类导入您的MainActivity 类。

    【讨论】:

      【解决方案4】:
        #For Full code
      
      package com.team.test;
      
          import android.content.Intent;
          import android.content.pm.ActivityInfo;
          import android.os.Bundle;
          import android.support.v4.app.FragmentActivity;
          import android.support.v4.app.FragmentStatePagerAdapter;
          import android.support.v4.app.NavUtils;
          import android.support.v4.view.PagerAdapter;
          import android.support.v4.view.ViewPager;
          import android.view.Menu;
          import android.view.MenuItem;
      
          /**
           * Demonstrates a "screen-slide" animation using a {@link ViewPager}. Because
           * {@link ViewPager} automatically plays such an animation when calling
           * {@link ViewPager#setCurrentItem(int)}, there isn't any animation-specific
           * code in this sample.
           * 
           * <p>
           * This sample shows a "next" button that advances the user to the next step in
           * a wizard, animating the current screen out (to the left) and the next screen
           * in (from the right). The reverse animation is played when the user presses
           * the "previous" button.
           * </p>
           * 
           * @see ScreenSlidePageFragment
           */
          public class MenuActivity extends FragmentActivity {
              /**
               * The number of pages (wizard steps) to show in this demo.
               */
              private static final int NUM_PAGES = 6;
      
              /**
               * The pager widget, which handles animation and allows swiping horizontally
               * to access previous and next wizard steps.
               */
              private ViewPager mPager;
      
              /**
               * The pager adapter, which provides the pages to the view pager widget.
               */
              private PagerAdapter mPagerAdapter;
      
              @Override
              protected void onCreate(Bundle savedInstanceState) {
                  super.onCreate(savedInstanceState);
                  setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
                  setContentView(R.layout.activity_screen_slide);
      
                  // Instantiate a ViewPager and a PagerAdapter.
                  mPager = (ViewPager) findViewById(R.id.pager);
                  mPagerAdapter = new ScreenSlidePagerAdapter(getSupportFragmentManager());
                  mPager.setAdapter(mPagerAdapter);
                  mPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
                      @Override
                      public void onPageSelected(int position) {
                          // When changing pages, reset the action bar actions since they
                          // are dependent
                          // on which page is currently active. An alternative approach is
                          // to have each
                          // fragment expose actions itself (rather than the activity
                          // exposing actions),
                          // but for simplicity, the activity provides the actions in this
                          // sample.
                          invalidateOptionsMenu();
                      }
                  });
              }
      
              @Override
              public boolean onCreateOptionsMenu(Menu menu) {
                  super.onCreateOptionsMenu(menu);
                  getMenuInflater().inflate(R.menu.activity_screen_slide, menu);
      
                  menu.findItem(R.id.action_previous).setEnabled(
                          mPager.getCurrentItem() > 0);
      
                  // Add either a "next" or "finish" button to the action bar, depending
                  // on which page
                  // is currently selected.
                  MenuItem item = menu
                          .add(Menu.NONE,
                                  R.id.action_next,
                                  Menu.NONE,
                                  (mPager.getCurrentItem() == mPagerAdapter.getCount() - 1) ? R.string.action_finish
                                          : R.string.action_next);
                  item.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM
                          | MenuItem.SHOW_AS_ACTION_WITH_TEXT);
                  return true;
              }
      
              @Override
              public boolean onOptionsItemSelected(MenuItem item) {
                  switch (item.getItemId()) {
                  case android.R.id.home:
                      // Navigate "up" the demo structure to the launchpad activity.
                      // See http://developer.android.com/design/patterns/navigation.html
                      // for more.
                      NavUtils.navigateUpTo(this, new Intent(this, Login.class));
                      return true;
      
                  case R.id.action_previous:
                      // Go to the previous step in the wizard. If there is no previous
                      // step,
                      // setCurrentItem will do nothing.
                      mPager.setCurrentItem(mPager.getCurrentItem() - 1);
                      return true;
      
                  case R.id.action_next:
                      // Advance to the next step in the wizard. If there is no next step,
                      // setCurrentItem
                      // will do nothing.
                      mPager.setCurrentItem(mPager.getCurrentItem() + 1);
                      return true;
                  }
      
                  return super.onOptionsItemSelected(item);
              }
      
              /**
               * A simple pager adapter that represents 5 {@link ScreenSlidePageFragment}
               * objects, in sequence.
               */
              public class ScreenSlidePagerAdapter extends FragmentStatePagerAdapter {
                  public ScreenSlidePagerAdapter(android.support.v4.app.FragmentManager fm) {
                      super(fm);
                  }
      
                  @Override
                  public android.support.v4.app.Fragment getItem(int position) {
                      return ScreenSlidePageFragment.create(position);
                  }
      
                  @Override
                  public int getCount() {
                      return NUM_PAGES;
                  }
              }
          }
      

      【讨论】:

        猜你喜欢
        • 2018-01-04
        • 1970-01-01
        • 1970-01-01
        • 2021-12-14
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多