0

0

【AI创造营】决战二仙桥

P粉084495128

P粉084495128

发布时间:2025-07-29 10:15:03

|

694人浏览过

|

来源于php中文网

原创

【AI创造营】决战二仙桥(DodgeFace-EXQver)是款基于人脸检测的躲避类游戏,优化了技术与模型,适配普通配置电脑。玩家需通过移动身体、转动头部躲避谭警官,未检测到脸即Game Over,死亡后按r重开。可通过--level X调整难度,新增谭谈交通宇宙元素,气球哥和强人锁男哥等NPC会出现并释放特殊技能。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

【ai创造营】决战二仙桥 - php中文网

参赛作品名

【AI创造营】决战二仙桥(DodgeFace-EXQver)

作品简介

和前作DodgeFace操作方式一样,内部使用的技术换了:之前是ace2p,如果电脑配置不好的话,可能跑起来非常的卡。现在换成人脸检测的方式了,模型也用的比较小的模型,现在应该一般配置的就能丝滑享受吧(话是这么说,但是我也没多余的电脑来测。。。

使用方式

保证你的脸在摄像头可以拍摄的范围内,运行程序

    python erxianqiao_map_skill.py

       

笔墨写作
笔墨写作

一款专注于各类公文写作的AI写作平台

下载

移动你的身体、转动你的头颅躲避那些...谭警官

如果没检测到你的脸会直接Game Over哦

如果不小心死掉了,按r重新开始,按其他的则退出游戏

如果你觉得游戏太过简单

    python erxianqiao_map_skill.py --level X

       

X是一个正整数,X的默认值是5,如果你想加大难度,试试比5大的数吧

一些提示

增加了一些细节,更有主题了,这次是谭谈交通宇宙

既然是谭谈交通宇宙,除了二仙桥大爷和我们的谭sir,还有另外两个npc可能会出现

一个是灵魂歌手-气球哥

技能是让我们控制的二仙桥大爷多一条命

另一个是“从我身上下来”的强人锁男哥

技能是让全场的角色停止,不能运动n秒(替身攻击The World???)

希望大家玩得开心~

github

   
In [ ]
#封装了一下检测模块,让视频流的检测更稳定一点class detUtils():
    def __init__(self):
        super(detUtils, self).__init__()
        self.lastres = None
        self.module = hub.Module(name="ultra_light_fast_generic_face_detector_1mb_320")    
    def distance(self, a, b):
        return math.sqrt(math.pow(a[0]-b[0], 2) + math.pow(a[1]-b[1], 2))    def iou(self, bbox1, bbox2):

        b1left = bbox1['left']
        b1right = bbox1['right']
        b1top = bbox1['top']
        b1bottom = bbox1['bottom']

        b2left = bbox2['left']
        b2right = bbox2['right']
        b2top = bbox2['top']
        b2bottom = bbox2['bottom']

        area1 = (b1bottom - b1top) * (b1right - b1left)
        area2 = (b2bottom - b2top) * (b2right - b2left)

        w = min(b1right, b2right) - max(b1left, b2left)
        h = min(b1bottom, b2bottom) - max(b1top, b2top)

        dis = self.distance([(b1left+b1right)/2, (b1bottom+b1top)/2],[(b2left+b2right)/2, (b2bottom+b2top)/2])        if w <= 0 or h <= 0:            return 0, dis
        
        iou = w * h / (area1 + area2 - w * h)        return iou, dis    
    def dodet(self, frame):
        result = self.module.face_detection(images=[frame], use_gpu=True)
        result = result[0]['data']        if isinstance(result, list):            if len(result) == 0:                return None, None
            if len(result) > 1:                if self.lastres is not None:
                    maxiou = -float('inf')
                    maxi = 0
                    mind = float('inf')
                    mini = 0
                    for index in range(len(result)):
                        tiou, td = self.iou(self.lastres, result[index])                        if tiou > maxiou:
                            maxi = index
                            maxiou = tiou                        if td < mind:
                            mind = td
                            mini = index  
                    if tiou == 0:                        return result[mini], result                    else:                        return result[maxi], result                else:
                    self.lastres = result[0]                    return result[0], result            else:
                self.lastres = result[0]                return result[0], result        else:            return None, None
   
In [ ]
#基础技能类class Skill():
    def __init__(self, interval, gm):
        self.stime = 0
        self.interval = interval
        self.gm = gm
        self.finish = False

    def trigger(self):
        self.stime = time.time()
        self.play()    def play(self):
        pass#气球哥的技能,加一条生命class Balloon(Skill):
    def __init__(self, interval, gm):
        super(Balloon, self).__init__(interval, gm)    def play(self):
        # print("Balloon Play")
        if self.finish is False:
            self.gm.glive()            if np.floor(time.time() - self.stime) >= self.interval:
                self.finish = True#强人锁男的技能,停止所有角色class Lock(Skill):
    def __init__(self, interval, gm):
        super(Lock, self).__init__(interval, gm)    def play(self):
        global llock        #print("Lock Play")
        if self.finish is False:
            llock = True
            if np.floor(time.time() - self.stime) >= self.interval:
                self.finish = True
                llock = False
        #print("Lock Play end:", llock)#谭sir的技能,减一条命class Tansir(Skill):
    def __init__(self,interval, gm):
        super(Tansir, self).__init__(interval, gm)    def play(self):
        # print("Tansir Play")
        if self.finish is False:
            self.gm.nlive()            if np.floor(time.time() - self.stime) >= self.interval:
                self.finish = True
   
In [ ]
#npc类,NPC都有一张贴图和一个技能class Ball():
    
    x = None
    y = None
    speed_x = None
    speed_y = None

    def __init__(self, x, y, speed_x, speed_y, img, skill):
        self.x = x
        self.y = y
        self.speed_x = speed_x
        self.speed_y = speed_y
        self.img = img
        mask = np.zeros_like(img)
        mask[img > 0] = 1
        self.mask = mask
        self.h, self.w = img.shape[:2]  
        self.skill = skill           

    def move(self, screen, checkimg):
        global GM        global llock        # print(llock)
        if not llock:
            self.x += self.speed_x
            self.y += self.speed_y        
            if self.x > W - self.w/2 or self.x < self.w/2:
                self.speed_x = -self.speed_x            if self.y > H - self.h/2 or self.y < self.h/2:
                self.speed_y = -self.speed_y

        t, l, b, r, tt, tl, tb, tr = getPIXEL(self.x, self.y, self.w/2, self.h/2)

        ctimg = checkimg[t:b,l:r]  
        stimg = screen[t:b,l:r]          
        
        if np.sum(ctimg[self.mask[tt:tb,tl:tr]>0]) > 0:
            self.skill.trigger()            if self.skill.finish is False:
                GM.appendskill(self.skill)            return True
        else:
            screen[t:b,l:r] = screen[t:b,l:r] * (1 - self.mask[tt:tb,tl:tr]) +  self.mask[tt:tb,tl:tr] * self.img[tt:tb,tl:tr]            return False
   

相关专题

更多
PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

c++ Libcurl用法详解
c++ Libcurl用法详解

本专题整合了c++ Libcurl用法详解,阅读专题下面的文章了解更多详细内容。

0

2026.01.07

c++ Libcurl用法大全
c++ Libcurl用法大全

本专题整合了c++ Libcurl用法详解,阅读专题下面的文章了解更多详细内容。

0

2026.01.07

C++ vector用法汇总
C++ vector用法汇总

本专题整合了C++中vector的用法大全,阅读专题下面的文章了解更多详细内容。

2

2026.01.07

C++ vector用法大全
C++ vector用法大全

本专题整合了C++中vector的用法大全,阅读专题下面的文章了解更多详细内容。

0

2026.01.07

2026年漫蛙最新官网地址
2026年漫蛙最新官网地址

漫蛙官网访问入口为https://manwa.me,另提供manwa.cc、manwa.vip、manwa.site等多节点备用链接,支持跨设备同步、个性化阅读及HTTPS安全加密。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

60

2026.01.07

php做exe需要在什么样的环境
php做exe需要在什么样的环境

PHP无法真正编译为EXE,所谓打包实为将解释器、脚本及依赖库封装成自解压容器;主流方案是ExeOutputforPHP(商业、Windows)和PHPDesktop(开源、跨平台),需手动处理扩展依赖、路径适配与运行时限制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2026.01.07

抖音抖币官方充值渠道汇总
抖音抖币官方充值渠道汇总

抖音官方抖币充值官网入口为https://pay.douyin.com/,具备直连支付系统、全端统一鉴权、HTTPS加密传输、多设备实时同步等特性,支持微信/支付宝/银联/话费等多种支付方式及严密账户安全机制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

5

2026.01.07

vscode创建html的教程
vscode创建html的教程

在 Visual Studio Code 中创建 HTML 文件的步骤如下:打开 VSCode并创建新文件。选择 "HTML" 模板。输入 HTML 代码。保存文件。(可选)预览文件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

3

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号