项目-坦克大战学习-子弹的移动与销毁

子弹的移动可以参照人机的移动方式,在创建出来的时候就将yidong设置为true然后给一个速度就行了,子弹的销毁代码可以借用坦克的超出检测代码,将检测到超出后执行的程序修改成销毁程序就行

对于子弹的销毁我们可以在列表中让那个超出边界的对象清除掉,下一次绘制地图就没有他了

但是我们不可以直接在检测超出的位置设置子弹的销毁,因为检测超出的时候列表还在运行,而销毁的方法是将子弹在列表中抹除,在列表运行时修改列表会出bug,所以我们换一种方式,给超出界限的子弹打上标记,然后在列表实例化完后在运行一个方法将打上标记的子弹销毁,这样就不会在列表运行期间对列表进行更改了

所以我们需要给子弹添加一个bool用来检测子弹是否超出

public bool xiaohui{ get; set; } //是否需要销毁默认否

如果子弹超出就在检测超出方法中修改bool值

if (Fangxiang == fangxiang.Up)//检测子弹目前朝向

{

if (y - speed < 0)//如果在前进一帧会大于地图边界

{

xiaohui=true; return;//标记为超出

}

}

然后在对象位置类遍历列表将检测出来超出的对象放入新的列表

foreach(zidan zid in zidanlist)//遍历zidan列表查找需要销毁的对象

{

if(zid.xiaohui==true)//符合条件

{

zd.Add(zid);//放入销毁检测列表

}

}

在运行销毁检测列表时将检测到的对象在子弹列表中销毁

foreach (zidan zidan in zd)

{

zidanlist.Remove(zidan);//将列表中所有对象销毁

}

这样就不会资源冲突了

相关推荐
QT 小鲜肉6 分钟前
【Linux命令大全】001.文件管理之mdu命令(实操篇)
linux·运维·服务器·chrome·笔记·microsoft
im_AMBER13 分钟前
数据结构 14 【复习】二叉树中序遍历 | 线索二叉树 | 树、森林、二叉树的转换 | 层次遍历二叉树
数据结构·笔记·学习·算法
im_AMBER14 分钟前
Leetcode 88 K 和数对的最大数目
数据结构·c++·笔记·学习·算法·leetcode
旖旎夜光15 分钟前
Linux(6)(上)
linux·学习
代码猪猪傻瓜coding16 分钟前
IEEE 模版 作者传记间距过大问题
笔记
小龙28 分钟前
大模型训练全流程学习笔记
笔记·学习·ai·大模型
全栈游侠30 分钟前
GT2933触摸驱动分析 - 初始化(续)
linux·笔记
糕......34 分钟前
Java集合框架全解析
java·开发语言·网络·学习·list
wangnaisheng35 分钟前
Intel IPP 图像处理相关函数
c++·c#·图像
hetao173383737 分钟前
2025-12-25~26 hetao1733837的刷题记录
c++·笔记·算法