我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python pygame实现五子棋双人联机

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python pygame实现五子棋双人联机

本文实例为大家分享了python pygame实现五子棋双人联机的具体代码,供大家参考,具体内容如下

同一局域网内,服务端开启时,另一机器将IP地址HOST改为服务端对应的IP地址、端口号与服务端的保持一致即可实现双人联机。(IP地址查询方式:菜单栏输入cmd,cmd窗口输入ipconfig找到无线网络下的IPv4地址)

服务端:

# -*- coding: utf-8 -*-
"""
Created on Tue Jun  8 14:03:09 2021

@author: Administrator
"""
import pygame
import sys
from pygame.locals import *
from collections import Counter
from socket import *
from time import ctime
import json
import select
import socket

#界面初始化
screen=pygame.display.set_mode((400,450))
pygame.display.set_caption('五子棋')
pygame.init()

#图片导入
img_board=pygame.image.load('F:/images/五子棋/chess_board.png')
img_bchess=pygame.image.load('F:/images/五子棋/black_chess.jpg')
img_wchess=pygame.image.load('F:/images/五子棋/white_chess.jpg')

#颜色
white=(255,255,255)
black=(0,0,0)

#用于传送的数据
msg=[]

#棋盘定义
chess_board=[[]]
def set_chess_board():
    x,y=0,0
    while True:
        if x==400:
            x=0
            y+=40
            if y<400:
                chess_board.append([])
        if y==400:
            break
        chess_board[-1].append([x,y])
        x+=40
set_chess_board()

#棋盘格子是否落子
chess_exist=[[0 for i in range(10)]for j in range(10)]
#黑白棋子初始化
black_chess,white_chess=[],[]
#棋子类型
chess_kind=1    #1为黑棋,0为白棋
wcx,wcy,bcx,bcy=[],[],[],[]   #white_chess_x

def draw_board():
    for i in chess_board:
        for j in i:
            screen.blit(img_board,(j[0],j[1]))
            pygame.display.update()

#默认棋子类型为1
def set_chess():
    if event.type==MOUSEBUTTONDOWN:
        pos=pygame.mouse.get_pos()
        for i in range(len(chess_board)):
            for j in range(len(chess_board[i])):
                if chess_board[i][j][0]<pos[0]<chess_board[i][j][0]+40 and chess_board[i][j][1]<pos[1]<chess_board[i][j][1]+40:
                    if chess_exist[i][j]==0:
                        black_chess.append([i,j])
                        bcx.append(black_chess[-1][0])
                        bcy.append(black_chess[-1][1])
                        msg.extend((i,j))
                        chess_exist[i][j]=1
                        pygame.display.update()
                        return 1

def draw_chess():
    for i in white_chess:
        screen.blit(img_wchess,(i[1]*40,i[0]*40))
    for i in black_chess:
        screen.blit(img_bchess,(i[1]*40,i[0]*40))
    pygame.display.update()

def row_column_win(x,m,n,chess):
    for i in x:
        if x[i]>=5:
            xy=[]
            for j in chess:
                if j[m]==i:
                    xy.append(j[n])
            xy.sort()
            count=0
            for j in range(len(xy)-1):
                if xy[j]+1==xy[j+1]:
                    count+=1
                else:
                    count=0
            if count>=4:
                return 1

def xiejiao_win(chess):
    x,y=[],[]
    chess.sort()
    for i in chess:
        x.append(i[0])
        y.append(i[1])
    c,first,last=0,0,0
    for i in range(len(x)-1):
        if x[i+1]!=x[i]:
            if x[i]+1==x[i+1]:
                c+=1
                last=i+1
            else:
                if c<4:
                    first=i+1
                    c=0
                else:
                    last=i
                    print(last)
                    break
        else:
            last=i+1
    if c>=4:
        dis=[]
        for i in range(first,last+1):
            dis.append(x[i]-y[i])
        count=Counter(dis)
        for i in count:
            if count[i]>=5:
                return 1
        dis=[]
        x2=[i*(-1) for i in x]
        for i in range(first,last+1):
            dis.append(x2[i]-y[i])
        count=Counter(dis)
        for i in count:
            if count[i]>=5:
                return 1

def gameover():
    wcx_count,wcy_count,bcx_count,bcy_count=Counter(wcx),Counter(wcy),Counter(bcx),Counter(bcy)
    if row_column_win(wcx_count,0,1,white_chess)==1:
        return 0
    elif row_column_win(bcx_count,0,1,black_chess)==1:
        return 1
    elif row_column_win(wcy_count,1,0,white_chess)==1:
        return 0
    elif row_column_win(bcy_count,1,0,black_chess)==1:
        return 1
    elif xiejiao_win(white_chess)==1:
        return 0
    elif xiejiao_win(black_chess)==1:
        return 1

def draw_text(text,x,y,size):
    pygame.font.init()
    fontObj=pygame.font.SysFont('SimHei',size )
    textSurfaceObj=fontObj.render(text, True, white,black)
    textRectObj=textSurfaceObj.get_rect()
    textRectObj.center=(x,y)
    screen.blit(textSurfaceObj, textRectObj)
    pygame.display.update()

#定义服务器名称
HOST = '0.0.0.0'
PORT = 400
BUFSIZE = 1024
ADDR = (HOST,PORT)

#定义服务器属性
tcpsersock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
tcpsersock.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)  # 对socket的配置重用ip和端口号
tcpsersock.bind(ADDR)
tcpsersock.listen(1)
inputs=[tcpsersock]
print(inputs)

draw_board()
settable=1
link=False
while True:
    rs,ws,es=select.select(inputs, [], [],0)
    for r in rs:
        if r is tcpsersock:
            link=True
            print('new ser')
            tcpcliscock, addr = tcpsersock.accept()
            inputs.append(tcpcliscock)
        else:
            data,addr=r.recvfrom(BUFSIZE)
            disconnected=not data
            draw_text('你的回合',200,420,15)
            if disconnected:
                inputs.remove(r)
                draw_text('对手掉线',200,420,15)
                while True:
                    for event in pygame.event.get():
                        if event.type==QUIT:
                            pygame.quit()
                            sys.exit()
            else:
                data=json.loads(data)
                settable=1
                white_chess.append(data)
                wcx.append(data[0])
                wcy.append(data[1])
    for event in pygame.event.get():
        if event.type==QUIT:
            pygame.quit()
            sys.exit()
            tcpsersock.close()
        if link==True:
            if settable==1:
                if set_chess()==1:
                    draw_text('对手回合',200,420,15)
                    settable=0
                    msg1=json.dumps(msg)
                    tcpcliscock.sendto(msg1.encode(),ADDR)
                    msg=[]       
    draw_chess()
    if gameover()==1:
        draw_text('你赢了!',200,420,15)
        while True:
            for event in pygame.event.get():
                if event.type==QUIT:
                    pygame.quit()
                    sys.exit()
    elif gameover()==0:
        draw_text('你输了!',200,420,15)
        while True:
            for event in pygame.event.get():
                if event.type==QUIT:
                    pygame.quit()
                    sys.exit()
tcpcliscock.close()
tcpsersock.close()

客户端:

# -*- coding: utf-8 -*-
"""
Created on Tue Jun  8 14:03:09 2021

@author: Administrator
"""
import pygame
import sys
from pygame.locals import *
from collections import Counter
from socket import *
from time import ctime
import json
import select
import socket
import time

#界面初始化
screen=pygame.display.set_mode((400,450))
pygame.display.set_caption('五子棋')
pygame.init()

#图片导入
img_board=pygame.image.load('F:/images/五子棋/chess_board.png')
img_bchess=pygame.image.load('F:/images/五子棋/black_chess.jpg')
img_wchess=pygame.image.load('F:/images/五子棋/white_chess.jpg')

#颜色
white=(255,255,255)
black=(0,0,0)

#用于传送的数据
msg=[]

#棋盘定义
chess_board=[[]]
def set_chess_board():
    x,y=0,0
    while True:
        if x==400:
            x=0
            y+=40
            if y<400:
                chess_board.append([])
        if y==400:
            break
        chess_board[-1].append([x,y])
        x+=40
set_chess_board()

#棋盘格子是否落子
chess_exist=[[0 for i in range(10)]for j in range(10)]
#黑白棋子初始化
black_chess,white_chess=[],[]
#棋子类型
chess_kind=1    #1为黑棋,0为白棋
wcx,wcy,bcx,bcy=[],[],[],[]   #white_chess_x

def draw_board():
    for i in chess_board:
        for j in i:
            screen.blit(img_board,(j[0],j[1]))
            pygame.display.update()

#默认棋子类型为0
def set_chess():
    if event.type==MOUSEBUTTONDOWN:
        pos=pygame.mouse.get_pos()
        for i in range(len(chess_board)):
            for j in range(len(chess_board[i])):
                if chess_board[i][j][0]<pos[0]<chess_board[i][j][0]+40 and chess_board[i][j][1]<pos[1]<chess_board[i][j][1]+40:
                    if chess_exist[i][j]==0:
                        white_chess.append([i,j])
                        wcx.append(white_chess[-1][0])
                        wcy.append(white_chess[-1][1])
                        msg.extend((i,j))
                        chess_exist[i][j]=1
                        pygame.display.update()
                        return 1

def draw_chess():
    for i in white_chess:
        screen.blit(img_wchess,(i[1]*40,i[0]*40))
    for i in black_chess:
        screen.blit(img_bchess,(i[1]*40,i[0]*40))
    pygame.display.update()

def row_column_win(x,m,n,chess):
    for i in x:
        if x[i]>=5:
            xy=[]
            for j in chess:
                if j[m]==i:
                    xy.append(j[n])
            xy.sort()
            count=0
            for j in range(len(xy)-1):
                if xy[j]+1==xy[j+1]:
                    count+=1
                else:
                    count=0
            if count>=4:
                return 1

def xiejiao_win(chess):
    x,y=[],[]
    chess.sort()
    for i in chess:
        x.append(i[0])
        y.append(i[1])
    c,first,last=0,0,0
    for i in range(len(x)-1):
        if x[i+1]!=x[i]:
            if x[i]+1==x[i+1]:
                c+=1
                last=i+1
            else:
                if c<4:
                    first=i+1
                    c=0
                else:
                    last=i
                    print(last)
                    break
        else:
            last=i+1
    if c>=4:
        dis=[]
        for i in range(first,last+1):
            dis.append(x[i]-y[i])
        count=Counter(dis)
        for i in count:
            if count[i]>=5:
                return 1
        dis=[]
        x2=[i*(-1) for i in x]
        for i in range(first,last+1):
            dis.append(x2[i]-y[i])
        count=Counter(dis)
        for i in count:
            if count[i]>=5:
                return 1

def gameover():
    wcx_count,wcy_count,bcx_count,bcy_count=Counter(wcx),Counter(wcy),Counter(bcx),Counter(bcy)
    if row_column_win(wcx_count,0,1,white_chess)==1:
        return 1
    elif row_column_win(bcx_count,0,1,black_chess)==1:
        return 0
    elif row_column_win(wcy_count,1,0,white_chess)==1:
        return 1
    elif row_column_win(bcy_count,1,0,black_chess)==1:
        return 0
    elif xiejiao_win(white_chess)==1:
        return 1
    elif xiejiao_win(black_chess)==1:
        return 0

def draw_text(text,x,y,size):
    pygame.font.init()
    fontObj=pygame.font.SysFont('SimHei',size )
    textSurfaceObj=fontObj.render(text, True, white,black)
    textRectObj=textSurfaceObj.get_rect()
    textRectObj.center=(x,y)
    screen.blit(textSurfaceObj, textRectObj)
    pygame.display.update()

#定义客户端名称
HOST = '10.203.111.180'
PORT = 400
BUFSIZE = 1024
ADDR = (HOST,PORT)

#连接服务器
tcpCliSock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
tcpCliSock.connect(ADDR)
inputs=[tcpCliSock]

draw_board()
settable=0
while True:
    rs,ws,es=select.select(inputs,[],[],0)
    for r in rs:
        if r is tcpCliSock:
            data,addr = r.recvfrom(BUFSIZE)
            draw_text('你的回合',200,420,15)
            data=json.loads(data)
            settable=1
            black_chess.append(data)
            bcx.append(data[0])
            bcy.append(data[1])
    for event in pygame.event.get():
        if event.type==QUIT:
            tcpCliSock.close()
            pygame.quit()
            sys.exit()
        if settable==1:
            if set_chess()==1:
                draw_text('对手回合',200,420,15)
                settable=0
                msg1=json.dumps(msg)
                tcpCliSock.sendto(msg1.encode(),ADDR)
                msg=[]
    draw_chess()
    if gameover()==1:
        draw_text('你赢了!',200,420,15)
        while True:
            for event in pygame.event.get():
                if event.type==QUIT:
                    pygame.quit()
                    sys.exit()
    elif gameover()==0:
        draw_text('你输了!',200,420,15)
        while True:
            for event in pygame.event.get():
                if event.type==QUIT:
                    pygame.quit()
                    sys.exit()

背景:

黑棋:

白棋:

效果演示:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python pygame实现五子棋双人联机

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么用python pygame实现五子棋双人联机

这篇文章主要讲解了“怎么用python pygame实现五子棋双人联机”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用python pygame实现五子棋双人联机”吧!同一局域网内,服务
2023-06-30

Python怎么实现双人五子棋对局

这篇文章主要介绍“Python怎么实现双人五子棋对局”,在日常操作中,相信很多人在Python怎么实现双人五子棋对局问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python怎么实现双人五子棋对局”的疑惑有所
2023-06-30

python怎么实现五子棋双人对弈

本文小编为大家详细介绍“python怎么实现五子棋双人对弈”,内容详细,步骤清晰,细节处理妥当,希望这篇“python怎么实现五子棋双人对弈”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。我用的是pygame模块来
2023-06-30

Python+Pygame实现彩色五子棋游戏

这篇文章主要为大家详细介绍了如何溧阳Python和Pygame实现彩色五子棋游戏,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
2023-02-10

java如何实现联机五子棋

这篇文章主要介绍“java如何实现联机五子棋”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“java如何实现联机五子棋”文章能帮助大家解决问题。下面是客户端运行的效果:这里是代码包的结构:接着我来依次
2023-06-30

Python如何实现五子棋人机对战和人人对战

这篇文章主要介绍“Python如何实现五子棋人机对战和人人对战”,在日常操作中,相信很多人在Python如何实现五子棋人机对战和人人对战问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python如何实现五子棋
2023-06-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录