广告位联系
返回顶部
分享到

用Python制作一个可以聊天的皮卡丘版桌面宠物

python 来源:互联网 作者:秩名 发布时间:2022-03-05 23:25:53 人浏览
摘要

导语 前段时间有小伙伴留言说想让我带大家写写桌面小挂件,今天就满足一下留过类似言的小伙伴的请求呗~不过感觉写桌面的挂历啥的没意思,就简单带大家做一只桌面宠物吧~ 废话不

导语

前段时间有小伙伴留言说想让我带大家写写桌面小挂件,今天就满足一下留过类似言的小伙伴的请求呗~不过感觉写桌面的挂历啥的没意思,就简单带大家做一只桌面宠物吧~

废话不多说,让我们愉快地开始吧~

开发工具

Python版本:3.6.4

相关模块:

PyQt5模块;

以及一些Python自带的模块

原理简介

既然要写个桌面宠物,首先当然是要找宠物的图片素材啦。这里我们使用的是来自shimiji这款手机APP上的宠物图片素材,例如皮卡丘:

我下了大约60多种宠物的图片素材供大家选择:

在相关文件里都打包一起提供了,所以这里就不分享爬虫代码了(我挑选了一下,只要不是我觉得特别丑的,我基本都保留了),别给人家服务器带来不必要的压力。

接下来,我们就可以开始设计我们的桌面宠物啦。鉴于网上用python写的桌面挂件基本都是基于tkinter的,为了突出公众号的与众不同,这里我们采用PyQt5来实现我们的桌面宠物。

步骤实现

首先,我们来初始化一个桌面宠物的窗口组件:

1

2

3

4

class DesktopPet(QWidget):

    def __init__(self, parent=None, **kwargs):

        super(DesktopPet, self).__init__(parent)

        self.show()

它的效果是这样子的:

接下来,我们设置一下窗口的属性让更适合作为一个宠物的窗口:

1

2

3

4

5

# 初始化

self.setWindowFlags(Qt.FramelessWindowHint|Qt.WindowStaysOnTopHint|Qt.SubWindow)

self.setAutoFillBackground(False)

self.setAttribute(Qt.WA_TranslucentBackground, True)

self.repaint()

并随机导入一张宠物图片来看看运行效果:

1

2

3

4

5

# 随机导入一个宠物

self.pet_images, iconpath = self.randomLoadPetImages()

# 当前显示的图片

self.image = QLabel(self)

self.setImage(self.pet_images[0][0])

其中随机导入一个宠物的所有图片的函数代码实现如下:

1

2

3

4

5

6

7

8

9

'''随机导入一个桌面宠物的所有图片'''

def randomLoadPetImages(self):

    pet_name = random.choice(list(cfg.PET_ACTIONS_MAP.keys()))

    actions = cfg.PET_ACTIONS_MAP[pet_name]

    pet_images = []

    for action in actions:

        pet_images.append([self.loadImage(os.path.join(cfg.ROOT_DIR, pet_name, 'shime'+item+'.png')) for item in action])

    iconpath = os.path.join(cfg.ROOT_DIR, pet_name, 'shime1.png')

    return pet_images, iconpath

当然,我们也希望宠物每次在桌面上出现的位置是随机的,这样会更有趣一些:

1

2

3

4

5

6

7

'''随机到一个屏幕上的某个位置'''

def randomPosition(self):

    screen_geo = QDesktopWidget().screenGeometry()

    pet_geo = self.geometry()

    width = (screen_geo.width() - pet_geo.width()) * random.random()

    height = (screen_geo.height() - pet_geo.height()) * random.random()

    self.move(width, height)

现在,运行我们的程序时,效果是这样子的:

好像蛮不错的呢~等等,好像有问题,重新设置了窗口属性之后,这玩意咋退出啊?在宠物右上角加个×这样的符号又好像很奇怪?

别急,我们可以给我们的桌面宠物添加一个托盘图标,以实现桌面宠物程序的退出功能:

1

2

3

4

5

6

7

8

9

# 设置退出选项

quit_action = QAction('退出', self, triggered=self.quit)

quit_action.setIcon(QIcon(iconpath))

self.tray_icon_menu = QMenu(self)

self.tray_icon_menu.addAction(quit_action)

self.tray_icon = QSystemTrayIcon(self)

self.tray_icon.setIcon(QIcon(iconpath))

self.tray_icon.setContextMenu(self.tray_icon_menu)

self.tray_icon.show()

效果是这样子的:

OK,这样好像有模有样了呢~但是好像还是不太对的样子,这宠物每次在桌面生成的位置是随机的,但是我们却无法调整这个宠物的位置,这显然不合理,作为一个桌面宠物,你肯定不能在妨碍主人工作的位置啊!要不我们来写一下鼠标按下、移动以及释放时的函数吧,这样就可以用鼠标拖动它了:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

'''鼠标左键按下时, 宠物将和鼠标位置绑定'''

def mousePressEvent(self, event):

    if event.button() == Qt.LeftButton:

        self.is_follow_mouse = True

        self.mouse_drag_pos = event.globalPos() - self.pos()

        event.accept()

        self.setCursor(QCursor(Qt.OpenHandCursor))

'''鼠标移动, 则宠物也移动'''

def mouseMoveEvent(self, event):

    if Qt.LeftButton and self.is_follow_mouse:

        self.move(event.globalPos() - self.mouse_drag_pos)

        event.accept()

'''鼠标释放时, 取消绑定'''

def mouseReleaseEvent(self, event):

    self.is_follow_mouse = False

    self.setCursor(QCursor(Qt.ArrowCursor))

效果如下:

哈哈,越来越像样了呢~最后,作为一个活泼的宠物,你不能这么呆板,一动也不动吧?好歹要学会做做表情逗主人开心吧?OK,我们先来设置一个定时器:

1

2

3

4

# 每隔一段时间做个动作

self.timer = QTimer()

self.timer.timeout.connect(self.randomAct)

self.timer.start(500)

定时器每隔一段时间切换一下选中的宠物的图片,以达到宠物做表情动作的动画效果(视频是一帧帧的图片组成的这种基础内容就不需要我来科普了吧T_T)。当然,这里我们必须对图片进行动作分类(在做同一个动作的图片属于同一类),保证宠物做表情动作时的连贯性。具体而言,代码实现如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

'''随机做一个动作'''

def randomAct(self):

    if not self.is_running_action:

        self.is_running_action = True

        self.action_images = random.choice(self.pet_images)

        self.action_max_len = len(self.action_images)

        self.action_pointer = 0

    self.runFrame()

'''完成动作的每一帧'''

def runFrame(self):

    if self.action_pointer == self.action_max_len:

        self.is_running_action = False

        self.action_pointer = 0

        self.action_max_len = 0

    self.setImage(self.action_images[self.action_pointer])

    self.action_pointer += 1

OK,大功告成了~


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://zhuanlan.zhihu.com/p/125693970
相关文章
  • Python Django教程之实现新闻应用程序

    Python Django教程之实现新闻应用程序
    Django是一个用Python编写的高级框架,它允许我们创建服务器端Web应用程序。在本文中,我们将了解如何使用Django创建新闻应用程序。 我们将
  • 书写Python代码的一种更优雅方式(推荐!)

    书写Python代码的一种更优雅方式(推荐!)
    一些比较熟悉pandas的读者朋友应该经常会使用query()、eval()、pipe()、assign()等pandas的常用方法,书写可读性很高的「链式」数据分析处理代码
  • Python灰度变换中伽马变换分析实现

    Python灰度变换中伽马变换分析实现
    1. 介绍 伽马变换主要目的是对比度拉伸,将图像灰度较低的部分进行修正 伽马变换针对的是对单个像素点的变换,也就是点对点的映射 形
  • 使用OpenCV实现迷宫解密的全过程

    使用OpenCV实现迷宫解密的全过程
    一、你能自己走出迷宫吗? 如下图所示,可以看到是一张较为复杂的迷宫图,相信也有人尝试过自己一点一点的找出口,但我们肉眼来解谜
  • Python中的数据精度问题的介绍

    Python中的数据精度问题的介绍
    一、python运算时精度问题 1.运行时精度问题 在Python中(其他语言中也存在这个问题,这是计算机采用二进制导致的),有时候由于二进制和
  • Python随机值生成的常用方法

    Python随机值生成的常用方法
    一、随机整数 1.包含上下限:[a, b] 1 2 3 4 import random #1、随机整数:包含上下限:[a, b] for i in range(10): print(random.randint(0,5),end= | ) 查看运行结
  • Python字典高级用法深入分析讲解
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python浅析多态与鸭子类型使用实例
    什么多态:同一事物有多种形态 为何要有多态=》多态会带来什么样的特性,多态性 多态性指的是可以在不考虑对象具体类型的情况下而直
  • Python字典高级用法深入分析介绍
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本

    Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本
    我们的目标是秒杀淘宝或京东等的订单,这里面有几个关键点,首先需要登录淘宝或京东,其次你需要准备好订单,最后要在指定时间快速
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计