Android的全屏显示图片滑块 [英] Android Displaying FullScreen Slider Images

查看:112
本文介绍了Android的全屏显示图片滑块的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有dispalyed的Andr​​oid屏幕上gridviewImages。
我的要求是,以滑动全屏照片

I have a gridviewImages dispalyed on Android screen. My Requirement is to Slide the FullScreen Images

下面我的code:

ImageAdapter:

public class ImageAdapter extends BaseAdapter {
   private Context mContext;

   // Constructor
   public ImageAdapter(Context c) {
      mContext = c;
   }

   public int getCount() {
      return mThumbIds.length;
   }

   public Object getItem(int position) {
      return null;
   }

   public long getItemId(int position) {
      return 0;
   }

   // create a new ImageView for each item referenced by the Adapter
   public View getView(int position, View convertView, ViewGroup parent) {
      ImageView imageView;
      if (convertView == null) {
      imageView = new ImageView(mContext);
      imageView.setLayoutParams(new GridView.LayoutParams(85, 85));
      imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
      imageView.setPadding(8, 8, 8, 8);
      } else {
      imageView = (ImageView) convertView;
      }

      imageView.setImageResource(mThumbIds[position]);
      return imageView;
   }

   // Keep all Images in array
   public Integer[] mThumbIds = {
      R.drawable.cn1, R.drawable.cn2,
      R.drawable.cn3, R.drawable.cn4,
      R.drawable.cn5, R.drawable.cn6,
      R.drawable.cn7, R.drawable.cn8,
      R.drawable.cn9, R.drawable.cn10,
      R.drawable.cn11, R.drawable.cn12

   };
}   

MainActivity:

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        GridView gridview = (GridView) findViewById(R.id.gridview);
          gridview.setAdapter(new ImageAdapter(this));
          gridview.setOnItemClickListener(new OnItemClickListener() {
              public void onItemClick(AdapterView<?> parent, View v,
                      int position, long id) {

                  // Send intent to SingleViewActivity
                  Intent i = 
                  new Intent(getApplicationContext(), SingleViewActivity.class);
                  // Pass image index
                  i.putExtra("id", position);
                  Log.d("onCreateMain>>","OnCreateMain");

                  startActivity(i);
              }
          });
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

}

SingleViewActivity:

public class SingleViewActivity extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.single_view);
        Log.d("onCreate>>","OnCreate");

        // Get intent data
        Intent i = getIntent();

        // Selected image id
        int position = i.getExtras().getInt("id");

        Log.d("Position>>>","Position"+position);
        ImageAdapter imageAdapter = new ImageAdapter(this);

        ImageView imageView = (ImageView) findViewById(R.id.SingleView);
        imageView.setImageResource(imageAdapter.mThumbIds[position]);
    }

}

布局的XML文件:

Layout XMl Files:

activity_main.xml中:

activity_main.xml:

<?xml version="1.0" encoding="utf-8"?>
<GridView xmlns:android="http://schemas.android.com/apk/res/android" 
   android:id="@+id/gridview"
   android:layout_width="fill_parent" 
   android:layout_height="fill_parent"
   android:columnWidth="90dp"
   android:numColumns="auto_fit"
   android:verticalSpacing="10dp"
   android:horizontalSpacing="10dp"
   android:stretchMode="columnWidth"
   android:gravity="center"
/>

single_view.xml:

single_view.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

   <ImageView android:id="@+id/SingleView"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"/>

</LinearLayout>

我的要求是,以滑动全屏图像,可以在任何一个可以帮助?

My Requirement is to Slide the FullScreen Images,Could any one help?

推荐答案

一个ViewPager会让你'滑'片段之间,而这正是你想达到的效果。只要打开你的当前SingleViewActivity成一个片段:

A ViewPager will let you 'slide' between fragments, which is exactly the effect you are trying to achieve. Just turn your current SingleViewActivity into a fragment:

public class SingleViewFragment extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        return inflater.inflate(R.layout.single_view, container, false);
    }

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

        int resource = getArguments().getInt("image");

        ImageView imageView = (ImageView) findViewById(R.id.SingleView);
        imageView.setImageResource(imageAdapter.mThumbIds[position]);
    }
}

您将需要一个PagerAdapter生成此片段需要。

You will need a PagerAdapter to generate this fragments as needed.

public class ImagesPagerAdapter extends FragmentPagerAdapter{

    public Integer[] mThumbIds = {
        R.drawable.cn1, R.drawable.cn2,
        R.drawable.cn3, R.drawable.cn4,
        R.drawable.cn5, R.drawable.cn6,
        R.drawable.cn7, R.drawable.cn8,
        R.drawable.cn9, R.drawable.cn10,
        R.drawable.cn11, R.drawable.cn12
    };

    @Override
    public Fragment getItem(int i) {
        Bundle args = new Bundle();
        args.putInt("image", mThumbIds[i]);

        SingleViewFragment fragment = new SingleViewFragment();
        fragment.setArguments(args);

        return fragment;
    }

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

然后你需要包含单个ViewPager,设置它的适配器ImagesPagerAdapter的一个实例的活动,并给它在开始的位置。

Then you will need an activity that contains a single ViewPager, set as its adapter an instance of the ImagesPagerAdapter, and give it a position in which to start.

public class SingleViewActivity extends Activity {

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

        // Selected image id
        int position = getIntent().getIntExtra("id", 0);

        ViewPager pager = (ViewPager) findViewById(R.id.pager);
        pager.setAdapter(new ImagesPagerAdapter(this));
        pager.setCurrentItem(position);
    }
}

在哪里activiy_pager只是包含你所需要的ViewPager布局。

Where activiy_pager is just a layout containing the ViewPager you need.

<ViewPager xmlns:android="http://schemas.android.com/apk/res/android"
       android:id="@+id/pager"
       android:layout_width="match_parent"
       android:layout_height="match_parent"/>

这篇关于Android的全屏显示图片滑块的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆