• Flutter 设置input边框


    example 1

    example 1

    import 'package:flutter/material.dart';
    
    void main() => runApp(MyApp());
    
    class MyApp extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          home: HomePage(),
        );
      }
    }
    
    class HomePage extends StatefulWidget {
      @override
      _HomePageState createState() => _HomePageState();
    }
    
    class _HomePageState extends State<HomePage> {
      @override
      Widget build(BuildContext context) {
        return Scaffold(
          body: Center(
            child: Padding(
              padding: const EdgeInsets.all(24.0),
              child: Material(
                shape: BeveledRectangleBorder(
                  borderRadius: BorderRadius.all(Radius.circular(10)),
                  side: BorderSide( 1, color: Theme.of(context).primaryColor),
                ),
                child: Padding(
                  padding: const EdgeInsets.only(left: 8.0, right: 8.0),
                  child: TextField(
                    decoration: InputDecoration(
                      hintText: "Username",
                      border: InputBorder.none,
                    ),
                  ),
                ),
              ),
            ),
          ),
        );
      }
    }
    

    example 2

    import 'package:flutter/material.dart';
    import 'cut_corners_border.dart';
    
    void main() => runApp(MyApp());
    
    class MyApp extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          theme: ThemeData(
            inputDecorationTheme: InputDecorationTheme(
              border: CutCornersBorder(),
            ),
          ),
          home: HomePage(),
        );
      }
    }
    
    class HomePage extends StatefulWidget {
      @override
      _HomePageState createState() => _HomePageState();
    }
    
    class _HomePageState extends State<HomePage> {
      @override
      Widget build(BuildContext context) {
        return Scaffold(
          body: Center(
            child: Padding(
              padding: const EdgeInsets.all(24.0),
              child: TextField(
                decoration: InputDecoration(
                  hintText: "Username",
                ),
              ),
            ),
          ),
        );
      }
    }
    

    cut_corners_border.dart 源码来至这里

    import 'dart:ui' show lerpDouble;
    
    import 'package:flutter/material.dart';
    import 'package:flutter/widgets.dart';
    
    class CutCornersBorder extends OutlineInputBorder {
      const CutCornersBorder({
        BorderSide borderSide: const BorderSide(),
        BorderRadius borderRadius: const BorderRadius.all(Radius.circular(2.0)),
        this.cut: 7.0,
        double gapPadding: 2.0,
      }) : super(
                borderSide: borderSide,
                borderRadius: borderRadius,
                gapPadding: gapPadding);
    
      @override
      CutCornersBorder copyWith({
        BorderSide borderSide,
        BorderRadius borderRadius,
        double gapPadding,
        double cut,
      }) {
        return CutCornersBorder(
          borderRadius: borderRadius ?? this.borderRadius,
          borderSide: borderSide ?? this.borderSide,
          cut: cut ?? this.cut,
          gapPadding: gapPadding ?? this.gapPadding,
        );
      }
    
      final double cut;
    
      @override
      ShapeBorder lerpFrom(ShapeBorder a, double t) {
        if (a is CutCornersBorder) {
          final CutCornersBorder outline = a;
          return CutCornersBorder(
            borderRadius: BorderRadius.lerp(outline.borderRadius, borderRadius, t),
            borderSide: BorderSide.lerp(outline.borderSide, borderSide, t),
            cut: cut,
            gapPadding: outline.gapPadding,
          );
        }
        return super.lerpFrom(a, t);
      }
    
      @override
      ShapeBorder lerpTo(ShapeBorder b, double t) {
        if (b is CutCornersBorder) {
          final CutCornersBorder outline = b;
          return CutCornersBorder(
            borderRadius: BorderRadius.lerp(borderRadius, outline.borderRadius, t),
            borderSide: BorderSide.lerp(borderSide, outline.borderSide, t),
            cut: cut,
            gapPadding: outline.gapPadding,
          );
        }
        return super.lerpTo(b, t);
      }
    
      Path _notchedCornerPath(Rect center,
          [double start = 0.0, double extent = 0.0]) {
        final Path path = Path();
        if (start > 0.0 || extent > 0.0) {
          path.relativeMoveTo(extent + start, center.top);
          _notchedSidesAndBottom(center, path);
          path..lineTo(center.left + cut, center.top)..lineTo(start, center.top);
        } else {
          path.moveTo(center.left + cut, center.top);
          _notchedSidesAndBottom(center, path);
          path.lineTo(center.left + cut, center.top);
        }
        return path;
      }
    
      Path _notchedSidesAndBottom(Rect center, Path path) {
        return path
          ..lineTo(center.right - cut, center.top)
          ..lineTo(center.right, center.top + cut)
          ..lineTo(center.right, center.top + center.height - cut)
          ..lineTo(center.right - cut, center.top + center.height)
          ..lineTo(center.left + cut, center.top + center.height)
          ..lineTo(center.left, center.top + center.height - cut)
          ..lineTo(center.left, center.top + cut);
      }
    
      @override
      void paint(
        Canvas canvas,
        Rect rect, {
        double gapStart,
        double gapExtent: 0.0,
        double gapPercentage: 0.0,
        TextDirection textDirection,
      }) {
        assert(gapExtent != null);
        assert(gapPercentage >= 0.0 && gapPercentage <= 1.0);
    
        final Paint paint = borderSide.toPaint();
        final RRect outer = borderRadius.toRRect(rect);
        if (gapStart == null || gapExtent <= 0.0 || gapPercentage == 0.0) {
          canvas.drawPath(_notchedCornerPath(outer.middleRect), paint);
        } else {
          final double extent =
              lerpDouble(0.0, gapExtent + gapPadding * 2.0, gapPercentage);
          switch (textDirection) {
            case TextDirection.rtl:
              {
                final Path path = _notchedCornerPath(
                    outer.middleRect, gapStart + gapPadding - extent, extent);
                canvas.drawPath(path, paint);
                break;
              }
            case TextDirection.ltr:
              {
                final Path path = _notchedCornerPath(
                    outer.middleRect, gapStart - gapPadding, extent);
                canvas.drawPath(path, paint);
                break;
              }
          }
        }
      }
    }
    
  • 相关阅读:
    browserwindow.js
    Spring官网下载dist.zip的几种方法
    Vmware vsphere client
    chkconfig
    【WS-Federation】到底有多少公司在用WS-Federation
    【Passport】微软过时的技术
    【NHibernate】应用层面需要掌握的知识汇总
    【NHibernate】HQL入门
    【内存】特别想看下程序在内存中的状态
    【NHibernate】配置- sql打印
  • 原文地址:https://www.cnblogs.com/ajanuw/p/11384827.html
Copyright © 2020-2023  润新知