如何将图像放在图像中颤动

Posted

技术标签:

【中文标题】如何将图像放在图像中颤动【英文标题】:how can put image inside the image in flutter 【发布时间】:2019-02-09 21:29:13 【问题描述】:

https://i.stack.imgur.com/w5mLQ.png

就像我们在大图片中看到的一个小圆形图像。以及如何安排文字如图所示

https://i.stack.imgur.com/w5mLQ.png

【问题讨论】:

如果您提出问题并展示您尝试过的内容(以文本形式)并分享结果,则此网站效果最佳。见How to Ask。仅仅询问代码示例,您可能不会获得太大的吸引力。 【参考方案1】:

看一下这个例子(一个汉堡图标和三个红点在紫色剪裁的背景上):

如果你想要这个,代码会很短:

body: Column(
        children: <Widget>[
          ClipPath(
            clipper: MyClipper(),
            child: Container(
              height: 350,
              width: double.infinity,
              decoration: BoxDecoration(
                gradient: LinearGradient(colors: [
                  Color.fromRGBO(16, 27, 117, 0.5),
                  Color.fromRGBO(16, 27, 117, 0.5),
                ]),
                image: DecorationImage(
                  image: AssetImage(
                    "assets/images/points_removed.png",
                  ),
                ),
              ),
              child: Align(
                alignment: Alignment(-0.8, -0.6),
                child: Image.asset(
                  "assets/images/hamburger_icon.png",
                  width: 30,
                  height: 20,
                ),
              ),
            ),
          ),
        ],
      ),

(可选)背景裁剪代码

class MyClipper extends CustomClipper<Path> 
  @override
  Path getClip(Size size) 
    var path = Path();
    path.lineTo(0, size.height - 80);
    path.quadraticBezierTo(
        size.width / 2, size.height, size.width, size.height - 80);
    path.lineTo(size.width, 0);
    path.close();
    return path;
  

  @override
  bool shouldReclip(CustomClipper<Path> oldClipper) 
    return false;
  

【讨论】:

如果您想打开带有汉堡图标的抽屉,请查看here 或here。【参考方案2】:
Widget build(BuildContext context) 
  return new Container(
    height: 150.0,
    margin: new EdgeInsets.all(10.0),
    decoration: new BoxDecoration(borderRadius: new BorderRadius.all(new Radius.circular(10.0)),
        gradient: new LinearGradient(colors: [Colors.yellow[700], Colors.redAccent],
            begin: Alignment.centerLeft, end: Alignment.centerRight, tileMode: TileMode.clamp)),
    child: new Row(
      crossAxisAlignment: CrossAxisAlignment.center,
      children: <Widget>[
        new Padding(padding: new EdgeInsets.only(left: 10.0, right: 10.0),
          child: new CircleAvatar(radius: 35.0, backgroundImage: NetworkImage('https://wallpapercave.com/wp/wp2365076.jpg'),)
        ),
        new Expanded(child: new Column(
          mainAxisAlignment: MainAxisAlignment.center,
          crossAxisAlignment: CrossAxisAlignment.start,
          children: <Widget>[
            new Text('New York', style: new TextStyle(fontSize: 20.0, color: Colors.white70, fontWeight: FontWeight.bold),),
            new SizedBox(height: 8.0,),
            new Text('Sunny', style: new TextStyle(fontSize: 12.0, color: Colors.white70),),
            new SizedBox(height: 10.0,),
            new Row(children: <Widget>[
              new Column(children: <Widget>[
                new Text('2342', style: new TextStyle(fontSize: 12.0, color: Colors.white)),
                new Text('Popularity', style: new TextStyle(fontSize: 10.0, color: Colors.white)),
              ],),
              new Column(children: <Widget>[
                new Text('2342', style: new TextStyle(fontSize: 12.0, color: Colors.white)),
                new Text('Like', style: new TextStyle(fontSize: 10.0, color: Colors.white)),
              ],),
              new Column(children: <Widget>[
                new Text('2342', style: new TextStyle(fontSize: 12.0, color: Colors.white)),
                new Text('Followed', style: new TextStyle(fontSize: 10.0, color: Colors.white)),
              ],)
            ],)
          ],)),
        new Padding(padding: new EdgeInsets.only(left: 10.0, right: 10.0),
          child: new Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: <Widget>[
            new Text('12°', style: new TextStyle(fontSize: 30.0, color: Colors.white70),),
            new Text('Ranking', style: new TextStyle(fontSize: 14.0, color: Colors.white70),),
          ],))

      ],),
  );

【讨论】:

【参考方案3】:

需要一些小部件来完成您想要实现的目标。以下是我将如何解决它(它可能需要一些微调来满足您的确切需求,但应该可以帮助您入门):

首先从背景开始(我相信你称之为大图)。为此,您可以使用Container 小部件来绘制矩形,并使用设置decoration 属性和BoxDecoration 小部件来设置背景图像。

接下来将Container 小部件的child 属性设置为包含圆形图像的Row 小部件和包含文本元素的Column 小部件。

整个事情可能看起来像这样:

new Container(
    decoration: new BoxDecoration(
        image: new DecorationImage(
            image: new AssetImage('assets/images/card_background.png'),
            fit: BoxFit.cover,
        ),
    ),
    child: new Row(
        children: <Widget>[
            new CircleAvatar(
                backgroundImage: new AssetImage('assets/images/avatar.png')
            ),
            new Column(
                children: <Widget>[
                    new Text('David Borg'),
                    new Text('Title: Flying Wing'),
                ],
            ),
        ],
    ),
)

以下是对上述代码 sn-p 中使用的最重要的小部件的一些参考:

Container小部件 BoxDecoration小部件 CircleAvatar 小部件 Column 小部件 Row小部件

请注意,我尚未测试 sn-p 中列出的代码,因此可能需要稍作调整。

【讨论】:

以上是关于如何将图像放在图像中颤动的主要内容,如果未能解决你的问题,请参考以下文章

如何将图像从颤动的资产上传到firebase存储?

如何在颤动中将资产图像存储在缓存中

如何将半径应用于颤动的图像?

Django:如何从颤动中读取使用 Dio 发送的图像

如何在listview颤动中显示来自firestore的图像数组?

如何将gps数据添加到图像,颤动image_picker Android