Thumbnail Bar Modes
Toggle between thumbnail bar modes: Floating, Pinned, Scrollable, and None.
/* * Copyright © 2017-2026 PSPDFKit GmbH. All rights reserved. * * The PSPDFKit Sample applications are licensed with a modified BSD license. * Please see License for details. This notice may not be removed from this file. */
package com.pspdfkit.catalog.examples.kotlin
import android.content.Contextimport android.net.Uriimport android.os.Bundleimport android.view.Menuimport android.view.MenuItemimport com.pspdfkit.catalog.Rimport com.pspdfkit.catalog.SdkExampleimport com.pspdfkit.catalog.tasks.ExtractAssetTaskimport com.pspdfkit.configuration.activity.PdfActivityConfigurationimport com.pspdfkit.configuration.activity.ThumbnailBarModeimport com.pspdfkit.listeners.scrolling.ScrollStateimport com.pspdfkit.ui.PdfActivityimport com.pspdfkit.ui.PdfActivityIntentBuilderimport com.pspdfkit.ui.PdfThumbnailBarimport com.pspdfkit.utils.PdfLog
/** * This example demonstrates different thumbnail bar modes available in the SDK. * It allows toggling between Floating, Pinned, Scrollable, and None modes via the options menu. */class ThumbnailBarExample(context: Context) : SdkExample( context, R.string.thumbnailBarExampleTitle, R.string.thumbnailBarExampleDescription, ) { override fun launchExample(context: Context, configuration: PdfActivityConfiguration.Builder) { // Start with floating thumbnail bar mode (default) configuration.setThumbnailBarMode(ThumbnailBarMode.THUMBNAIL_BAR_MODE_FLOATING)
ExtractAssetTask.extract(WELCOME_DOC, title, context) { documentFile -> val intent = PdfActivityIntentBuilder.fromUri(context, Uri.fromFile(documentFile)) .configuration(configuration.build()) .activityClass(ThumbnailBarExampleActivity::class) .build()
context.startActivity(intent) } }}
/** * Activity that demonstrates switching between different thumbnail bar modes. */class ThumbnailBarExampleActivity : PdfActivity() {
companion object { private const val KEY_THUMBNAIL_BAR_MODE = "thumbnail_bar_mode" private const val KEY_THUMBNAIL_BAR_TAG = "thumbnail_bar" }
private var currentMode = ThumbnailBarMode.THUMBNAIL_BAR_MODE_FLOATING private val onScrollListener: PdfThumbnailBar.OnScrollListener = object : PdfThumbnailBar.OnScrollListener() { override fun onScroll(firstVisiblePage: Int, firstVisibleOffsetPx: Int) { super.onScroll(firstVisiblePage, firstVisibleOffsetPx) PdfLog.i(KEY_THUMBNAIL_BAR_TAG, "firstVisiblePage $firstVisiblePage firstVisibleOffsetPx $firstVisibleOffsetPx") }
override fun onScrollStateChanged(newState: ScrollState) { super.onScrollStateChanged(newState) PdfLog.i(KEY_THUMBNAIL_BAR_TAG, "ScrollState $newState") } }
override fun onCreateOptionsMenu(menu: Menu): Boolean { super.onCreateOptionsMenu(menu) menuInflater.inflate(R.menu.thumbnail_bar_modes_menu, menu) return true }
override fun onPrepareOptionsMenu(menu: Menu): Boolean { // Update checked state based on current mode menu.findItem(R.id.thumbnail_bar_mode_floating)?.isChecked = currentMode == ThumbnailBarMode.THUMBNAIL_BAR_MODE_FLOATING menu.findItem(R.id.thumbnail_bar_mode_pinned)?.isChecked = currentMode == ThumbnailBarMode.THUMBNAIL_BAR_MODE_PINNED menu.findItem(R.id.thumbnail_bar_mode_scrollable)?.isChecked = currentMode == ThumbnailBarMode.THUMBNAIL_BAR_MODE_SCROLLABLE menu.findItem(R.id.thumbnail_bar_mode_none)?.isChecked = currentMode == ThumbnailBarMode.THUMBNAIL_BAR_MODE_NONE return super.onPrepareOptionsMenu(menu) }
override fun onSaveInstanceState(outState: Bundle) { super.onSaveInstanceState(outState) outState.putString(KEY_THUMBNAIL_BAR_MODE, currentMode.name) }
override fun onRestoreInstanceState(savedInstanceState: Bundle) { super.onRestoreInstanceState(savedInstanceState) currentMode = savedInstanceState.getString(KEY_THUMBNAIL_BAR_MODE) ?.let { ThumbnailBarMode.valueOf(it) } ?: ThumbnailBarMode.THUMBNAIL_BAR_MODE_FLOATING pspdfKitViews.thumbnailBarView?.setThumbnailBarMode(currentMode) invalidateOptionsMenu() }
override fun onOptionsItemSelected(item: MenuItem): Boolean { val bar = pspdfKitViews.thumbnailBarView val newMode = when (item.itemId) { R.id.thumbnail_bar_mode_floating -> ThumbnailBarMode.THUMBNAIL_BAR_MODE_FLOATING R.id.thumbnail_bar_mode_pinned -> ThumbnailBarMode.THUMBNAIL_BAR_MODE_PINNED R.id.thumbnail_bar_mode_scrollable -> ThumbnailBarMode.THUMBNAIL_BAR_MODE_SCROLLABLE R.id.thumbnail_bar_mode_none -> ThumbnailBarMode.THUMBNAIL_BAR_MODE_NONE else -> null } ?: return super.onOptionsItemSelected(item)
currentMode = newMode bar?.setThumbnailBarMode(newMode) if (newMode == ThumbnailBarMode.THUMBNAIL_BAR_MODE_SCROLLABLE) bar?.setOnScrollListener(onScrollListener)
// a custom outer margin can be added to the thumbnail bar by using// bar?.setOuterMargin(100, 100, 100, 100)
invalidateOptionsMenu() return true }}This code sample is an example that illustrates how to use our SDK. Please adapt it to your specific use case.