티스토리 뷰
반응형
SMALL
public class CarouselEffectTransformer implements ViewPager.PageTransformer {
private int maxTranslateOffsetX;
private ViewPager viewPager;
public CarouselEffectTransformer(Context context) {
this.maxTranslateOffsetX = dp2px(context, 180);
}
public void transformPage(View view, float position) {
if (viewPager == null) {
viewPager = (ViewPager) view.getParent();
}
int leftInScreen = view.getLeft() - viewPager.getScrollX();
int centerXInViewPager = leftInScreen + view.getMeasuredWidth() / 2;
int offsetX = centerXInViewPager - viewPager.getMeasuredWidth() / 2;
float offsetRate = (float) offsetX * 0.16f / viewPager.getMeasuredWidth();
float scaleFactor = 1 - Math.abs(offsetRate);
if (scaleFactor > 0) {
view.setScaleX(scaleFactor);
view.setScaleY(scaleFactor);
view.setTranslationX(-maxTranslateOffsetX * offsetRate);
//ViewCompat.setElevation(view, 0.0f);
}
ViewCompat.setElevation(view, scaleFactor);
}
/**
* Dp to pixel conversion
*/
private int dp2px(Context context, float dipValue) {
float m = context.getResources().getDisplayMetrics().density;
return (int) (dipValue * m + 0.5f);
}
}
반응형
viewPager.setPadding(padding, 0, padding, 0); // ViewPager Child Item 기준으로 양쪽 패딩을 줌으로써 양쪽 이미지가 padding 에 따라 보여진다.
viewPager.setPageMargin((int) dpToPx(20)); // ViewPager Child Item 간의 Margin 값.
viewPager.setPageTransformer(false, new CarouselEffectTransformer(this)); // Set pageTransformer
Carousel Effect 는 ViewPager가 양쪽에 미리 보여지는 상태에서 해야 이쁘게 작동한드아 ..
좋은 커스텀 코드를 얻음.
Sample Example Github
반응형
LIST
'Android > ViewPager' 카테고리의 다른 글
[ ViewPager #6 ] Dot Indicator ( Simple ver ) (0) | 2024.02.28 |
---|---|
[ ViewPager #4 ] Auto Scroll & Slow Scroll (0) | 2020.03.26 |
[ ViewPager #3 ] FragmentPagerAdapter vs FragmentStatePagerAdapter (0) | 2020.03.25 |
[ ViewPager #2 ] WrapContent ViewPager (0) | 2019.12.17 |
댓글
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- widget onreceive
- Fragment data
- Android Wear Os
- RandomColor
- 맥 전용
- 갤럭시 워치
- 프래그먼트 데이터 저장
- Android
- android widget 만들기
- widget glide
- 역시 키크론이네
- 쏘렌토 하이브리드
- 쏘렌토 하이브리드 시그니처
- 폴더블 상태 유지
- widget onupdate
- 폰과 워치 페어링
- 폴더블 이벤트 받기
- aos img url bitmap
- wear os
- widget 만들기
- 랜덤컬러
- 가중치랜덤
- flutter web
- 웨어러블
- 안드로이드 폴드 대응
- Foldable Event
- 안드로이드 플립 대응
- widget 이미지 로딩
- 풀배열 키보드
- Dot indicator
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
글 보관함