How to disable the default Widget splash effect in Flutter

By default, many Flutter Material Design widgets show splash effects when selected.

This applies to IconButton, InkWell, ListTile and many other widgets.

If you're creating a completely custom design and want to disable this app-wide, all you need to do is this:

MaterialApp( theme: ThemeData( splashColor: Colors.transparent, highlightColor: Colors.transparent, hoverColor: Colors.transparent, ), )

Alternatively, you can apply this to a certain widget sub-tree by inserting a parent Theme widget:

Theme( data: Theme.of(context).copyWith( splashColor: Colors.transparent, highlightColor: Colors.transparent, hoverColor: Colors.transparent, ) child: child, )

You can also disable this directly for specific widgets:

IconButton( splashColor: Colors.transparent, highlightColor: Colors.transparent, hoverColor: Colors.transparent, icon: someIcon, onPressed: someCallback, )

Easy-peasy, like it should be. 😎

Happy coding!

Want More?

Invest in yourself with my high-quality Flutter courses.

The Complete Dart Developer Guide

The Complete Dart Developer Guide

Learn Dart Programming in depth. Includes: basic to advanced topics, exercises, and projects. Fully updated to Dart 2.15.

The Complete Flutter Course Bundle

The Complete Flutter Course Bundle

Learn about State Management, App Architecture, Navigation, Testing, and much more by building a full-stack Flutter eCommerce app on iOS, Android, and web.

Flutter Animations Masterclass - Full Course

Flutter Animations Masterclass - Full Course

Master Flutter animations and build a completely custom habit tracking application.