polygon_clipper

A plugin to clip a Widget into a polygon shape. Works with any kind of Widget.


License
GPL-3.0

Documentation

Polygon Clipper

A Flutter plugin to create views using regular polygon shapes (e.g. Pentagons and Hexagons).

pub package

Example1 Example2 Example3

Installation

Add this to your package's pubspec.yaml file:

dependencies:
  polygon_clipper: ^1.0.2

Usage

Using ClipPolygon widget

import 'package:polygon_clipper/polygon_clipper.dart';  // Import package for ClipPolygon

ClipPolygon(  
 sides: 6, 
 borderRadius: 5.0, // Default 0.0 degrees
 rotate: 90.0, // Default 0.0 degrees
 boxShadows: [  
  PolygonBoxShadow(color: Colors.black, elevation: 1.0),
  PolygonBoxShadow(color: Colors.grey, elevation: 5.0)
 ],
 child: Container(color: Colors.black),
);

Using PolygonBorder shape

import 'package:polygon_clipper/polygon_border.dart'; // Import package for PolygonBorder

FloatingActionButton(
  shape: PolygonBorder(
    sides: 5,
    borderRadius: 5.0, // Default 0.0 degrees
    rotate: 90.0, // Default 0.0 degrees
    border: BorderSide.none, // Default BorderSide.none
  ),
  onPressed: runAction,
  child: Icon(Icons.star),
),

Parameters

ClipPolygon
Param Type Description
sides int The number of sides to draw the polygon
borderRadius double The length of the border radius in degrees.
rotate double The initial polygon rotation in degrees.
child Widget The widget that will be rendered inside the polygon.
boxShadows PolygonBoxShadow[] A list of box shadows.
PolygonBoxShadow
Param Type Description
color Color The color of the box shadow.
elevation double The distance of the shadow.
PolygonBorder
Param Type Description
sides int The number of sides to draw the polygon
borderRadius double The length of the border radius in degrees.
rotate double The initial polygon rotation in degrees.
border BorderSide The style of the border (when PolygonBorder is used as a decoration in Container, etc.)

Contributing

If you wish to contribute to this project, I encourage you to open a pull request.