flutter - 如何在 flutter 中修剪定位小部件的角

标签 flutter flutter-layout flutter-positioned

这是我得到的输出:

enter image description here

我想将绿色定位小部件与灰色容器的圆角一起夹在角上。 任何帮助将不胜感激。

我当前的代码:

import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: CustomCard(
          title: 'Custom Card', percentage: 50.0, color: Colors.green),
    );
  }
}

class CustomCard extends StatelessWidget {
  final String title;
  final double percentage;
  final Color color;
  CustomCard(
      {required this.title, required this.percentage, required this.color});
  @override
  Widget build(BuildContext context) {
    double width = MediaQuery.of(context).size.width;
    return Scaffold(
      appBar: AppBar(
        title: Text(title),
      ),
      body: Padding(
        padding: const EdgeInsets.all(8.0),
        child: Stack(clipBehavior: Clip.antiAliasWithSaveLayer, children: [
          Container(
            height: 100.0,
            width: width,
            decoration: BoxDecoration(
              borderRadius: BorderRadius.circular(10),
              color: Colors.grey,
            ),
          ),
          Positioned(
            left: -(percentage / 100) * width,
            top: -(percentage / 100) * width,
            child: Container(
              height: (percentage / 100) * width * 2,
              width: (percentage / 100) * width * 2,
              decoration: BoxDecoration(
                borderRadius:
                    BorderRadius.circular(((percentage / 100) * width)),
                color: color,
              ),
            ),
          ),
        ]),
      ),
    );
  }
}

谢谢。

最佳答案

@Ketan 如果你用 `ClipRRect1 小部件包裹堆栈并为其提供边框半径,那么它将向绿色和灰色区域添加边框。


class CustomCard extends StatelessWidget {
  final String title;
  final double percentage;
  final Color color;
  CustomCard({this.title, this.percentage, this.color});
  @override
  Widget build(BuildContext context) {
    double width = MediaQuery.of(context).size.width;
    return Scaffold(
      appBar: AppBar(
        title: Text(title),
      ),
      body: Padding(
          padding: const EdgeInsets.all(8.0),
          child: ClipRRect(
            borderRadius: BorderRadius.circular(10),
            child: Stack(clipBehavior: Clip.antiAliasWithSaveLayer, children: [
              Container(
                height: 100.0,
                width: width,
                decoration: BoxDecoration(
                  borderRadius: BorderRadius.circular(10),
                  color: Colors.grey,
                ),
              ),
              Positioned(
                left: -(percentage / 100) * width,
                top: -(percentage / 100) * width,
                child: Container(
                  height: (percentage / 100) * width * 2,
                  width: (percentage / 100) * width * 2,
                  decoration: BoxDecoration(
                    borderRadius:
                        BorderRadius.circular(((percentage / 100) * width)),
                    color: color,
                  ),
                ),
              ),
            ]),
          )),
    );
  }
}

关于flutter - 如何在 flutter 中修剪定位小部件的角,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68449547/

相关文章:

flutter - 在 flutter 中显示透明对话框

Flutter setState 不更新小部件

flutter - 如何使类似堆栈的定位小部件可滚动?

flutter - 使用 flutter 开发不同的屏幕尺寸?

dart - 如何在 AppBar 中使用 Positioned 小部件

flutter - 将推送通知从 firebase_messaging 6 迁移到 firebase_messaging 10+

flutter - 如何在 GridView (Flutter) 中进行分页

flutter - 如何将文本小部件放置在具有最大宽度的容器的水平端,而不展开它

flutter - 如何在 flutter 中更改应用程序图标的形状?

dart - 如何将图像背景分配给 flutter 中的列