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

Mobile Technologies Mobile Computing 2 years ago

9.04K 1 0 0 0

_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.

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; } }
0 views
0 shares

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.

Similar Forum


Q

Would Firebase be a good choice as a server for the Flutter mobile game I'm creating?

_x000D_ _x000D_ I am building a turn-based Flutter game. Would Firebase be a good choice as a server...
Q

Implement Bottom Navigation activity along with a VerticalViewPager with nested Cardview in Android...

_x000D_ _x000D_ I want to develop an Android App which will have a Bottom Navigation Bar and above i...
Q

(JS) For , determine if the device offers or not to capture a photo from the camera

_x000D_ _x000D_ When uploading a file, I need to give the user the possibility: upload the file fr...

Important Mobile Technologies Links