颤振时AspectRatio的错误

时间:2018-09-08 07:35:39

标签: flutter

你好,我试图做出地理围栏响应,我有一堆谷歌地图网址和一个圆圈。这段代码可以:

                                new Card(
                                  elevation: 2.0,
                                  child: new Stack(
                                    alignment: AlignmentDirectional.center,
                                    children: <Widget>[

                                      new Container(
                                        child: new Image.network(staticMapUri.toString()),
                                      ),
                                      new Container(
                                        alignment: new FractionalOffset(0.0, 0.0),
                                        decoration: new BoxDecoration(
                                          shape: BoxShape.circle,
                                          color: Colors.lightBlue.withOpacity(0.5),
                                        ),
                                        child:
                                        new AspectRatio(
                                          aspectRatio: MediaQuery.of(context).size.longestSide/GPS2,
                                          child :
                                          FractionalTranslation(
                                            translation: Offset(0.0, 0.0),
                                            child: new Container(
                                            ),
                                          ),
                                        ),
                                      ),
                                      new Container(
                                        //padding: const EdgeInsets.only(bottom:10.0),
                                        margin: new EdgeInsets.all(140.0),
                                        child : Icon(Icons.location_on, color: Colors.white, size: 25.0),
                                      ),
                                    ],
                                  ),
                                ),

但是我搜索将GPS2替换为具有滑块值的动态值,因此代码如下:


                                       new Slider(
                                        value: valperimetre,
                                        onChanged: (double e) => change(e),
                                        activeColor: Colors.lightBlue,
                                        inactiveColor :Colors.grey,
                                        divisions: 10,
                                        label: "$valperimetre""m",
                                        max : 500.0,
                                        min: 0.0,
                                      ),

              new Card(
                elevation: 2.0,
                child: new Stack(
                  alignment: AlignmentDirectional.center,
                  children: <Widget>[

                    new Container(
                      child: new Image.network(staticMapUri.toString()),
                    ),
                    new Container(
                      alignment: new FractionalOffset(0.0, 0.0),
                      decoration: new BoxDecoration(
                        shape: BoxShape.circle,
                        color: Colors.lightBlue.withOpacity(0.5),
                      ),
                      child:
                      new AspectRatio(
                        aspectRatio: MediaQuery.of(context).size.longestSide/valperimetre,
                        child :
                        FractionalTranslation(
                          translation: Offset(0.0, 0.0),
                          child: new Container(
                          ),
                        ),
                      ),
                    ),
                    new Container(
                      //padding: const EdgeInsets.only(bottom:10.0),
                      margin: new EdgeInsets.all(140.0),
                      child : Icon(Icons.location_on, color: Colors.white, size: 25.0),
                    ),
                  ],
                ),
              ),

但当前我有此错误:“如果我正常重建应用程序:断言失败:第399行pos 15:'aspectRatio.isFinite':不正确。” 如果我将valperimetre替换为100.0,则在重建应用程序后,然后将100.0替换为valperimetre并进行热重装就可以了。

1 个答案:

答案 0 :(得分:1)

尝试将此条件检查放入代码中。

//your code here
 child:(valperimetre == 0.0 || valperimetre == null) ? 
        Container()
       :new AspectRatio(
          aspectRatio: MediaQuery.of(context).size.longestSide/valperimetre,
//your code here