Description
Custom ViewPager that allows to block swiping right or left where the ViewPager child fragments set the scroll direction and handle blocked swipe events. The library also comes with an adapter that can handle different view pages views and can control the view pager scrolling from within view pager pages.
SwipeDirectionViewPager alternatives and similar packages
Based on the "Kotlin" category.
Alternatively, view SwipeDirectionViewPager alternatives based on common mentions on social networks and blogs.
-
android-youtube-player
YouTube Player library for Android and Chromecast, stable and customizable. -
CalendarView
A highly customizable calendar view and compose library for Android. -
Balloon
:balloon: Modernized and sophisticated tooltips, fully customizable with an arrow and animations for Android. -
Kotterknife
Android view injection writen in Kotlin based on ButterKnife -
Shortbread
Android library that creates app shortcuts from annotations -
kotlin-android-template
Android + Kotlin + Github Actions + ktlint + Detekt + Gradle Kotlin DSL + buildSrc = โค๏ธ -
NotyKT ๐๏ธ
๐ NotyKT is a complete ๐Kotlin-stack (Backend + Android) ๐ฑ application built to demonstrate the use of Modern development tools with best practices implementation๐ฆธ. -
Material Chip View
Material Chip view. Can be used as tags for categories, contacts or creating text clouds -
DrawableToolbox
๐ ๏ธ The missing drawable toolbox for Android. Create drawables programmatically and get rid of the boring and always repeated drawable.xml files. -
Navigation Toolbar for Android
:octocat: Navigation toolbar is a slide-modeled UI navigation controller made by @Ramotion -
CodeView
Display code with syntax highlighting :sparkles: in native way. -
Time
Type-safe time calculations in Kotlin, powered by generics. -
Carousel Recyclerview
Carousel Recyclerview let's you create carousel layout with the power of recyclerview by creating custom layout manager. -
Pluto Debug Framework
Pluto is a on-device debugging framework for Android applications, which helps in inspection of HTTP requests/responses, capture Crashes and ANRs and manipulating application data on-the-go. -
Yasha
A DSL library for rendering RecyclerView and ViewPager. -
CrunchyCalendar โ awesome calendar widget for android apps
A beautiful material calendar with endless scroll, range selection and a lot more! -
sliding-panel
Android sliding panel that is part of the view hierarchy, not above it. -
Android Kotlin Samples
Some basic samples of Kotlin for Android -
MaterialTimelineView
With MaterialTimelineView you can easily create a material looking timeline. -
Pdf Viewer For Android
A Lightweight PDF Viewer Android library which only occupies around 125kb while most of the Pdf viewer occupies up to 16MB space. -
MaterialDrawerKt
A Kotlin DSL wrapper around the mikepenz/MaterialDrawer library. -
Capturable
๐Jetpack Compose utility library for capturing Composable content and transforming it into Bitmap Image๐ผ๏ธ -
Transition X
{ } Declarative Kotlin DSL for choreographing Android transitions -
Only
:bouquet: An easy way to persist and run code block only as many times as necessary on Android. -
SSComposeCookBook
A Collection of major Jetpack compose UI components which are commonly used.๐๐๐ -
Swagger Gradle Codegen
๐ซ A Gradle Plugin to generate your networking code from Swagger -
SSCustomBottomNavigation
Animated TabBar with native control and Jetpack Navigation support..โจ๐๐ -
EasyPermissions-ktx
๐ Kotlin version of the popular google/easypermissions wrapper library to simplify basic system permissions logic on Android M or higher. -
Awesome Jetpack compose
A collaborative list of awesome jetpack compose resources. -
DeviceInfo-Sample
[Android Library] Get easy access to device information super fast, real quick -
Permission Flow for Android
Know about real-time state of a Android app Permissions with Kotlin Flow APIs. -
CameraViewEx
Easy Android camera integration, advanced features. -
Aimybox voice assistant
Embeddable custom voice assistant for Android applications -
Nextflix-Composable
Includes jetpack compose, navigation, paging, hilt, retrofit, coil, coroutines, flow.. -
Intro Showcase View
Highlight different features of the app using Jetpack Compose -
Events Calendar
Events Calendar is a user-friendly library that helps you achieve a cool Calendar UI with events mapping. You can customise every pixel of the calendar as per your wish and still achieve in implementing all the functionalities of the native android calendar in addition with adding dots to the calendar which represents the presence of an event on the respective dates. It can be done easily, you are just a few steps away from implementing your own badass looking Calendar for your very own project! -
ZoomHelper
ZoomHelper will make any view to be zoomable just like Instagram pinch-to-zoom -
SSCustomEditTextOutLineBorder
Same as the Outlined text fields presented on the Material Design page but with some dynamic changes. ๐ ๐ -
Maildroid
Maildroid is a small robust android library for sending emails using SMTP server -
Turtle ๐ข
Run shell commands from a Kotlin script or application with ease -
Vanilla Place Picker
Simple(vanilla) yet 'Do it all' place picker for your place picking needs in Android -
Mutekt
Simplify mutating "immutable" state models (a Kotlin multiplatform library) -
TimelineView
A customizable and easy-to-use Timeline View library for Android. Works as a RecyclerView decorator (ItemDecoration) -
Crowdin Android SDK
Crowdin Android SDK delivers all new translations from Crowdin project to the application immediately -
Compose Compiler Reports to HTML Generator
A utility (Gradle Plugin + CLI) to convert Jetpack Compose compiler metrics and reports to beautified HTML page.
Appwrite - The Open Source Firebase alternative introduces iOS support
Do you think we are missing an alternative of SwipeDirectionViewPager or a related project?
README
SwipeDirectionViewPager

Introduction
Custom ViewPager that allows to block swiping right or left where the ViewPager child fragments set the scroll direction and handle blocked swipe events. The library also comes with an adapter that can handle different view pages views and can control the view pager scrolling from within view pager pages.
How to install
repositories {
maven {
url "https://jitpack.io"
}
}
dependencies {
implementation 'com.github.kibotu:SwipeDirectionViewPager:-SNAPSHOT'
}
How to use
Basic Setup
1 Create adapter
// use Fragment#childFragmentManager in nested fragments
var adapter: ViewPagerPresenterAdapter<PageModel, ViewPagerModel> = ViewPagerPresenterAdapter(supportFragmentManager)
2 add to view pager
viewPager.adapter = adapter
3 add listeners
adapter.swipeLeftEdgeListener = Runnable {
snackbar(this, "has swiped left on first page")
}
adapter.swipeRightEdgeListener = Runnable {
snackbar(this, "has swiped right on last page")
}
4 add view pager fragments
(0 until 5).forEach {
adapter.append(PageModel(text = "Page $it")) { TextPage() }
adapter.append(PageModel(imageUrl = createRandomImageUrl())) { ImagePage() }
}
// don't forget to notify updates
adapter.notifyDataSetChanged()
5 implement ViewPagerPresenterAdapter.ViewPagerPresenter interface in your view pager fragments, e.g.:
class Page : Fragment(), ViewPagerPresenterAdapter.ViewPagerPresenter<PageModel, ViewPagerModel> {
/**
* into pages injected adapter
*/
override var viewPagerPresenterAdapter: ViewPagerPresenterAdapter<PageModel, ViewPagerModel>? = null
/**
* gets called when allowSwipeDirection is set and user scrolls to the previous or next page.
* basically, you set 'only swipe left' and when user swipes right, you can give the user feedback
*/
override fun onSwipeIntercepted(direction: SwipeDirection){
}
/**
* set page specific swipe allowed direction
*/
override fun allowSwipeDirection(): SwipeDirection {
return SwipeDirection.ALL
}
}
Inserting fragments
Adding a new page to the end
adapter.append(PageModel(text = "Page $it")) { TextPage() }
Adding a new page to the beginning
adapter.prepend(PageModel(text = "Page $it")) { TextPage() }
Getting fragments
var fragment = viewPagerPresenterAdapter?.getFragment(adapterPosition); // don't use #getItemPosition, it interferes with fragment updates
Getting models
using adapter position
var model = viewPagerPresenterAdapter?.model(adapterPosition);
using a fragment
var model = viewPagerPresenterAdapter?.model(fragment);
Getting adapter position
Note: neither models nor fragments are unique, it's returning simply the first one found
using a fragment
var position = viewPagerPresenterAdapter?.indexOf(fragment);
using a model
var position = viewPagerPresenterAdapter?.indexOf(model);
Update fragments
ViewPager fragments need to inherit form [Updatable]. the #update(t: T) gets called in order to update fragments without the need to recreate them. (which would be the case using #notifyDataSetChanged)
replace model at given position
viewPagerPresenterAdapter?.update(PageModel(text = "updated model at position 0"), 0)
replacing a model at given criteria
viewPagerPresenterAdapter?.update(PageModel(text = "update replaced model by filter"), { it.text == "Page 2" })
modifying model data in place
viewPagerPresenterAdapter?.updateInPlace(filter = { it.text == "Page 3" }, modify = { it.text = "updated model in place by filter" })
Misc
PageModel - can be any data model, which can be bound to view pager page and can be accessed inside pages.
var model : PageModel = viewPagerPresenterAdapter?.model(fragment)
// or
var model : PageModel = viewPagerPresenterAdapter?.model(adapterPosition)
ViewPagerModel - meant to be a shared object between all pages and its parent view pager holder
var viewPagerModel : ViewPagerModel = viewPagerPresenterAdapter?.viewPagerModel
ScrollHandler
Allows view pager pages to control view pager scrolls.
viewPagerPresenterAdapter.scrollHandler
/**
* Skips a given amount of pages.
*/
fun skip(amount: Int, smooth: Boolean = true)
/**
* Scrolls to a given position.
*/
fun scrollTo(position: Int, smooth: Boolean = true)
/**
* Scrolls to next page.
*/
fun scrollToNextPage()
/**
* Scrolls to previous page.
*/
fun scrollToPreviousPage()
/**
* @return true if current page is first.
*/
fun isFirstPage(): Boolean
/**
* @return true if current page is last.
*/
fun isLastPage(): Boolean
RTL Support by using
net.kibotu.swipedirectionviewpager.SwipeDirectionViewPagerRtl, which uses duolingo's RtlViewPager
implementation "com.android.support:support-core-ui:$support_version"
implementation 'com.duolingo.open:rtl-viewpager:1.0.3'
How to build
graldew clean build
CI
gradlew clean assembleRelease test javadoc
Build Requirements
- JDK8
- Android Build Tools 27.0.2
- Android SDK 27
Contributors
- [Jan Rabe]([email protected])
License
Copyright 2018 Jan Rabe
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
*Note that all licence references and agreements mentioned in the SwipeDirectionViewPager README section above
are relevant to that project's source code only.