使用默认的android图像查看器来显示图片

时间:2017-09-20 09:55:17

标签: android android-intent android-imageview android-gallery

我知道我可以使用默认的Android图像查看器打开图像,例如使用new Intent(Intent.ACTION_VIEW)等。

如果我打开图像然后向左/向右滑动,我会看到设备上保存的其他图像。

例如,如果我打开其中一个whatsapp图像,向左/向右滑动我会看到保存在whatsapp文件夹中的所有其他图像。

有没有办法将默认的Android图片查看器传递给uri List / Array,以防止用户左/右滑动并查看设备上的所有图片?

我希望用户向左/向右滑动,只看到我允许他看的图像。

提前谢谢

2 个答案:

答案 0 :(得分:2)

最佳方案是您可以将viewpager与图像数组或图像列表一起使用,您可以获得向左或向右滑动的功能,您只需要执行viewpager并创建一个适配器在调用getItem事件时获取图像,

答案 1 :(得分:2)

尝试此操作即可使用 android.support.v4.view.ViewPager

  

布局管理器,允许用户左右翻页数据。您提供PagerAdapter的实现来生成视图显示的页面。

<android.support.v4.view.ViewPager
    android:id="@+id/viewPager"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

</android.support.v4.view.ViewPager>

演示代码

ViewPager viewPager;
ArrayList<String> imageArray;
imageArray = new ArrayList<>();
viewPager = findViewById(R.id.cspl_viewPager);
imageArray.add(R.drawable.bg);
imageArray.add(R.drawable.bg);
imageArray.add(R.drawable.bg);
imageArray.add(R.drawable.bg);
imageArray.add(R.drawable.bg);
imageArray.add(R.drawable.bg);
ImageAdapter adapter = new ImageAdapter(this, imageArray);
viewPager.setAdapter(adapter);

现在像这样创建ImageAdapter

    public class ImageAdapter extends PagerAdapter {

        Context context;
        ArrayList<String> imageArray;

        public ImageAdapter(Context context, ArrayList<String> imageArray) {
            this.context = context;
            this.imageArray = imageArray;
        }

        @Override
        public int getCount() {
            return imageArray.size();
        }

        @Override
        public boolean isViewFromObject(View view, Object object) {
            return view == ((ImageView) object);
        }

        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            ImageView imageView = new ImageView(context);

            LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(WindowManager.LayoutParams.WRAP_CONTENT, 50);
            imageView.setLayoutParams(layoutParams);

            int padding = context.getResources().getDimensionPixelSize(R.dimen.font_size_10);
            imageView.setPadding(padding, padding, padding, padding);

//            imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);

            Glide.with(ProfileActivity.this)
                    .load(R.drawable.bg)
                    .into(imageView);


            ((ViewPager) container).addView(imageView, 0);

            return imageView;

        }

        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            ((ViewPager) container).removeView((ImageView) object);
        }
    }