0

我想使用抽屉菜单在我的 Sherlock 片段中实现滑动视图。我做到了,它似乎工作正常,但是,有一个小问题我无法弄清楚。

所以让我们从我的一些代码开始:

主要活动

public class MainActivity extends SherlockFragmentActivity {

    // Declare Variable
    DrawerLayout mDrawerLayout;
    ListView mDrawerList;
    ActionBarDrawerToggle mDrawerToggle;
    MenuListAdapter mMenuAdapter;
    String[] title;
    String[] subtitle;
    int[] icon;
    Fragment fragment1 = new TestFragment();

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.drawer_main);

        // Generate title
        title = new String[] { "Test title" };

        // Generate subtitle
        subtitle = new String[] { "Test subtitle" };

        // Generate icon
        icon = new int[] { R.drawable.action_about };

        // Locate DrawerLayout in drawer_main.xml
        mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);

        // Locate ListView in drawer_main.xml
        mDrawerList = (ListView) findViewById(R.id.left_drawer);

        // Set a custom shadow that overlays the main content when the drawer
        // opens
        mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow,
                GravityCompat.START);

        // Pass results to MenuListAdapter Class
        mMenuAdapter = new MenuListAdapter(this, title, subtitle, icon);

        // Set the MenuListAdapter to the ListView
        mDrawerList.setAdapter(mMenuAdapter);

        // Capture button clicks on side menu
        mDrawerList.setOnItemClickListener(new DrawerItemClickListener());

        // Enable ActionBar app icon to behave as action to toggle nav drawer
        getSupportActionBar().setHomeButtonEnabled(true);
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);

        // ActionBarDrawerToggle ties together the the proper interactions
        // between the sliding drawer and the action bar app icon
        mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout,
                R.drawable.ic_drawer, R.string.drawer_open,
                R.string.drawer_close) {

            public void onDrawerClosed(View view) {
                // TODO Auto-generated method stub
                super.onDrawerClosed(view);
            }

            public void onDrawerOpened(View drawerView) {
                // TODO Auto-generated method stub
                super.onDrawerOpened(drawerView);
            }
        };

        mDrawerLayout.setDrawerListener(mDrawerToggle);

        if (savedInstanceState == null) {
            selectItem(0);
        }
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getSupportMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {

        if (item.getItemId() == android.R.id.home) {

            if (mDrawerLayout.isDrawerOpen(mDrawerList)) {
                mDrawerLayout.closeDrawer(mDrawerList);
            } else {
                mDrawerLayout.openDrawer(mDrawerList);
            }
        }

        return super.onOptionsItemSelected(item);
    }

    // The click listener for ListView in the navigation drawer
    private class DrawerItemClickListener implements
            ListView.OnItemClickListener {
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position,
                long id) {
            selectItem(position);
        }
    }

    private void selectItem(int position) {

        FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
        // Locate Position
        switch (position) {
        case 0:
            ft.replace(R.id.content_frame, fragment1);
            break;
        ft.commit();
        mDrawerList.setItemChecked(position, true);
        // Close drawer
        mDrawerLayout.closeDrawer(mDrawerList);
    }

    @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        // Sync the toggle state after onRestoreInstanceState has occurred.
        mDrawerToggle.syncState();
    }

    @Override
    public void onConfigurationChanged(Configuration newConfig) {
        super.onConfigurationChanged(newConfig);
        // Pass any configuration change to the drawer toggles
        mDrawerToggle.onConfigurationChanged(newConfig);
    }
}

测试片段:

public class TestFragment extends SherlockFragment {

    ViewPager mViewPager;

    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View rootView = inflater.inflate(R.layout.test, container, false);

        mViewPager = (ViewPager) rootView.findViewById(R.id.viewpager);
        PagerTabStrip pagerTabStrip = (PagerTabStrip) rootView.findViewById(R.id.pagerTabStrip);

        testAdapter titleAdapter = new testAdapter(getFragmentManager());
        mViewPager.setAdapter(titleAdapter);
        mViewPager.setCurrentItem(0);

        return rootView;
    }

}

测试适配器

public class testAdapter extends FragmentPagerAdapter {
    private String titles[] = new String[]{"View1","View2"};
    private Fragment frags[] = new Fragment[titles.length];

public systemAdapter(FragmentManager fm) {
    super(fm);
    frags[0] = new testSwipe1();
    frags[1] = new testSwipe2();
}

@Override
public CharSequence getPageTitle (int position){
    Log.v("TitleAdapter - getPageTitle=", titles[position]);
    return titles[position];
}

@Override
public Fragment getItem(int position) {
    Log.v("TitleAdapter - getItem=", String.valueOf(position));
    return frags[position];
}

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

testSwipe1 和 testSwipe2 是一样的:

public class testSwipe1 extends SherlockFragment {

    public View onCreateView(LayoutInflater inflater, ViewGroup container,          Bundle savedInstanceState) {        View rootView = inflater.inflate(R.layout.testswipe_layout, container, false);

        ImageButton testImage = (ImageButton) rootView.findViewById(R.id.test);

        //todo function image

        return rootView; 
}

}

好的,抽屉工作正常,如果我点击“测试标题”,它会通过滑动使布局膨胀,我可以在 2 个测试滑动视图中看到图像。但是,如果我打开抽屉并再次点击“测试标题”,我可以在我的滑动片段布局上看到没有图像的滑动视图。如果我将设备置于横向并返回纵向,我的滑动片段上的图像就会回来!打开抽屉->再次点击测试标题->图像消失....->景观设计师->纵向->图像返回。

定义的布局是抽屉和滑动视图的标准。在 swipeviews 片段布局内只有一个图像视图。所以问题必须在java部分,但我不知道在哪里。有什么帮助吗?

4

2 回答 2

0

试试这个:TestAdapter 应该实现 FragmentStatePagerAdapter 而不是 FragmentsPagerAdapter。原因是方法 getItem() 的调用方式不同。我有同样的问题。希望这可以帮助。

于 2013-07-22T20:11:12.573 回答
0

我已经编辑了这里给出的代码。

我只是通过使用它的方法asyDrawerLayout.java实现OnGestureListener接口来更改文件。

onCreate()我通过添加以下行将手势设置为当前上下文。

gd = new GestureDetector(this, this);

然后我覆盖onTouchEvent()如下

@Override
public boolean onTouchEvent(MotionEvent event) {
    // TODO Auto-generated method stub
    //Registering TouchEvent with GestureDetector
    return gd.onTouchEvent(event);
}

然后我改变了onFling()如下

@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
        float velocityY) {
    //Defining Sensitivity
    float sensitivity = 30;
    //Swipe Left Check
    if(e1.getX() - e2.getX() > sensitivity && mOpen){
        closeDrawer();
        return true;
    }
    //Swipe Right Check
    if(e2.getX() - e1.getX() > sensitivity && !mOpen){
        openDrawer();
        return true;
    }
    return true;
}

现在它正在使用抽屉菜单+ swipeView。

你可以从这里下载我编辑的版本。

于 2013-09-21T17:18:20.297 回答