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