国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Python 竟能開發(fā)如此精美的俄羅斯方塊【附源碼】

這篇具有很好參考價(jià)值的文章主要介紹了Python 竟能開發(fā)如此精美的俄羅斯方塊【附源碼】。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

1、案例介紹

俄羅斯方塊是由 4 個(gè)小方塊組成不同形狀的板塊,隨機(jī)從屏幕上方落下,按方向鍵調(diào)整板塊的位置和方向,在底部拼出完整的一行或幾行。這些完整的橫條會(huì)消失,給新落下來的板塊騰出空間,并獲得分?jǐn)?shù)獎(jiǎng)勵(lì)。沒有被消除掉的方塊不斷堆積,一旦堆到頂端,便告輸,游戲結(jié)束。本例難度為高級(jí),適合具有 Python 進(jìn)階和 Pygame 編程技巧的用戶學(xué)習(xí)。

2、設(shè)計(jì)要點(diǎn)

邊框――由 15*25 個(gè)空格組成,方塊就落在這里面。盒子――組成方塊的其中小方塊,是組成方塊的基本單元。

方塊――從邊框頂?shù)粝碌臇|西,游戲者可以翻轉(zhuǎn)和改變位置。每個(gè)方塊由 4 個(gè)盒子組成。形狀――不同類型的方塊。這里形狀的名字被叫做 T, S, Z ,J, L, I , O。如下圖所示:

模版――用一個(gè)列表存放形狀被翻轉(zhuǎn)后的所有可能樣式。全部存放在變量里,變量名字如 S or J。著陸――當(dāng)一個(gè)方塊到達(dá)邊框的底部或接觸到在其他的盒子話,就說這個(gè)方塊著陸了。那樣的話,另一個(gè)方塊就會(huì)開始下落。

3、示例效果

4、示例源碼文章來源地址http://www.zghlxwxcb.cn/news/detail-523604.html

import?pygame
import?random
import?os

pygame.init()

GRID_WIDTH?=?20
GRID_NUM_WIDTH?=?15
GRID_NUM_HEIGHT?=?25
WIDTH,?HEIGHT?=?GRID_WIDTH?*?GRID_NUM_WIDTH,?GRID_WIDTH?*?GRID_NUM_HEIGHT
SIDE_WIDTH?=?200
SCREEN_WIDTH?=?WIDTH?+?SIDE_WIDTH
WHITE?=?(0xff,?0xff,?0xff)
BLACK?=?(0,?0,?0)
LINE_COLOR?=?(0x33,?0x33,?0x33)

CUBE_COLORS?=?[
????(0xcc,?0x99,?0x99),?(0xff,?0xff,?0x99),?(0x66,?0x66,?0x99),
????(0x99,?0x00,?0x66),?(0xff,?0xcc,?0x00),?(0xcc,?0x00,?0x33),
????(0xff,?0x00,?0x33),?(0x00,?0x66,?0x99),?(0xff,?0xff,?0x33),
????(0x99,?0x00,?0x33),?(0xcc,?0xff,?0x66),?(0xff,?0x99,?0x00)
]

screen?=?pygame.display.set_mode((SCREEN_WIDTH,?HEIGHT))
pygame.display.set_caption("俄羅斯方塊")
clock?=?pygame.time.Clock()
FPS?=?30

score?=?0
level?=?1

screen_color_matrix?=?[[None]?*?GRID_NUM_WIDTH?for?i?in?range(GRID_NUM_HEIGHT)]

#?設(shè)置游戲的根目錄為當(dāng)前文件夾
base_folder?=?os.path.dirname(__file__)


def?show_text(surf,?text,?size,?x,?y,?color=WHITE):
????font_name?=?os.path.join(base_folder,?'font/font.ttc')
????font?=?pygame.font.Font(font_name,?size)
????text_surface?=?font.render(text,?True,?color)
????text_rect?=?text_surface.get_rect()
????text_rect.midtop?=?(x,?y)
????surf.blit(text_surface,?text_rect)


class?CubeShape(object):
????SHAPES?=?['I',?'J',?'L',?'O',?'S',?'T',?'Z']
????I?=?[[(0,?-1),?(0,?0),?(0,?1),?(0,?2)],
?????????[(-1,?0),?(0,?0),?(1,?0),?(2,?0)]]
????J?=?[[(-2,?0),?(-1,?0),?(0,?0),?(0,?-1)],
?????????[(-1,?0),?(0,?0),?(0,?1),?(0,?2)],
?????????[(0,?1),?(0,?0),?(1,?0),?(2,?0)],
?????????[(0,?-2),?(0,?-1),?(0,?0),?(1,?0)]]
????L?=?[[(-2,?0),?(-1,?0),?(0,?0),?(0,?1)],
?????????[(1,?0),?(0,?0),?(0,?1),?(0,?2)],
?????????[(0,?-1),?(0,?0),?(1,?0),?(2,?0)],
?????????[(0,?-2),?(0,?-1),?(0,?0),?(-1,?0)]]
????O?=?[[(0,?0),?(0,?1),?(1,?0),?(1,?1)]]
????S?=?[[(-1,?0),?(0,?0),?(0,?1),?(1,?1)],
?????????[(1,?-1),?(1,?0),?(0,?0),?(0,?1)]]
????T?=?[[(0,?-1),?(0,?0),?(0,?1),?(-1,?0)],
?????????[(-1,?0),?(0,?0),?(1,?0),?(0,?1)],
?????????[(0,?-1),?(0,?0),?(0,?1),?(1,?0)],
?????????[(-1,?0),?(0,?0),?(1,?0),?(0,?-1)]]
????Z?=?[[(0,?-1),?(0,?0),?(1,?0),?(1,?1)],
?????????[(-1,?0),?(0,?0),?(0,?-1),?(1,?-1)]]
????SHAPES_WITH_DIR?=?{
????????'I':?I,?'J':?J,?'L':?L,?'O':?O,?'S':?S,?'T':?T,?'Z':?Z
????}

????def?__init__(self):
????????self.shape?=?self.SHAPES[random.randint(0,?len(self.SHAPES)?-?1)]
????????#?骨牌所在的行列
????????self.center?=?(2,?GRID_NUM_WIDTH?//?2)
????????self.dir?=?random.randint(0,?len(self.SHAPES_WITH_DIR[self.shape])?-?1)
????????self.color?=?CUBE_COLORS[random.randint(0,?len(CUBE_COLORS)?-?1)]

????def?get_all_gridpos(self,?center=None):
????????curr_shape?=?self.SHAPES_WITH_DIR[self.shape][self.dir]
????????if?center?is?None:
????????????center?=?[self.center[0],?self.center[1]]

????????return?[(cube[0]?+?center[0],?cube[1]?+?center[1])
????????????????for?cube?in?curr_shape]

????def?conflict(self,?center):
????????for?cube?in?self.get_all_gridpos(center):
????????????#?超出屏幕之外,說明不合法
????????????if?cube[0]?<?0?or?cube[1]?<?0?or?cube[0]?>=?GRID_NUM_HEIGHT?or?\
????????????????????cube[1]?>=?GRID_NUM_WIDTH:
????????????????return?True

????????????#?不為None,說明之前已經(jīng)有小方塊存在了,也不合法
????????????if?screen_color_matrix[cube[0]][cube[1]]?is?not?None:
????????????????return?True

????????return?False

????def?rotate(self):
????????new_dir?=?self.dir?+?1
????????new_dir?%=?len(self.SHAPES_WITH_DIR[self.shape])
????????old_dir?=?self.dir
????????self.dir?=?new_dir
????????if?self.conflict(self.center):
????????????self.dir?=?old_dir
????????????return?False

????def?down(self):
????????#?import?pdb;?pdb.set_trace()
????????center?=?(self.center[0]?+?1,?self.center[1])
????????if?self.conflict(center):
????????????return?False

????????self.center?=?center
????????return?True

????def?left(self):
????????center?=?(self.center[0],?self.center[1]?-?1)
????????if?self.conflict(center):
????????????return?False
????????self.center?=?center
????????return?True

????def?right(self):
????????center?=?(self.center[0],?self.center[1]?+?1)
????????if?self.conflict(center):
????????????return?False
????????self.center?=?center
????????return?True

????def?draw(self):
????????for?cube?in?self.get_all_gridpos():
????????????pygame.draw.rect(screen,?self.color,
?????????????????????????????(cube[1]?*?GRID_WIDTH,?cube[0]?*?GRID_WIDTH,
??????????????????????????????GRID_WIDTH,?GRID_WIDTH))
????????????pygame.draw.rect(screen,?WHITE,
?????????????????????????????(cube[1]?*?GRID_WIDTH,?cube[0]?*?GRID_WIDTH,
??????????????????????????????GRID_WIDTH,?GRID_WIDTH),
?????????????????????????????1)


def?draw_grids():
????for?i?in?range(GRID_NUM_WIDTH):
????????pygame.draw.line(screen,?LINE_COLOR,
?????????????????????????(i?*?GRID_WIDTH,?0),?(i?*?GRID_WIDTH,?HEIGHT))

????for?i?in?range(GRID_NUM_HEIGHT):
????????pygame.draw.line(screen,?LINE_COLOR,
?????????????????????????(0,?i?*?GRID_WIDTH),?(WIDTH,?i?*?GRID_WIDTH))

????pygame.draw.line(screen,?WHITE,
?????????????????????(GRID_WIDTH?*?GRID_NUM_WIDTH,?0),
?????????????????????(GRID_WIDTH?*?GRID_NUM_WIDTH,?GRID_WIDTH?*?GRID_NUM_HEIGHT))


def?draw_matrix():
????for?i,?row?in?zip(range(GRID_NUM_HEIGHT),?screen_color_matrix):
????????for?j,?color?in?zip(range(GRID_NUM_WIDTH),?row):
????????????if?color?is?not?None:
????????????????pygame.draw.rect(screen,?color,
?????????????????????????????????(j?*?GRID_WIDTH,?i?*?GRID_WIDTH,
??????????????????????????????????GRID_WIDTH,?GRID_WIDTH))
????????????????pygame.draw.rect(screen,?WHITE,
?????????????????????????????????(j?*?GRID_WIDTH,?i?*?GRID_WIDTH,
??????????????????????????????????GRID_WIDTH,?GRID_WIDTH),?2)


def?draw_score():
????show_text(screen,?u'得分:{}'.format(score),?20,?WIDTH?+?SIDE_WIDTH?//?2,?100)


def?remove_full_line():
????global?screen_color_matrix
????global?score
????global?level
????new_matrix?=?[[None]?*?GRID_NUM_WIDTH?for?i?in?range(GRID_NUM_HEIGHT)]
????index?=?GRID_NUM_HEIGHT?-?1
????n_full_line?=?0
????for?i?in?range(GRID_NUM_HEIGHT?-?1,?-1,?-1):
????????is_full?=?True
????????for?j?in?range(GRID_NUM_WIDTH):
????????????if?screen_color_matrix[i][j]?is?None:
????????????????is_full?=?False
????????????????continue
????????if?not?is_full:
????????????new_matrix[index]?=?screen_color_matrix[i]
????????????index?-=?1
????????else:
????????????n_full_line?+=?1
????score?+=?n_full_line
????level?=?score?//?20?+?1
????screen_color_matrix?=?new_matrix


def?show_welcome(screen):
????show_text(screen,?u'俄羅斯方塊',?30,?WIDTH?/?2,?HEIGHT?/?2)
????show_text(screen,?u'按任意鍵開始游戲',?20,?WIDTH?/?2,?HEIGHT?/?2?+?50)


running?=?True
gameover?=?True
counter?=?0
live_cube?=?None
while?running:
????clock.tick(FPS)
????for?event?in?pygame.event.get():
????????if?event.type?==?pygame.QUIT:
????????????running?=?False
????????elif?event.type?==?pygame.KEYDOWN:
????????????if?gameover:
????????????????gameover?=?False
????????????????live_cube?=?CubeShape()
????????????????break
????????????if?event.key?==?pygame.K_LEFT:
????????????????live_cube.left()
????????????elif?event.key?==?pygame.K_RIGHT:
????????????????live_cube.right()
????????????elif?event.key?==?pygame.K_DOWN:
????????????????live_cube.down()
????????????elif?event.key?==?pygame.K_UP:
????????????????live_cube.rotate()
????????????elif?event.key?==?pygame.K_SPACE:
????????????????while?live_cube.down()?==?True:
????????????????????pass
????????????remove_full_line()

????#?level?是為了方便游戲的難度,level?越高?FPS?//?level?的值越小
????#?這樣屏幕刷新的就越快,難度就越大
????if?gameover?is?False?and?counter?%?(FPS?//?level)?==?0:
????????#?down?表示下移骨牌,返回False表示下移不成功,可能超過了屏幕或者和之前固定的
????????#?小方塊沖突了
????????if?live_cube.down()?==?False:
????????????for?cube?in?live_cube.get_all_gridpos():
????????????????screen_color_matrix[cube[0]][cube[1]]?=?live_cube.color
????????????live_cube?=?CubeShape()
????????????if?live_cube.conflict(live_cube.center):
????????????????gameover?=?True
????????????????score?=?0
????????????????live_cube?=?None
????????????????screen_color_matrix?=?[[None]?*?GRID_NUM_WIDTH?for?i?in?range(GRID_NUM_HEIGHT)]
????????#?消除滿行
????????remove_full_line()
????counter?+=?1
????#?更新屏幕
????screen.fill(BLACK)
????draw_grids()
????draw_matrix()
????draw_score()
????if?live_cube?is?not?None:
????????live_cube.draw()
????if?gameover:
????????show_welcome(screen)
????pygame.display.update()

到了這里,關(guān)于Python 竟能開發(fā)如此精美的俄羅斯方塊【附源碼】的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 物聯(lián)網(wǎng)云智能開發(fā)—MosQuitto服務(wù)器的安裝 測(cè)試 訂閱&發(fā)布及加密教程

    物聯(lián)網(wǎng)云智能開發(fā)—MosQuitto服務(wù)器的安裝 測(cè)試 訂閱&發(fā)布及加密教程

    官方介紹 Eclipse Mosquitto是一個(gè)開放源碼(EPL/EDL許可)消息代理,它實(shí)現(xiàn)了MQTT協(xié)議版本5.0、3.1.1和3.1。mosquitto是輕量級(jí)的,適用于所有設(shè)備,從低功率單板計(jì)算機(jī)到全服務(wù)器。MQTT協(xié)議提供了使用發(fā)布/訂閱模型執(zhí)行消息傳遞的輕量級(jí)方法。這使得它適用于物聯(lián)網(wǎng)消息傳遞,如低功

    2024年04月28日
    瀏覽(30)
  • 俄羅斯方塊小游戲開發(fā)

    俄羅斯方塊小游戲開發(fā)

    代碼圖: 結(jié)果圖:

    2024年02月04日
    瀏覽(23)
  • HTML5 游戲開發(fā)實(shí)戰(zhàn) | 俄羅斯方塊

    HTML5 游戲開發(fā)實(shí)戰(zhàn) | 俄羅斯方塊

    ? 俄羅斯方塊是一款風(fēng)靡全球的電視游戲機(jī)和掌上游戲機(jī)游戲,它曾經(jīng)造成的轟動(dòng)與造成的經(jīng)濟(jì)價(jià)值可以說是游戲史上的一件大事。這款游戲看似簡(jiǎn)單但卻變化無窮,游戲過程僅需要玩家將不斷下落的各種形狀的方塊移動(dòng)、翻轉(zhuǎn),如果某一行被方塊充滿了,那就將這一行消掉

    2024年02月11日
    瀏覽(24)
  • python制作俄羅斯方塊

    python制作俄羅斯方塊

    作者簡(jiǎn)介 :一名后端開發(fā)人員,每天分享后端開發(fā)以及人工智能相關(guān)技術(shù),行業(yè)前沿信息,面試寶典。 座右銘 :未來是不可確定的,慢慢來是最快的。 個(gè)人主頁(yè) :極客李華-CSDN博客 合作方式 :私聊+ 這個(gè)專欄內(nèi)容 :BAT等大廠常見后端java開發(fā)面試題詳細(xì)講解,更新數(shù)目10

    2024年02月12日
    瀏覽(24)
  • 用python制作俄羅斯方塊

    代碼如下,可以直接運(yùn)行:

    2024年02月11日
    瀏覽(26)
  • 免費(fèi)分享一套Python俄羅斯方塊源碼 PyQt5俄羅斯方塊源碼,太好玩了~

    免費(fèi)分享一套Python俄羅斯方塊源碼 PyQt5俄羅斯方塊源碼,太好玩了~

    大家好,我是java1234_小鋒老師,看到一個(gè)不錯(cuò)的Python俄羅斯方塊源碼 PyQt5俄羅斯方塊源碼,分享下哈。 【免費(fèi)】Python俄羅斯方塊源碼 PyQt5俄羅斯方塊源碼 Python小游戲源碼_嗶哩嗶哩_bilibili 【免費(fèi)】Python俄羅斯方塊源碼 PyQt5俄羅斯方塊源碼 Python小游戲源碼項(xiàng)目來自互聯(lián)網(wǎng),免

    2024年01月25日
    瀏覽(24)
  • Python課程設(shè)計(jì)之俄羅斯方塊

    Python課程設(shè)計(jì)之俄羅斯方塊

    點(diǎn)擊查看 點(diǎn)擊下載 Python課程設(shè)計(jì)之俄羅斯方塊 軟件需求 :Python環(huán)境 壓縮包內(nèi)含 :源代碼、打包好的可執(zhí)行文件、文檔報(bào)告 (1)、搭建基礎(chǔ)窗體 使用tkinter實(shí)現(xiàn)基礎(chǔ)窗體。 運(yùn)行代碼生成窗口如下 接下來需要在窗體里面,添加一個(gè)畫布容器用來“裝”俄羅斯方塊,就是讓這

    2024年02月09日
    瀏覽(26)
  • python基礎(chǔ)項(xiàng)目實(shí)戰(zhàn)-俄羅斯方塊

    python基礎(chǔ)項(xiàng)目實(shí)戰(zhàn)-俄羅斯方塊

    一、俄羅斯方塊游戲設(shè)計(jì)分析: 俄羅斯方塊是一款風(fēng)靡全球,從一開始到現(xiàn)在都一直經(jīng)久不衰的電腦、手機(jī)、掌上游戲機(jī)產(chǎn)品,是一款游戲規(guī)則簡(jiǎn)單,但又不缺乏樂趣的簡(jiǎn)單經(jīng)典小游戲,上手容易,適用范圍廣泛,人所共知。俄羅斯方塊游戲基本規(guī)則是油4個(gè)小方塊組成的7種不

    2024年02月12日
    瀏覽(24)
  • 俄羅斯方塊游戲設(shè)計(jì)與實(shí)現(xiàn)(Python)

    俄羅斯方塊游戲設(shè)計(jì)與實(shí)現(xiàn)(Python)

    目錄 第一章 緒論 1 1.1 任務(wù)概述 1 1.1.1 軟件功能 1 1.1.2 運(yùn)行環(huán)境 1 1.2 需求分析 3 1.2.1 游戲界面 3 1.2.2 菜單操作 3 1.2.3 游戲操作 3 1.3 設(shè)計(jì)目的 4 第二章 相關(guān)技術(shù)及開發(fā)工具 5 2.1 python介紹 5 2.2 python發(fā)展歷史 6 2.3 python特點(diǎn) 6 2.4 python開發(fā)環(huán)境構(gòu)建 7 第三章 概要設(shè)計(jì) 8 3.1 程序流程

    2024年02月02日
    瀏覽(42)
  • 用python寫一個(gè)俄羅斯方塊程序

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包