Skip to main content

How to implement swipe to refresh functionality in a GridView in Kotlin Android

How to implement swipe to refresh functionality in a GridView in Kotlin Android.

Here's a step-by-step tutorial on how to implement swipe to refresh functionality in a GridView in Kotlin Android.

Step 1: Create a new Android project in Kotlin and add the necessary dependencies.

  • Open Android Studio and create a new Kotlin project.
  • Open the app-level build.gradle file and add the following dependency:
implementation 'androidx.swiperefreshlayout:swiperefreshlayout:1.1.0'

Step 2: Create a new layout file for the main activity.

  • Open the activity_main.xml layout file and replace the default content with the following code:
<?xml version="1.0" encoding="utf-8"?>
<androidx.swiperefreshlayout.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swipeRefreshLayout"
android:layout_width="match_parent"
android:layout_height="match_parent">

<GridView
android:id="@+id/gridView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:numColumns="3"
android:verticalSpacing="8dp"
android:horizontalSpacing="8dp"
android:padding="8dp"/>

</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>

Step 3: Create a custom adapter for the GridView.

  • Create a new Kotlin file called CustomAdapter.kt and add the following code:
class CustomAdapter(private val context: Context, private val data: List<String>) : BaseAdapter() {

override fun getCount(): Int {
return data.size
}

override fun getItem(position: Int): Any {
return data[position]
}

override fun getItemId(position: Int): Long {
return position.toLong()
}

override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {
val view: View
if (convertView == null) {
view = LayoutInflater.from(context).inflate(R.layout.grid_item, parent, false)
} else {
view = convertView
}

val itemTextView = view.findViewById<TextView>(R.id.itemTextView)
itemTextView.text = data[position]

return view
}
}

Step 4: Create a new layout file for the grid item.

  • Create a new layout file called grid_item.xml and add the following code:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical">

<TextView
android:id="@+id/itemTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp"/>

</LinearLayout>

Step 5: Implement swipe to refresh functionality in the main activity.

  • Open the MainActivity.kt file and add the following code:
class MainActivity : AppCompatActivity() {

private lateinit var swipeRefreshLayout: SwipeRefreshLayout
private lateinit var gridView: GridView
private lateinit var adapter: CustomAdapter

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)

swipeRefreshLayout = findViewById(R.id.swipeRefreshLayout)
gridView = findViewById(R.id.gridView)

val data = listOf("Item 1", "Item 2", "Item 3", "Item 4", "Item 5", "Item 6", "Item 7", "Item 8", "Item 9")
adapter = CustomAdapter(this, data)
gridView.adapter = adapter

swipeRefreshLayout.setOnRefreshListener {
// Perform your refresh operation here
// For example, fetch new data from the server

// Simulate a delay by using a Handler
Handler().postDelayed({
// Add new data to the existing list
val newData = listOf("Item 10", "Item 11", "Item 12")

// Clear the adapter and add the new data
adapter.clear()
adapter.addAll(newData)

// Notify the adapter that the data has changed
adapter.notifyDataSetChanged()

// Stop the swipe to refresh animation
swipeRefreshLayout.isRefreshing = false

}, 2000) // Delay for 2 seconds
}
}
}

Step 6: Run the app and test the swipe to refresh functionality.

  • Run the app on an emulator or a physical device.
  • Swipe down on the GridView to trigger the refresh action.
  • After a 2-second delay, the grid items will be updated with new data.

That's it! You have successfully implemented swipe to refresh functionality in a GridView in Kotlin Android. You can customize the adapter and the refresh operation according to your specific needs.