clippy_flutter 1.1.1 copy "clippy_flutter: ^1.1.1" to clipboard
clippy_flutter: ^1.1.1 copied to clipboard

Clip your widgets with custom shapes provided.

example/lib/main.dart

import 'package:example/arc_demo.dart';
import 'package:example/arrow_demo.dart';
import 'package:example/buttcheek_demo.dart';
import 'package:example/chevron_demo.dart';
import 'package:example/diagonal_demo.dart';
import 'package:example/message_demo.dart';
import 'package:example/bevel_demo.dart';
import 'package:example/ticket_demo.dart';
import 'package:example/trapezoid_demo.dart';
import 'package:example/triangle_demo.dart';
import 'package:flutter/material.dart';
import 'package:clippy_flutter/clippy_flutter.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'clippy_flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.pink,
      ),
      routes: {
        '/': (_) => HomePage(),
        '/diagonal_demo': (_) => DiagonalDemo(),
        '/chevron_demo': (_) => ChevronDemo(),
        '/ticket_demo': (_) => TicketDemo(),
        '/buttcheek_demo': (_) => ButtCheekDemo(),
        '/triangle_demo': (_) => TriangleDemo(),
        '/arrow_demo': (_) => ArrowDemo(),
        '/trapezoid_demo': (_) => TrapezoidDemo(),
        '/arc_demo': (_) => ArcDemo(),
        '/message_demo': (_) => MessageDemo(),
        '/bevel_demo': (_) => BevelDemo(),
      },
    );
  }
}

class HomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('clippy_flutter Demo'),
      ),
      body: Padding(
        padding: const EdgeInsets.all(4.0),
        child: SingleChildScrollView(
          child: Center(
            child: Wrap(
              spacing: 2.0,
              runSpacing: 4.0,
              alignment: WrapAlignment.center,
              crossAxisAlignment: WrapCrossAlignment.center,
              children: <Widget>[
                Diagonal(
                  clipHeight: 20.0,
                  axis: Axis.vertical,
                  position: DiagonalPosition.BOTTOM_RIGHT,
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/diagonal_demo'),
                    child: Container(
                      color: Colors.red,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('Diagonal')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Chevron(
                  triangleHeight: 30.0,
                  edge: Edge.RIGHT,
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/chevron_demo'),
                    child: Container(
                      color: Colors.lightGreen,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('Chevron')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Ticket(
                  radius: 10.0,
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/ticket_demo'),
                    child: Container(
                      color: Colors.yellow,
                      width: 100.0,
                      height: 50.0,
                      child: Center(child: Text('Ticket')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                ButtCheek(
                  height: 10.0,
                  child: GestureDetector(
                    onTap: () =>
                        Navigator.pushNamed(context, '/buttcheek_demo'),
                    child: Container(
                      color: Colors.blue,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('ButtCheek')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Triangle.isosceles(
                  edge: Edge.TOP,
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/triangle_demo'),
                    child: Container(
                      color: Colors.pinkAccent,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('Triangle')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Arrow(
                  triangleHeight: 30.0,
                  rectangleClipHeight: 10.0,
                  edge: Edge.RIGHT,
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/arrow_demo'),
                    child: Container(
                      color: Colors.deepOrange,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('Arrow')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Message(
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/message_demo'),
                    child: Container(
                      color: Colors.green,
                      width: 100.0,
                      height: 100.0,
                      child: Center(
                          child: Padding(
                        padding: const EdgeInsets.only(bottom: 20.0),
                        child: Text('Message'),
                      )),
                    ),
                  ),
                  triangleX1: 60.0,
                  triangleX2: 80.0,
                  triangleX3: 80.0,
                  triangleY1: 20.0,
                ),
                SizedBox(height: 8.0),
                Trapezoid(
                  cutLength: 15.0,
                  edge: Edge.TOP,
                  child: GestureDetector(
                    onTap: () =>
                        Navigator.pushNamed(context, '/trapezoid_demo'),
                    child: Container(
                      color: Colors.yellow,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('Trapezoid')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Arc(
                  edge: Edge.BOTTOM,
                  arcType: ArcType.CONVEY,
                  height: 20.0,
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/arc_demo'),
                    child: Container(
                      color: Colors.purpleAccent,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('Arc')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Bevel(
                  cutLength: 10.0,
                  child: GestureDetector(
                    onTap: () => Navigator.pushNamed(context, '/bevel_demo'),
                    child: Container(
                      color: Colors.red,
                      width: 100.0,
                      height: 100.0,
                      child: Center(child: Text('Bevel')),
                    ),
                  ),
                ),
                SizedBox(height: 8.0),
                Rabbet(
                  cutLength: 10.0,
                  child: Container(
                    color: Colors.cyan,
                    width: 100.0,
                    height: 100.0,
                    child: Center(child: Text('Rabbet')),
                  ),
                ),
                SizedBox(height: 8.0),
                Point(
                  triangleHeight: 30.0,
                  edge: Edge.LEFT,
                  child: Container(
                    color: Colors.pink,
                    width: 100.0,
                    height: 100.0,
                    child: Center(child: Text('Point')),
                  ),
                ),
                SizedBox(height: 8.0),
                Parallelogram(
                  cutLength: 10.0,
                  edge: Edge.RIGHT,
                  child: Container(
                    color: Colors.lightGreen,
                    width: 100.0,
                    height: 100.0,
                    child: Center(child: Text('Paralelogram')),
                  ),
                ),
                SizedBox(height: 8.0),
                Polygon(
                  sides: 5,
                  child: Container(
                    color: Colors.red,
                    width: 100.0,
                    height: 100.0,
                    child: Center(child: Text('Polygon')),
                  ),
                ),
                SizedBox(height: 8.0),
                Label(
                  triangleHeight: 10.0,
                  edge: Edge.RIGHT,
                  child: Container(
                    padding: const EdgeInsets.only(
                        left: 8.0, right: 18.0, top: 8.0, bottom: 8.0),
                    color: Colors.green,
                    child: Text('Label'),
                  ),
                ),
                SizedBox(height: 8.0),
                Rhombus(
                  child: Container(
                    color: Colors.orangeAccent,
                    width: 100.0,
                    height: 100.0,
                    child: Center(child: Text('Rhombus')),
                  ),
                ),
                Star(
                  child: Container(
                    color: Colors.yellow,
                    width: 100.0,
                    height: 100.0,
                    child: Center(child: Text('Star')),
                  ),
                ),
              ],
            ),
          ),
        ),
      ),
    );
  }
}
142
likes
30
points
3.54k
downloads

Publisher

unverified uploader

Weekly Downloads

Clip your widgets with custom shapes provided.

Repository (GitHub)
View/report issues

License

BSD-2-Clause (license)

Dependencies

flutter

More

Packages that depend on clippy_flutter