在Flutter里实现一个开心农场地块布局!Web前端工程师也可以看看,作为Flutter入门。

简介: 为避免贴大段代码,文中代码部分仅作为参考,并非全部代码,请理解后自行补全或者下载源码进行学习。

绘制方案选型


用什么来画呢?我给小兄弟的例子是用custompainter绘制的,但本文里我会用Widget来实现,原因是地块不多的话,用Widget也感受不到什么性能差距。自己用custompainter实现的话,会麻烦一些


比如显示一张图片...


  • Widget


Image.asset("图片路径");


  • Custompainter


ImageStream stream = AssetImage("图片路径", bundle: rootBundle).resolve(ImageConfiguration.empty);
void listener(ImageInfo frame, bool synchronousCall) {
    final UI.Image image = frame.image;
    //将Image绘制到画布上
    canvas.drawImage(image, UI.Offset(60.0, 60.0), Paint());
    stream.removeListener(ImageStreamListener(listener));
}
stream.addListener(ImageStreamListener(listener));


导入图片素材


image.png


我准备了两个地块款式,两款树的图片,全放在Flutter项目目录里的assets目录下


image.png


这样我们在pubspec.yaml(flutter项目的package.json)里配置一下就可以用以下代码来显示图片了


image.png


Image.asset("assets/floor1.png");


配置布局


其实这个地块,我们只需要一个数组就可以配置。不过是25块地嘛?我们建立一个长度为25的数组来管理地块


0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0


现在我们加几个换行符,让这个数组对地块的表述是不是更直观了?


0,0,0,0,0,
0,0,0,0,0,
0,0,0,0,0,
0,0,0,0,0,
0,0,0,0,0


这样是不是更清晰了?地块的等级,有没有浇水,有没有树都可以用数字来表示,比如你的地块和树的款式都不超过10个的话,那么地块款式用个位1-9表示,树的种类用十位0-9表示。


1,1,1,1,1,
1,11,1,1,1,
1,1,1,1,1,
1,1,1,1,1,
1,1,1,1,1


这就代表所有地块用1号图片,并且在第2行的第2个地块上种了一棵1号款式的树


当然这个数组里放Map也是可以的,不是非要纯数字。这样可以存放更多信息,但在本例里数字已经足够了。


想明白了配置,我们只需要用Widget构建出来就行了


构建布局


这里我用Stack+Positioned来构建布局


Stack和Positioned的结合就像是css里的position:absolute


List<int> map = [
    1,1,1,1,1,
    1,1,1,1,1,
    1,1,1,1,1,
    1,1,1,1,1,
    1,1,1,1,1
  ];
for(int i = 0;i<map.length;i++){
  all.add(Positioned(
    left: (i%rowCount).floor()*floorSize.width,
    top:(i/rowCount).floor()*floorSize.height,
    child: Text("$i")
  ));
}


这是按序号横排


image.png


如果需要按序号纵向排列,只需要将%/对调一下


left: (i/rowCount).floor()*floorSize.width,
top:(i%rowCount).floor()*floorSize.height,


image.png


现在我们把地块的图片显示出来


image.png


left: (i/rowCount).floor()*floorSize.width,
top:(i%rowCount).floor()*floorSize.height,
child: Image.asset("assets/floor1.png",width: floorSize.width,height: floorSize.height)


由于地块是菱形,所以我们还需要计算一下偏移


  1. 按横排序号上移50%
  2. 按竖排序号右移50%
  3. 宽高减半计算


int xIndex = (i/rowCount).floor();
int yIndex = (i%rowCount).floor();
Positioned(
    left: xIndex*floorSize.width/2+yIndex*floorSize.width/2,
    top:yIndex*floorSize.height/2-xIndex*floorSize.height/2
)


image.png


TADA! 我们成功拼出了地块对不对!


现在让地块按照数组来显示地块图片


List<int> map = [
    1,1,1,1,1,
    1,1,1,1,1,
    1,1,2,1,1,
    1,1,1,1,1,
    1,1,1,1,1
  ];
Image.asset("assets/floor${map[i]}.png")


image.png


把树加进来


前面我们制定的配置格式为个位数表示地块,十位数表示树种类,那么代码如下


int floorType = map[i]%10;//数字取个位
int treeType = ((map[i]%100)/10).floor();//数字取十位


剩下就是把树的图片显示出来了


List<int> map = [
    1,1,1,1,1,
    1,1,51,1,1,
    1,1,42,1,1,
    1,1,51,1,1,
    1,1,1,1,1
];
int treeType = ((map[i]%100)/10).floor();
if(treeType>0){
    all.add(Positioned(
      left: xIndex*floorSize.width/2+yIndex*floorSize.width/2-treeSize.width*.3,
      top:yIndex*floorSize.height/2-xIndex*floorSize.height/2+135-treeSize.height,
      child: Image.asset("assets/youzi$treeType.png",width: treeSize.width,height: treeSize.height)
    ));
}


image.png


TADA! 我们成功种上树了!


缩放移动怎么解决?


在Flutter里非常简单,用InteractiveViewer!!


InteractiveViewer(
    boundaryMargin: const EdgeInsets.all(double.infinity),
    minScale: 0.2,
    maxScale: 2,
    child: getMapWidget() //这个函数返回的就是前面构建的地块Stack
)



image.png


后记


这仅仅只完成了最简单的农场游戏布局,不过相信大家已经通过这篇文章理解了实现方式,用任意框架都可以轻易完成了吧!


相关文章
|
7天前
|
JavaScript 前端开发 小程序
一小时入门Vue.js前端开发
本文是作者关于Vue.js前端开发的快速入门教程,包括结果展示、参考链接、注意事项以及常见问题的解决方法。文章提供了Vue.js的基础使用介绍,如何安装和使用cnpm,以及如何解决命令行中遇到的一些常见问题。
一小时入门Vue.js前端开发
|
5天前
|
开发框架 移动开发 Android开发
安卓与iOS开发中的跨平台解决方案:Flutter入门
【9月更文挑战第30天】在移动应用开发的广阔舞台上,安卓和iOS两大操作系统各自占据半壁江山。开发者们常常面临着选择:是专注于单一平台深耕细作,还是寻找一种能够横跨两大系统的开发方案?Flutter,作为一种新兴的跨平台UI工具包,正以其现代、响应式的特点赢得开发者的青睐。本文将带你一探究竟,从Flutter的基础概念到实战应用,深入浅出地介绍这一技术的魅力所在。
22 7
|
7天前
|
前端开发 API
(WEB前端编辑DWG)在线CAD如何实现图形识别功能
mxcad 提供的图形识别功能可帮助用户快速识别和提取 CAD 图纸中的各种图形,如直线、多段线、弧线、圆及图块,显著提升设计效率。此功能不仅适用于图形分类,还能进行数量统计和快速定位,减少手动操作。用户可通过 API 进行二次开发,自定义识别逻辑。具体步骤包括打开在线示例、选择识别功能、设置识别参数并开始识别。更多开发文档请关注公众号:梦想云图网页 CAD。
|
9天前
|
前端开发 开发者 Python
从零到一:Python Web框架中的模板引擎入门与进阶
在Web开发的广阔世界里,模板引擎是连接后端逻辑与前端展示的重要桥梁。对于Python Web开发者而言,掌握模板引擎的使用是从零到一构建动态网站或应用不可或缺的一步。本文将带你从基础入门到进阶应用,深入了解Python Web框架中的模板引擎。
14 3
|
9天前
|
前端开发 容器
前端基础(十五)_多栏布局(两列自适应布局、圣杯布局---三列布局、双飞翼布局--三列布局、等高布局)
本文介绍了前端开发中的多种自适应布局技术,包括两列自适应布局、圣杯布局(三列布局)、双飞翼布局(三列布局)和等高布局。文章通过代码示例展示了如何使用HTML和CSS实现这些布局,以及如何通过flex布局简化实现过程。
33 2
|
8天前
|
JSON 前端开发 JavaScript
不会webpack的前端可能是捡来的,万字总结webpack的超入门核心知识
该文章提供了Webpack的基础入门指南,涵盖安装配置、基本使用、加载器(Loaders)、插件(Plugins)的应用,以及如何通过Webpack优化前端项目的打包构建流程。
不会webpack的前端可能是捡来的,万字总结webpack的超入门核心知识
|
8天前
|
存储 前端开发 JavaScript
浅谈Web前端安全策略xss和csrf,及又该如何预防?
该文章详细讨论了Web前端安全中的XSS(跨站脚本攻击)和CSRF(跨站请求伪造)攻击原理及其防范措施,帮助读者了解如何保护Web应用程序免受这两种常见安全威胁的影响。
浅谈Web前端安全策略xss和csrf,及又该如何预防?
|
17天前
|
编解码 前端开发 JavaScript
web端 本地调用摄像头、前端摄像头
web端 本地调用摄像头、前端摄像头
|
23天前
|
前端开发
|
23天前
|
弹性计算 前端开发 容器
【前端web入门第六天】02 flex布局
Flex布局是一种现代CSS布局模式,通过给父元素设置`display: flex`,其子元素可自动挤压或拉伸。它包含弹性容器和弹性盒子,主轴默认为水平方向,侧轴为垂直方向。主轴对齐方式由`justify-content`属性控制,侧轴对齐方式包括`align-items`(针对所有子元素)和`align-self`(针对单个子元素)。修改主轴方向使用`flex-direction`属性,`flex`属性用于控制子元素在主轴上的伸缩比例。此外,`flex-wrap`属性允许子元素换行,而`align-content`属性则定义多行对齐方式。
下一篇
无影云桌面