How to transform a rectangle in flutter like in this example?

Mobile Technologies Mobile Computing 2 years ago

0 1 0 0 0 tuteeHUB earn credit +10 pts

5 Star Rating 1 Rating
_x000D_ _x000D_ I am a beginner in Flutter and Dart, and I am working on designing a custom navigation bar. What I would like to know is how can I use flutter to transform a rectangle into this kind of shape? Any help or tutorials on custom drawn widgets are much appreciated!

Posted on 16 Aug 2022, this text provides information on Mobile Computing related to Mobile Technologies. Please note that while accuracy is prioritized, the data presented might not be entirely correct or up-to-date. This information is offered for general knowledge and informational purposes only, and should not be considered as a substitute for professional advice.

Take Quiz To Earn Credits!

Turn Your Knowledge into Earnings.

tuteehub_quiz

Answers (1)

Post Answer
profilepic.png
manpreet Tuteehub forum best answer Best Answer 2 years ago
_x000D_ ClipPath can be the solution for you and you can create custom clippers like this : class MyClipper extends CustomClipper { @override Path getClip(Size size) { Path myPath = Path(); myPath.lineTo(0.0, size.height); myPath.quadraticBezierTo( size.width / 4, size.height / 1.2, size.width / 2, size.height / 1.2 ); myPath.quadraticBezierTo( size.width - (size.width / 4), size.height / 1.2, size.width, size.height); myPath.lineTo(size.width, 0.0); return myPath; } @override bool shouldReclip(CustomClipper oldClipper) { return false; } } I posted my whole code in the follow, you can play with it and convert to what you need : import 'package:flutter/material.dart'; void main() { runApp(MyApp()); } class MyApp extends StatefulWidget { @override _MyAppState createState() => _MyAppState(); } class _MyAppState extends State { @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( body: Container( child: Center( child: ClipPath( clipper: MyClipper(), child: Container( height: 200, width: 300, color: Colors.black26, ), )), ), ), ); } } class MyClipper extends CustomClipper { @override Path getClip(Size size) { Path myPath = Path(); myPath.lineTo(0.0, size.height); myPath.quadraticBezierTo( size.width / 4, size.height / 1.2, size.width / 2, size.height / 1.2 ); myPath.quadraticBezierTo( size.width - (size.width / 4), size.height / 1.2, size.width, size.height); myPath.lineTo(size.width, 0.0); return myPath; } @override bool shouldReclip(CustomClipper oldClipper) { return false; } }

No matter what stage you're at in your education or career, TuteeHub will help you reach the next level that you're aiming for. Simply,Choose a subject/topic and get started in self-paced practice sessions to improve your knowledge and scores.

Important Mobile Technologies Links