网络编程
位置:首页>> 网络编程>> Python编程>> python实现公司年会抽奖程序

python实现公司年会抽奖程序

作者:我要做程序达人  发布时间:2022-12-19 15:35:27 

标签:python,抽奖程序

本文实例为大家分享了python实现年会抽奖程序的具体代码,供大家参考,具体内容如下

发一下自己写的公司抽奖程序。

需求:公司年会要一个抽奖程序,转盘上的每一个人名是随机中奖的,中奖后的人不可以再次中奖,按住抽奖,就会一直在转,放开后,要再转一两圈才停。

刚好自己在学python cocos2d,就用这个刚学的东东,直接上源码


# coding:utf-8
#
import sys
# import os
# sys.path.insert(0, os.path.join(os.path.dirname(__file__), '../..'))
# 解决程序中要显示中文问题
reload(sys)
sys.setdefaultencoding('utf8')
from pyglet import image, font
from pyglet.gl import *
from pyglet.window import key

from cocos.actions import *
from cocos.director import director
from cocos.layer import Layer
from cocos.layer import ColorLayer
from cocos.scene import Scene
from cocos.sprite import Sprite
from cocos.text import *
from cocos.menu import *

import random
from cocos.audio.effect import Effect
consts_window = {
"width": 680,
"height": 700,
"vsync": True,
"resizable": True,
'audio_backend':'sdl'
}

def get_sprite_test( index ):
d = tests[index]
return Scene( d( index ) )

class SpriteLayer( Layer ):

is_event_handler = True #: enable pyglet's events

def __init__( self, index=1 ):
super(SpriteLayer, self ).__init__()
self.index = index

self.top_text = "广州德瀚信息信息科技有限公司-年会抽奖"

self.image = pyglet.resource.image('r1.png',0.01)
# self.image = image.AnimationFrame(image.load('r1.png'),0.1)
self.image.anchor_x = self.image.width / 2
self.image.anchor_y = self.image.height / 2

self.rimage = pyglet.resource.image('r2.png',0.01)
# self.rimage = image.AnimationFrame(image.load('r2.png'),0.1)
self.rimage.anchor_x = self.image.width / 2
self.rimage.anchor_y = self.image.height / 2

self.bgimage = pyglet.resource.image('bg1.png')
self.bgimage.anchor_x = self.image.width / 2
self.bgimage.anchor_y = self.image.height / 2

self.pressbgimage = pyglet.resource.image('bg2.png')
self.pressbgimage.anchor_x = self.image.width / 2
self.pressbgimage.anchor_y = self.image.height / 2

self.prizeimage = pyglet.resource.image('name.png')
self.prizeimage.anchor_x = self.image.width / 2
self.prizeimage.anchor_y = self.image.height / 2

def on_key_release( self, keys, mod ):
# LEFT: go to previous scene
# RIGTH: go to next scene
# ENTER: restart scene
if keys == key.LEFT:
 self.index -= 1
 if self.index < 1:
 self.index = len( tests )
elif keys == key.RIGHT:
 self.index += 1
 if self.index > len( tests ):
 self.index = 1

if keys in (key.LEFT, key.RIGHT):
 director.replace( get_sprite_test( self.index ) )
 return True

class PrizeMenu(Menu):
def __init__( self ):
super( PrizeMenu, self ).__init__()

self.menu_valign = BOTTOM
self.menu_halign = RIGHT
self.font_item['color'] = (0,0,0,255)
self.font_item_selected['color'] = (32,16,32,255)
# print dir(self)

# then add the items
items = [
 ( MenuItem('一等奖', self.prize_go ) ),
 ( MenuItem('二等奖', self.prize_go ) ),
 ( MenuItem('三等奖', self.prize_go ) ),
 ( MenuItem('参与奖', self.prize_go ) ),

]

# self.create_menu( items, selected_effect=zoom_in(),
#   unselected_effect=zoom_out())
self.create_menu( items, shake(), shake_back())

def on_quit( self ):
pyglet.app.exit()
def prize_go( self ):
s = self.parent
if s.is_begin:
 s.top_notice.element.text=""
else:
 # s.stop_num = 1
 s.go_prize()

# def main():

# pyglet.font.add_directory('.')

# director.init( resizable=True)
# director.run( Scene( PrizeMenu() ) )

# if __name__ == '__main__':
# main()

class StartPrize( SpriteLayer ):
def __init__( self,index ):
super( StartPrize, self ).__init__(index)

self.current_num = 0 #当前位置
self.is_begin = False #是否已经开始
self.prize_cycle = 0 #转动圈数
self.prize_speed = 0.05 #初始速度
self.prize_speed_slow = 0.3 #慢速度
self.stop_num = 0 #停止的位置
self.alread_get_prize = [] # 已经得奖的人
self.start_slow = False
self.can_stop = False
self.press_go = False

self.sprite = Sprite( self.image )
# self.sprite = Sprite( image.Animation([image.AnimationFrame(image.load('r1.png'),0.001)] ))
self.alread_prize_sprite = Sprite( self.rimage )

self.bgsprite = Sprite( self.bgimage )
self.pressbgsprite = Sprite( self.pressbgimage )
self.prizesprite = Sprite( self.prizeimage )

self.top_label = Label( self.top_text )
# 注意是要有个element
self.top_label.element.x = -250
self.top_label.element.y = 350
self.top_label.element.color = (0,0,0,255)
self.top_label.element.font_size = 20

self.top_notice = Label( "点击中间开始抽奖" )
self.top_notice.element.x = 120
self.top_notice.element.y = 300
self.top_notice.element.color = (255,0,0,255)
self.top_notice.element.font_size = 20

self.pressbgsprite.do(Hide())
self.alread_prize_sprite.do(Hide())
# self.sprite.do(Hide())

def on_enter( self ):
super(StartPrize,self).on_enter()

bgcolor = ColorLayer(255,255,255,255, consts_window['width'], consts_window['height'])
bgcolor.position = (-320,-320)
# 背景颜色
self.add( bgcolor )
# 标题
self.add( self.top_label )
self.add( self.top_notice )
# 转动的背景图
self.add( self.sprite ,z=3)
self.add( self.alread_prize_sprite ,z=3)
# 人名图
self.add( self.prizesprite ,z=4)
# 背景图
self.add( self.bgsprite,z=1 )
self.add( self.pressbgsprite,z=1 )

self.position = 320,320

# menu = PrizeMenu()
# menu.position = (-320,-320)
# self.add(menu)

# self.sprite.do( Repeat(Rotate( 360, 4 ) ))

def on_key_press( self, keys, mod ):
super(StartPrize,self).on_key_release(keys, mod)
if keys == key.ENTER:
 if self.is_begin:
 self.top_notice.element.text="正在抽奖中。。"
 else:
 self.press_go = True
 self.go_prize()
 return True

def on_key_release( self, keys, mod ):
super(StartPrize,self).on_key_release(keys, mod)
if keys == key.ENTER:
 if self.press_go:
 self.prize_cycle = 0
 self.can_stop = True
 self.press_go = False
 return True
if keys == key.S:
 # self.stop_prize()
 return True
def on_mouse_press (self, x, y, buttons, modifiers):
px,py = director.get_virtual_coordinates (x, y)
# print px,py
if px > 188 and px<450 and py>188 and py<450:
 if self.is_begin:
 self.top_notice.element.text="正在抽奖中。。"
 else:
 self.press_go = True
 self.go_prize()
def on_mouse_release (self, x, y, buttons, modifiers):
px,py = director.get_virtual_coordinates (x, y)
if self.press_go:
 self.prize_cycle = 0
 self.can_stop = True
 self.press_go = False

def rotate_select(self,dt):

if (self.current_num >= 24):
 self.current_num = 0
 self.prize_cycle += 1

if ( self.prize_cycle > 1 and self.can_stop):
 if( not self.start_slow ):
 # 减速
 self.unschedule(self.rotate_select)
 self.schedule_interval(self.rotate_select, self.prize_speed_slow)
 self.start_slow = True

# print self.alread_get_prize
# print "stopnum" , self.stop_num
# print "prize_cycle" , self.prize_cycle
# print "current_num" , self.current_num
# print self.current_num
# 注意rotate_select是要两个参数的
self.sprite.rotation=self.sprite.rotation+15
self.alread_prize_sprite.rotation = self.alread_prize_sprite.rotation+15

if self.current_num in self.alread_get_prize:
 self.sprite.do(Hide())
 self.alread_prize_sprite.do(Show())
else:
 self.alread_prize_sprite.do(Hide())
 self.sprite.do(Show())
effect = Effect('1.wav')
effect.play()

if ( self.prize_cycle > 2 and self.stop_num == self.current_num and self.can_stop):
 self.stop_prize()
 return True

self.current_num += 1

def get_random(self):
r = random.randint(0,23)
if r in self.alread_get_prize:
 r = self.get_random()
return r

def go_prize(self):
self.current_num = 0
self.sprite.rotation=0
self.alread_prize_sprite.rotation = 0
self.prize_cycle = 0
self.stop_num = self.get_random()
# self.stop_num = 0

if self.stop_num in self.alread_get_prize:
 self.top_notice.element.text="error, alread get prize"
 return False
self.top_notice.element.text="正在抽奖中。。"
self.start_slow = False
self.can_stop = False

self.is_begin = True

# 定时器
self.schedule_interval(self.rotate_select, self.prize_speed)
# self.schedule(self.rotate_select)
self.bgsprite.do(Hide())
self.pressbgsprite.do(Show())

def stop_prize(self):
self.alread_get_prize.append(self.current_num)
self.is_begin = False
effect = Effect('2.wav')
effect.play()
self.top_notice.element.text=""

self.pressbgsprite.do(Hide())
self.bgsprite.do(Show())
self.unschedule(self.rotate_select)

tests = {
1: StartPrize,
}

def main():
director.init(**consts_window)
# director.show_FPS = True
director.run( get_sprite_test( 1 ) )
if __name__ == '__main__':
main()

PrizeMenu这个本来是想要显示要抽哪个奖的,后来需求中不需要了,就没有继续完善。

开发用的是python cocos2d, 还要装pyglet, 最坑爹的是还要装pygame, cocos2d的音效竟然是用pygame的。

因为是name.png是公司同事的姓名,所以就涂黑了,尊重隐私

下载链接:年会抽奖

dehan_prize_run下的prize.exe就可以运行,用py2exe打包成exe的。。。
prize_src.zip是源码

来源:https://blog.csdn.net/cheng830306/article/details/18449431

0
投稿

猜你喜欢

  • 生活形态(Life-Style)的概念源自社会学与心理学,六十年代即有学者正式引用到市场营销领域,并运用其心理影射与多维度等特质,着力解释人
  • 虽然现在IE还是主导了整个浏览器的天下,但IE靠的并非是产品设计上的优势,而是依靠windows的力量,因为绝大多数的初级网民认为IE的产品
  • 在做数据库备份和还原数据库的时候出现"错误2812:未能找到存储过程’master.dbo.xp_fileexist’"
  • 为什么能实现在线编辑呢? 首先需要ie 的支持,在 ie 5.5以后就有一个编辑状态,就是利用这个编辑状态,然后用javascript 来控
  • 方法一、尽量使用复杂的SQL来代替简单的一堆 SQL.同样的事务,一个复杂的SQL完成的效率高于一堆简单SQL完成的效率。有多个查询时,要善
  • 现在有一个xml,格式如下: <date> <item> <id> 1 </id> <
  • Python入门教程FROM:http://www.cnblogs.com/taowen/articles/11239.aspx作者:tao
  • 示例:mysql> DELIMITER //mysql> CREATE PROCEDURE `statis`()  
  • 高阶函数是在Python中一个非常有用的功能函数,所谓高阶函数就是一个函数可以用来接收另一个函数作为参数,这样的函数叫做高阶函数。pytho
  • 之前在比赛的时候需要用Python实现灰色关联分析,从网上搜了下只有实现两个列之间的,于是我把它改写成了直接想Pandas中的计算工具直接计
  • 在SQL Server中,提供了通过Exchange或Outlook收发邮件的扩展存储过程。下面简单地介绍一下:一、启动SQL Mail:x
  • 简单的2048小游戏不多说,直接上图,这里并未实现GUI之类的,需要的话,可自行实现:接下来就是代码模块,其中的2048游戏原来网络上有很多
  • Cookie是一种小型文本文件,存储在用户计算机中,用于跟踪用户在互联网上的活动。Cookie通常由网站创建,以便记住用户的偏好和登录状态,
  • 以前在介绍SQL2k的时候已经提到了SQL2k对XML的支持,使用for XML语句就可以很容易的把执行的结果转化为一个XML,这样可以在很
  • 一、介绍ADB(Android调试桥)是一个命令行工具(CLI),可用于控制Android设备并与之通信。您可以执行许多操作,例如安装应用程
  • WebSocket的作用WebSock其实在平常使用,我们是时常见到的,用于实时通讯,例如我们常用的实时聊天、服务端向客户端消息推送、也可以
  • 前言反爬虫是网站为了维护自己的核心安全而采取的抑制爬虫的手段,反爬虫的手段有很多种,一般情况下除了百度等网站,反扒机制会常常更新以外。为了保
  • 在使用操作XML文件时,我们可以使用Load方法直接加载xml文件即可,在ie和ff下通用。但是是XML字符串,则在两种浏览器下就会有所不同
  • slice 可以用来获取数组片段,它返回新数组,不会修改原数组。除了正常用法,slice 经常用来将 array-like 对象转换为 tr
  • 2.彻底弄懂CSS盒子模式二(导航栏实例) 3.彻底弄懂CSS盒子模式三(浮动的表演和清除的自述) 4.彻底弄懂CSS盒子模式四(绝对定位和
手机版 网络编程 asp之家 www.aspxhome.com