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

效果:

自己需要两个棋子:

服务器玩家全部代码:

# 案列使用TCP连接
# 这是服务器端

import socket
import wx
import threading
import time
from PIL import Image

#  定义套接字 s
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
Cell=40

# 定义窗口类
class MyFrame(wx.Frame):
    # 初始化这里就是生成界面,然后绑定了按钮事件,其他没了
    def __init__(self):
        super().__init__(parent=None,size=(600,600),title="五子棋:服务器")
        self.Center()
        self.panel=wx.Panel(parent=self)
        #openButton = wx.Button(parent=map, id=1, label="开房间")
        #self.Bind(wx.EVT_BUTTON, self.StartGame)
        self.panel.Bind(wx.EVT_PAINT, self.PaintBackground) # 绘图
        self.panel.Bind(wx.EVT_LEFT_DOWN,self.GoChess) # 绑定鼠标左键消息
        self.picture = [wx.Bitmap("黑.png"), wx.Bitmap("白.png")]
        # 创造二维数组用来判断自己是否获胜
        self.map = [[" ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " "] for y in range(15)]
        # 定义一个变量来标志自己是否可以走棋
        self.IsGoGame = True

        self.StartGame()


    # 画背景函数
    def PaintBackground(self,event):
        self.dc = wx.PaintDC(self.panel)
        # 创造背景
        brush = wx.Brush("white")
        self.dc.SetBackground(brush)
        self.dc.Clear()
        # 画方格线
        pen = wx.Pen(wx.Colour(0, 0, 0), 1, wx.SOLID)
        self.dc.SetPen(pen)
        for i in range(15):
            self.dc.DrawLine(0, Cell*i, 600, Cell*i)
            self.dc.DrawLine(Cell * i, 0, Cell * i, 600)


    # 在x,y坐标绘制棋子
    def PaintPiece(self,x,y):
        image = wx.StaticBitmap(self.panel, -1, self.picture[0],size=(40,40),pos=(x*Cell Cell/2,y*Cell Cell/2))
        #image.SetPosition((x*Cell Cell/2,y*Cell Cell/2))

    # 玩家自己走棋
    def GoChess(self,event):
        #SetPosition(event.GetPosition())
        if self.IsGoGame:
            pos = event.GetPosition()  # 在x,y坐标绘制棋子
            x = int((pos.x - Cell / 2) // Cell)
            y = int((pos.y - Cell / 2) // Cell)
            self.PaintPiece(x, y)

            # 下子后,向客户端发送位置
            msg = str(x)   ","   str(y)
            self.conn.send(msg.encode())  # 给客户端发送信息
            print("服务器发送:", msg)
            self.map[x][y]="a"
            # 判断是否胜利
            if self.win_lose("a"):
                self.one_Dialog("win")
            self.IsGoGame=False
        else:
            self.one_Dialog("notGo")

    # 开启服务器端函数
    def StartGame(self):
        self.otherNum=0
        self.image=[]
        for item in range(50):
            self.image.append(wx.StaticBitmap(self.panel, -1, self.picture[1], size=(40, 40),pos=(-100,-100)))
        threadGame=threading.Thread(target=self.thread_body,name="Srever")
        threadGame.start()

    def thread_body(self):
        s.bind(("127.0.0.1", 8888))  # 绑定IP和端口(参数为二元组),就是寻址
        s.listen(5)  # 因为是TCP,所有要监听端口
        print("服务器启动·····")
        self.conn, self.addess = s.accept()  # 等待客户端连接(参数为最大连接数),返回一个二元组(新的socket对象 客户端地址)
        while True:
            data = self.conn.recv(1024)  # 接受1024字节序列数据(这个函数阻塞,直到接受到数据)
            if len(data) != 0:
                msg = data.decode()
                print("服务器接收:",msg)
                msg = msg.split(",")
                #self.PaintPiece(int(msg[0]), int(msg[1]))
                #image = wx.StaticBitmap(self.panel, -1, self.picture[0], size=(40, 40))

                # 设置原来实例化好的棋子的位置
                self.image[self.otherNum].SetPosition((int(msg[0]) * Cell   Cell / 2, int(msg[1])* Cell   Cell / 2))
                self.otherNum =1
                self.map[int(msg[0])][int(msg[1])] = "b"
                if self.win_lose("b"): # 判断对方玩家是否胜利
                    self.one_Dialog("lose")
                self.IsGoGame = True # 接收消息后 玩家能够走棋

            #time.sleep(2)

    def one_Dialog(self,msg):
        if msg=="win":
            dlg = wx.MessageDialog(None, u"你胜利了!", u"恭喜", wx.YES_NO | wx.ICON_QUESTION)
            if dlg.ShowModal() == wx.ID_YES:
                self.Close(True)
            dlg.Destroy()
        elif msg=="lose":
            dlg = wx.MessageDialog(None, u"你输了!", u"很遗憾", wx.YES_NO | wx.ICON_QUESTION)
            if dlg.ShowModal() == wx.ID_YES:
                self.Close(True)
            dlg.Destroy()
        elif msg == "notGo":
            dlg = wx.MessageDialog(None, u"等待对方下棋!", u"提示", wx.YES_NO | wx.ICON_QUESTION)
            if dlg.ShowModal() == wx.ID_YES:
                #self.Close(True)
                dlg.Destroy()

    def win_lose(self,msg):
        a = str(msg)
        print("a=", a)
        for i in range(0, 11):
            for j in range(0, 11):
                if self.map[i][j] == a and self.map[i   1][j   1] == a and self.map[i   2][j   2] == a and \
                                self.map[i   3][
                                            j   3] == a and self.map[i   4][j   4] == a:
                    print("x=y轴上形成五子连珠")
                    return True
        for i in range(4, 15):
            for j in range(0, 11):
                if self.map[i][j] == a and self.map[i - 1][j   1] == a and self.map[i - 2][j   2] == a and \
                                self.map[i - 3][
                                            j   3] == a and self.map[i - 4][j   4] == a:
                    print("x=-y轴上形成五子连珠")
                    return True
        for i in range(0, 15):
            for j in range(4, 15):
                if self.map[i][j] == a and self.map[i][j - 1] == a and self.map[i][j - 2] == a and self.map[i][
                            j - 2] == a and self.map[i][
                            j - 4] == a:
                    print("Y轴上形成了五子连珠")
                    return True
        for i in range(0, 11):
            for j in range(0, 15):
                if self.map[i][j] == a and self.map[i   1][j] == a and self.map[i   2][j] == a and \
                                self.map[i   3][j] == a and \
                                self.map[i   4][j] == a:
                    print("X轴形成五子连珠")
                    return True
        return False


# 应用程序
class App(wx.App):
    def OnInit(self):
        frame=MyFrame()
        frame.Show()
        return True
    def OnExit(self):
        s.close() # 关闭socket对象
        return 0

# 进入main函数运行:循环
if __name__=="__main__":
    app=App()
    app.MainLoop()

客户端玩家全部代码:

# 案列使用TCP连接
# 这是服务器端

import socket
import wx
import threading
import time
from PIL import Image


#  定义套接字 s
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
Cell=40

# 定义窗口类
class MyFrame(wx.Frame):
    # 初始化这里就是生成界面,然后绑定了按钮事件,其他没了
    def __init__(self):
        super().__init__(parent=None,size=(600,600),title="五子棋:客户端")
        self.Center()
        self.panel=wx.Panel(parent=self)
        #openButton = wx.Button(parent=map, id=1, label="开房间")
        #self.Bind(wx.EVT_BUTTON, self.StartGame)
        self.panel.Bind(wx.EVT_PAINT, self.PaintBackground) # 绘图
        self.panel.Bind(wx.EVT_LEFT_DOWN,self.GoChess) # 绑定鼠标左键消息
        self.picture=[wx.Bitmap("白.png"),wx.Bitmap("黑.png")]

        # 创造二维数组用来判断自己是否获胜
        self.map = [[" ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " ", " "] for y in range(15)]
        # 定义一个变量来标志自己是否可以走棋
        self.IsGoGame=False

        self.StartGame()

    # 画背景函数
    def PaintBackground(self,event):
        self.dc = wx.PaintDC(self.panel)
        # 创造背景
        brush = wx.Brush("white")
        self.dc.SetBackground(brush)
        self.dc.Clear()
        # 画方格线
        pen = wx.Pen(wx.Colour(0, 0, 0), 1, wx.SOLID)
        self.dc.SetPen(pen)
        for i in range(15):
            self.dc.DrawLine(0, Cell*i, 600, Cell*i)
            self.dc.DrawLine(Cell * i, 0, Cell * i, 600)

    # 在x,y坐标绘制棋子
    def PaintPiece(self,x,y):
        image = wx.StaticBitmap(self.panel, -1,self.picture[0] ,size=(40,40),pos=(x*Cell Cell/2,y*Cell Cell/2))
        #image.SetPosition()

    def GoChess(self,event):
        #SetPosition(event.GetPosition())
        if self.IsGoGame: # 轮到自己下棋
            pos = event.GetPosition()  # 在x,y坐标绘制棋子
            x=int((pos.x-Cell/2)//Cell)
            y=int((pos.y-Cell/2)//Cell)
            self.PaintPiece(x, y)

            # 下子后,向客户端发送位置
            msg=str(x) "," str(y)
            s.send(msg.encode())  # 给客户端发送信息
            print("客户端发送:", msg)
            self.map[x][y] = "a"
            # 判断是否胜利
            if self.win_lose("a"):
                self.one_Dialog("win")
            self.IsGoGame=False
        else:
            self.one_Dialog("notGo")


    # 开启服务器端函数
    def StartGame(self):
        self.image=[]
        self.otherNum = 0
        for item in range(50):
            self.image.append(wx.StaticBitmap(self.panel, -1, self.picture[1], size=(40, 40), pos=(-100, -100)))
        while True:
            try:
                s.connect(("127.0.0.1", 8888))
                break
            except:
                print("等待服务器启动~")
        threadGame = threading.Thread(target=self.thread_body, name="Client")
        threadGame.start()
        return

    def thread_body(self):
        while True:
            data = s.recv(1024)  # 等待接收服务器端信息
            if len(data) != 0:
                msg=data.decode()
                print("客户端接收:", msg)
                msg = msg.split(",")
                #self.PaintPiece(int(msg[0]), int(msg[1]))
                #image = wx.StaticBitmap(self.panel, -1, self.picture[0], size=(40, 40))
                self.image[self.otherNum].SetPosition((int(msg[0]) * Cell   Cell / 2, int(msg[1]) * Cell   Cell / 2))
                self.otherNum  = 1
                self.map[int(msg[0])][int(msg[1])] = "b"
                if self.win_lose("b"):
                    self.one_Dialog("lose")
                self.IsGoGame=True
            #time.sleep(2)

    def one_Dialog(self, msg):
        if msg == "win":
            dlg = wx.MessageDialog(None, u"你胜利了!", u"恭喜", wx.YES_NO | wx.ICON_QUESTION)
            if dlg.ShowModal() == wx.ID_YES:
                self.Close(True)
            dlg.Destroy()
        if msg == "lose":
            dlg = wx.MessageDialog(None, u"你输了!", u"很遗憾", wx.YES_NO | wx.ICON_QUESTION)
            if dlg.ShowModal() == wx.ID_YES:
                self.Close(True)
            dlg.Destroy()
        if msg == "notGo":
            dlg = wx.MessageDialog(None, u"等待对方下棋!", u"提示", wx.YES_NO | wx.ICON_QUESTION)
            if dlg.ShowModal() == wx.ID_YES:
                #self.Close(True)
                dlg.Destroy()

    # 判断整个棋盘的输赢
    def win_lose(self,msg):
        a = str(msg)
        print("a=", a)
        for i in range(0, 11):
            for j in range(0, 11):
                if self.map[i][j] == a and self.map[i   1][j   1] == a and self.map[i   2][j   2] == a and self.map[i   3][
                            j   3] == a and self.map[i   4][j   4] == a:
                    print("x=y轴上形成五子连珠")
                    return True
        for i in range(4, 15):
            for j in range(0, 11):
                if self.map[i][j] == a and self.map[i - 1][j   1] == a and self.map[i - 2][j   2] == a and self.map[i - 3][
                            j   3] == a and self.map[i - 4][j   4] == a:
                    print("x=-y轴上形成五子连珠")
                    return True
        for i in range(0, 15):
            for j in range(4, 15):
                if self.map[i][j] == a and self.map[i][j - 1] == a and self.map[i][j - 2] == a and self.map[i][j - 2] == a and self.map[i][
                            j - 4] == a:
                    print("Y轴上形成了五子连珠")
                    return True
        for i in range(0, 11):
            for j in range(0, 15):
                if self.map[i][j] == a and self.map[i   1][j] == a and self.map[i   2][j] == a and self.map[i   3][j] == a and \
                                self.map[i   4][j] == a:
                    print("X轴形成五子连珠")
                    return True
        return False

# 应用程序
class App(wx.App):
    def OnInit(self):
        frame=MyFrame()
        frame.Show()
        return True
    def OnExit(self):
        s.close() # 关闭socket对象
        return 0

# 进入main函数运行:循环
if __name__=="__main__":
    app=App()
    app.MainLoop()

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

Python实现双人五子棋对局的更多相关文章

  1. XCode 3.2 Ruby和Python模板

    在xcode3.2下,我的ObjectiveCPython/Ruby项目仍然可以打开更新和编译,但是你无法创建新项目.鉴于xcode3.2中缺少ruby和python的所有痕迹(即创建项目并添加新的ruby/python文件),是否有一种简单的方法可以再次安装模板?我发现了一些关于将它们复制到某个文件夹的信息,但我似乎无法让它工作,我怀疑文件夹的位置已经改变为3.2.解决方法3.2中的应用程序模板

  2. Swift基本使用-函数和闭包(三)

    声明函数和其他脚本语言有相似的地方,比较明显的地方是声明函数的关键字swift也出现了Python中的组元,可以通过一个组元返回多个值。传递可变参数,函数以数组的形式获取参数swift中函数可以嵌套,被嵌套的函数可以访问外部函数的变量。可以通过函数的潜逃来重构过长或者太复杂的函数。

  3. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  4. Swift、Go、Julia与R能否挑战 Python 的王者地位

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 红薯因 Swift 重写开源中国失败,貌似欲改用 Python

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  6. 你没看错:Swift可以直接调用Python函数库

    上周Perfect又推出了新一轮服务器端Swift增强函数库:Perfect-Python。对,你没看错,在服务器端Swift其实可以轻松从其他语种的函数库中直接拿来调用,不需要修改任何内容。以如下python脚本为例:Perfect-Python可以用下列方法封装并调用以上函数,您所需要注意的仅仅是其函数名称以及参数。

  7. Swift中的列表解析

    在Swift中完成这个的最简单的方法是什么?我在寻找类似的东西:从Swift2.x开始,有一些与你的Python样式列表解析相当的东西。(在这个意义上,它更像是Python的xrange。如果你想保持集合懒惰一路通过,只是这样说:与Python中的列表解析语法不同,Swift中的这些操作遵循与其他操作相同的语法。

  8. swift抛出终端的python错误

    每当我尝试启动与python相关的swift时,我都会收到错误.我该如何解决?

  9. 在Android上用Java嵌入Python

    解决方法看看this,它适用于J2SE,你可以尝试在Android上运行.

  10. 在android studio中使用python代码构建android应用程序

    我有一些python代码和它的机器人,我正在寻找一种方法来使用android项目中的那些python代码.有没有办法做到这一点!?解决方法有两种主要工具可供使用,它们彼此不同:>QPython>Kivy使用Kivy,大致相同的代码也可以部署到IOS.

随机推荐

  1. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  2. python数学建模之三大模型与十大常用算法详情

    这篇文章主要介绍了python数学建模之三大模型与十大常用算法详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感想取得小伙伴可以参考一下

  3. Python爬取奶茶店数据分析哪家最好喝以及性价比

    这篇文章主要介绍了用Python告诉你奶茶哪家最好喝性价比最高,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧

  4. 使用pyinstaller打包.exe文件的详细教程

    PyInstaller是一个跨平台的Python应用打包工具,能够把 Python 脚本及其所在的 Python 解释器打包成可执行文件,下面这篇文章主要给大家介绍了关于使用pyinstaller打包.exe文件的相关资料,需要的朋友可以参考下

  5. 基于Python实现射击小游戏的制作

    这篇文章主要介绍了如何利用Python制作一个自己专属的第一人称射击小游戏,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手试一试

  6. Python list append方法之给列表追加元素

    这篇文章主要介绍了Python list append方法如何给列表追加元素,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  7. Pytest+Request+Allure+Jenkins实现接口自动化

    这篇文章介绍了Pytest+Request+Allure+Jenkins实现接口自动化的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. 利用python实现简单的情感分析实例教程

    商品评论挖掘、电影推荐、股市预测……情感分析大有用武之地,下面这篇文章主要给大家介绍了关于利用python实现简单的情感分析的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

  9. 利用Python上传日志并监控告警的方法详解

    这篇文章将详细为大家介绍如何通过阿里云日志服务搭建一套通过Python上传日志、配置日志告警的监控服务,感兴趣的小伙伴可以了解一下

  10. Pycharm中运行程序在Python console中执行,不是直接Run问题

    这篇文章主要介绍了Pycharm中运行程序在Python console中执行,不是直接Run问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

返回
顶部