Mega Bundle SALE is ON! Get ALL of our amazing Flutter codebases with 75% OFF discount 🔥

So, what exactly does “Haptic Feedback” mean when it comes to Flutter? Before we can start coding, we need to have a solid understanding of haptic feedback. The same justification applies to our use of haptic feedback.

The device reacts to the user’s taps on the screen by performing the appropriate action. The reaction provided by the gadget is referred to as haptic feedback.

In many cases, the purpose of haptic feedback is to alert the user whenever an action is performed or an event is clicked.

Various Flutter Haptic Feedback Types

• HeavyImpact – Inputs haptic feedback in response to a collision with a large object.

• MediumImpact – Provides haptic sensation in line with a collision contact with a medium mass.

• LightImpact – Using LightImpact, you may feel the impact of a light mass on your hand.

• Vibrate –It vibrates for a brief period of time to provide the user with haptic feedback.

• SelectionClick – A haptic feedback is provided to show that the selection is moving from one discrete value to another.

How to Use Flutter’s Haptic Feedback Feature

In order to begin, three classes must be created: main.dart, home.dart, and second.dart.

Main.Dart Code

import 'package:flutter/material.dart';
import 'home.dart';
void main() {
  runApp(MyApp());
}
class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
  debugShowCheckedModeBanner: false,
      home: MyHomePage(),
    );
  }
}

The root of the application was constructed using a stateless widget in this manner. Because we don’t want to burden our app’s main thread, we don’t code here.

Home.Dart Code

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'second.dart';
class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}
 
class _MyHomePageState extends State<MyHomePage> {
  //"space" used for space between widgets
  final space = SizedBox(height: 55);
 
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: Colors.greenAccent,
      appBar: AppBar(
        title: Text("Haptic Feedback"),
        backgroundColor: Colors.indigo,
        elevation: 2,
      ),
      body: SingleChildScrollView(
        child: Padding(
          padding: const EdgeInsets.all(8.0),
          child: Center(
            child: Column(
              mainAxisAlignment: MainAxisAlignment.spaceAround,
              children: [
                Text(
                  "Press button for touch impact",
                  style: TextStyle(fontSize: 25, fontWeight: FontWeight.bold),
                ),
                space,
                // Buttons wrapped in containers
                Container(
                  width: MediaQuery.of(context).size.width,
                  height: MediaQuery.of(context).size.height / 12,
                  child: ElevatedButton(
                    child: Text("Heavy Impact"),
                    onPressed: () {
                      HapticFeedback.heavyImpact();
                      Navigator.push(
                          context,
                          MaterialPageRoute(
                              builder: (context) => SecondPage()));
                    },
                  ),
                ),
                space,
                Container(
                  width: MediaQuery.of(context).size.width,
                  height: MediaQuery.of(context).size.height / 12,
                  child: ElevatedButton(
                    child: Text("Light Impact"),
                    onPressed: () {
                      HapticFeedback.lightImpact();
                      Navigator.push(
                          context,
                          MaterialPageRoute(
                              builder: (context) => SecondPage()));
                    },
                  ),
                ),
                space,
                Container(
                  width: MediaQuery.of(context).size.width,
                  height: MediaQuery.of(context).size.height / 12,
                  child: ElevatedButton(
                    child: Text("Medium Impact"),
                    onPressed: () {
                      HapticFeedback.mediumImpact();
                      Navigator.push(
                          context,
                          MaterialPageRoute(
                              builder: (context) => SecondPage()));
                    },
                  ),
                ),
                space,
                Container(
                  width: MediaQuery.of(context).size.width,
                  height: MediaQuery.of(context).size.height / 12,
                  child: ElevatedButton(
                    child: Text("Vibrate "),
                    onPressed: () {
                      HapticFeedback.vibrate();
                      Navigator.push(
                          context,
                          MaterialPageRoute(
                              builder: (context) => SecondPage()));
                    },
                  ),
                ),
                space,
                Container(
                  width: MediaQuery.of(context).size.width,
                  height: MediaQuery.of(context).size.height / 12,
                  child: ElevatedButton(
                    child: Text("selectionClick "),
                    onPressed: () {
                      HapticFeedback.vibrate();
                      Navigator.push(
                          context,
                          MaterialPageRoute(
                              builder: (context) => SecondPage()));
                    },
                  ),
                ),
              ],
            ),
          ),
        ),
      ),
    );
  }
}

As you can see, we have developed a user interface (UI) that includes buttons that provide haptic feedback.

Now, when the button is pressed by the user, it will reply appropriately. This kind of reaction is referred to by its technical name, haptic feedback.

Second.Dart Code

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart'; 
class SecondPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text("Second Page"),),
      body: Center(
        child: Container(
          // Button to go back to home page
          child: ElevatedButton(child: Text("Back to Home"),onPressed: (){
            Navigator.pop(context);
          },),
        ),
      ),
    );
  }
}

When the user clicks the button on this page, they will be sent from the home page to the second page. This is the third and last screen that I have designed for the user interface.

The pictures on the screen will be seen here.

We have high hopes that reading this blog will help you learn more about haptic feedback utilizing flutter and that you will be able to put your newfound knowledge into practice.

Happiness for All Those who Learn.


Leave a Reply

Your email address will not be published. Required fields are marked *

Shopping Cart