Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/visual-studio-2008/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android-使用pageradapter,我想让第一张图像显示屏幕的1/4,然后让它自然滚动_Android_Image Gallery_Android Pageradapter - Fatal编程技术网

Android-使用pageradapter,我想让第一张图像显示屏幕的1/4,然后让它自然滚动

Android-使用pageradapter,我想让第一张图像显示屏幕的1/4,然后让它自然滚动,android,image-gallery,android-pageradapter,Android,Image Gallery,Android Pageradapter,我的目标是创造这个 主要的问题是,当我滚动图像时,我无法使第一个位置的图像保持在1/4(或任何大小),它将占据整个屏幕的宽度,然后作为一个正常的分页器 我试过以下方法 Objectanimator.offload 摆弄边距、填充物等 找到为第一个图像设置边界的任何方法 设置空imageview以将视图推到一边,这似乎是最可行的,尽管我必须调用notifyDataSetChanged() 当我在适配器内更改数据时,我调用notifyDataSetChanged();我们都知道,它会在不进行任

我的目标是创造这个

主要的问题是,当我滚动图像时,我无法使第一个位置的图像保持在1/4(或任何大小),它将占据整个屏幕的宽度,然后作为一个正常的分页器

我试过以下方法

  • Objectanimator.offload
  • 摆弄边距、填充物等
  • 找到为第一个图像设置边界的任何方法
  • 设置空imageview以将视图推到一边,这似乎是最可行的,尽管我必须调用notifyDataSetChanged()
当我在适配器内更改数据时,我调用notifyDataSetChanged();我们都知道,它会在不进行任何平滑转换的情况下更新视图

我觉得这应该有一个简单而干净的解决方案,只要我知道如何为第一个图像设置边界。也许我错了

这是我正在使用的代码 我已经创建了一个自定义图库小部件


公共类ImageGalleryViewPager扩展了ViewPager{
公共图像GalleryViewPager(上下文){
超级(上下文);
setMyScroller();
}
公共ImageGalleryViewPager(上下文、属性集属性){
超级(上下文,attrs);
setMyScroller();
}
//下一个是为了平滑滚动而添加的
私有void setMyScroller(){
试一试{
Class viewpager=viewpager.Class;
字段滚动器=viewpager.getDeclaredField(“mScroller”);
scroller.setAccessible(true);
set(这是新的ImageGalleryViewPager.MyScroller(getContext());
}捕获(例外e){
e、 printStackTrace();
}
}
@凌驾
公共无效设置适配器(PagerAdapter适配器){
super.setAdapter(适配器);
setCurrentItem(adapter.getCount());
}
公共类MyScroller扩展了Scroller{
公共MyScroller(上下文){
super(上下文,新减速器插值器());
}
@凌驾
公共无效开始滚动(int startX、int startY、int dx、int dy、int duration){
超级startScroll(startX,startY,dx,dy,350/*1秒*/);
}
}
@凌驾
公共布尔值onInterceptTouchEvent(MotionEvent ev){
返回超级onInterceptTouchEvent(ev);
}
}
我在Cardview中使用它

    <com.apirix.inspection.views.viewpagers.ImageGalleryViewPager
        android:id="@+id/image_gallery_vp"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
</android.support.v7.widget.CardView></RelativeLayout>

这是我的寻呼机

public AssignmentListGalleryAdapter(Context context, List<Media> medias, ViewPager horizontalView) {
    mContext = context;
    mMedias = medias;
    mHorizontalView = horizontalView;
}

@Override
public Object instantiateItem(ViewGroup container, int position) {

    LayoutInflater inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    mItemView = inflater.inflate(R.layout.row_image_gallery_viewpager, container, false);
    ButterKnife.bind(this, mItemView);


    mUri = mMedias.get(position).getUrl();
    closeAllImagesButton.add(mCloseButton);
    mContainer = container;

    container.setClipToPadding(false);
    container.setPadding(30, 0, 60, 0);

    if (!mUri.isEmpty()) {
        Picasso.with(mContext)
                .load(mUri)
                .fit()
                .into(mFullScreenImageView);
    }

    mCloseButton.setOnClickListener(this);
    container.addView(mItemView);
    return mItemView;

}

public int getItemPosition(Object object) {
    return POSITION_NONE;
}
public AssignmentListGalleryAdapter(上下文上下文、列表媒体、ViewPager horizontalView){
mContext=上下文;
媒体;
mHorizontalView=水平视图;
}
@凌驾
公共对象实例化项(视图组容器,int位置){
LayoutInflater充气器=(LayoutInflater)mContext.getSystemService(Context.LAYOUT\u充气器\u服务);
mItemView=充气机。充气(R.layout.row\u image\u gallery\u viewpager,container,false);
巴特刀。绑定(这个,mItemView);
mUri=mMedias.get(position.getUrl();
关闭图像按钮。添加(mCloseButton);
mContainer=容器;
container.setCliptoppadding(false);
容器。设置填充(30,0,60,0);
如果(!mUri.isEmpty()){
毕加索(McContext)
.负载(mUri)
.fit()
.进入(mFullScreenImageView);
}
mCloseButton.setOnClickListener(此);
container.addView(mItemView);
返回mItemView;
}
public int getItemPosition(对象){
返回位置\无;
}

我认为您可以通过在cardView中添加填充物来实现所需的功能,但仅限于适配器的第一个元素

因此,您将有两个卡片视图:

row\u image\u gallery\u viewpager\u first.xml

    <com.apirix.inspection.views.viewpagers.ImageGalleryViewPager
    android:id="@+id/image_gallery_vp"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingEnd="100dp"/>
<com.apirix.inspection.views.viewpagers.ImageGalleryViewPager
        android:id="@+id/image_gallery_vp"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
</android.support.v7.widget.CardView></RelativeLayout>

希望这能起作用。

我认为您可以通过在cardView中添加填充物来实现所需的功能,但仅限于适配器的第一个元素

因此,您将有两个卡片视图:

row\u image\u gallery\u viewpager\u first.xml

    <com.apirix.inspection.views.viewpagers.ImageGalleryViewPager
    android:id="@+id/image_gallery_vp"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingEnd="100dp"/>
<com.apirix.inspection.views.viewpagers.ImageGalleryViewPager
        android:id="@+id/image_gallery_vp"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
</android.support.v7.widget.CardView></RelativeLayout>

希望这能奏效。

太棒了!现在,当我第一次滑动时,我希望图像适合pageradapter,再次查看提供的Gif Mhh您的意思是您的第二个项目不适合屏幕?在初始滑动时,pageradapter应将第一个图像扩展到容器的全宽。所以我向左滑动一次,图像展开,我再次向左滑动,得到图像2。小1->大1->图像2希望我能说清楚。是的,我现在明白了,这要复杂得多,但也有可能。事实上,我认为你需要通过带有滑动手势检测器的touchlistener捕捉第一次滑动。在卡片视图上应用调整大小动画,使其扩展为全尺寸。然后让nexts滑动在适配器上正常运行。我不知道我是否清楚?太棒了!现在,当我第一次滑动时,我希望图像适合pageradapter,再次查看提供的Gif Mhh您的意思是您的第二个项目不适合屏幕?在初始滑动时,pageradapter应将第一个图像扩展到容器的全宽。所以我向左滑动一次,图像展开,我再次向左滑动,得到图像2。小1->大1->图像2希望我能说清楚。是的,我现在明白了,这要复杂得多,但也有可能。事实上,我认为你需要通过带有滑动手势检测器的touchlistener捕捉第一次滑动。在卡片视图上应用调整大小动画,使其扩展为全尺寸。然后让nexts滑动在适配器上正常运行。我不知道我是否清楚?