Matlab实现简易纪念碑谷游戏的示例代码

按上下左右键(↑↓←→)移动物块

按AD键转动视角

游戏效果如图所示原本无法通过的路径经过视角调整即可通过

完整代码

function maze4
global maze;
global GUI;
global role;
GUI.fig=figure('units','pixels',...
        'position',[350 100 500 500],...
        'Numbertitle','off',...
        'name','maze',...
        'Color',[0 0 0],...
        'resize','off');
        %        'menubar','none',...
GUI.axes=axes('Units','pixels',...
        'parent',GUI.fig,...
        'Color',[0.05 0.05 0.05],...
        'Position',[0 0 500 500],...
        'Box','on', ...
        'XLim',[0 10],...
        'YLim',[0 10],...
        'ZLim',[-1 8],...
        'XColor',[0.05 0.05 0.05],...
        'YColor',[0.05 0.05 0.05],...
        'ZColor',[0.05 0.05 0.05],...
        'xtick',[],'ytick',[],'ztick',[]);
hold on;axis equal
plotcube([10 10,0.5],[0 0 -0.5],1,[0.85 0.85 0.87]);

maze.layer0.map=ones(10,10);
maze.layer1.map=[0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 1 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 1 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 1 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 1 0 0 0 0 1 0 0];
maze.layer2.map=[0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 1 0 0 0;
                 0 0 0 0 0 1 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 1 1 0 0 0 0 0 0 0;
                 0 0 1 1 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 1 0 0 0 0 1 0 0];
maze.layer3.map=[0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 1 1 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 1 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 1 0 0 0 0 1 0 0];
maze.layer4.map=[0 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 1 0 0 1;
                 0 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 1 0;
                 0 0 0 0 0 0 0 0 0 0;
                 1 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 1 0 0 0 0 1 0 0];
maze.layer5.map=[0 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 0 0 0 1;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 1 0;
                 0 0 0 0 0 0 0 0 1 0;
                 0 0 0 0 0 0 0 0 0 0;
                 0 0 0 0 0 0 0 0 0 1;
                 1 0 0 0 0 0 0 0 0 0;
                 0 1 0 0 0 0 0 1 0 0];
maze.layer6.map=[0 0 0 0 0 0 0 0 0 1;
                 1 1 1 0 0 0 0 0 0 0;
                 1 0 0 0 0 0 0 0 0 0;
                 1 0 0 0 0 1 0 0 0 0;
                 1 1 0 0 0 1 0 0 0 0;
                 0 0 0 0 0 1 0 0 0 1;
                 0 0 0 0 0 1 0 0 0 1;
                 0 0 0 0 1 0 0 1 0 1;
                 0 0 0 0 1 0 0 1 0 0;
                 1 0 0 0 1 1 1 1 0 0];
maze.layer7.map=zeros(10,10);
maze.layer8.map=zeros(10,10);                 

 for i=1:6
    [x,y]=find(maze.(['layer',num2str(i)]).map==1);
    maze.(['layer',num2str(i)]).cube.num=sum(sum(maze.(['layer',num2str(i)]).map));
    maze.(['layer',num2str(i)]).cube.pos=[x,y,ones(maze.(['layer',num2str(i)]).cube.num,1).*i];
    maze.(['layer',num2str(i)]).cube.color=[0.85 0.85 0.95];
    maze.(['layer',num2str(i)]).cube.size=[1 1 1];
    maze.(['layer',num2str(i)]).cube.alpha=1;

    tempSize =maze.(['layer',num2str(i)]).cube.size;
    tempPos  =maze.(['layer',num2str(i)]).cube.pos;
    tempAlpha=maze.(['layer',num2str(i)]).cube.alpha;
    tempColor=maze.(['layer',num2str(i)]).cube.color;
    tempNum  =maze.(['layer',num2str(i)]).cube.num;
    arrayfun(@(i)plotcube(tempSize,tempPos(i,:)-tempSize,tempAlpha,tempColor),1:tempNum);
 end

ax=GUI.axes;
ax.CameraPosition=[39.4959  -29.1496   71.8289];
maze.scene=0;

moveDirect=[-1 0 0;0 1 0;1 0 0;0 -1 0];
role.pos=[1,1,1];
role.cubex=[0 1 1 0 0 0;1 1 0 0 1 1;1 1 0 0 1 1;0 1 1 0 0 0];
role.cubey=[0 0 1 0 0 0;0 1 1 1 0 0;0 1 1 1 1 1;0 0 1 0 1 1];
role.cubez=[0 0 0 0 0 1;0 0 0 0 0 1;1 1 1 1 0 1;1 1 1 1 0 1];
fill3(role.cubex+role.pos(1)-1,...
      role.cubey+role.pos(2)-1,...
      role.cubez+role.pos(3)-1,[0.65 0.65 0.87],'tag','role')
fill3(role.cubex+1-1,...
      role.cubey+10-1,...
      role.cubez+7-1,[0.85 0.65 0.67])

while(0)
pause(2)
disp(ax.CameraPosition)
end

set(gcf, 'KeyPressFcn', @key);
    function key(~,event)
        tempRolePos=role.pos;
        switch event.Key
            case 'uparrow',tempRolePos=role.pos+moveDirect(1,:);
            case 'rightarrow',tempRolePos=role.pos+moveDirect(2,:);
            case 'downarrow',tempRolePos=role.pos+moveDirect(3,:);
            case 'leftarrow',tempRolePos=role.pos+moveDirect(4,:);
            case 'a'
                for j=1:30
                    pause(0.02)
                    tempCamPos=ax.CameraPosition;
                    ax.CameraPosition(1)=tempCamPos(1)*cos(pi/60)-tempCamPos(2)*sin(pi/60);
                    ax.CameraPosition(2)=tempCamPos(1)*sin(pi/60)+tempCamPos(2)*cos(pi/60);
                end
                maze.scene=mod(maze.scene+1,4);
                moveDirect=[moveDirect(end,:);moveDirect(1:3,:)];
            case 'd'
                for j=1:30
                    pause(0.02)
                    tempCamPos=ax.CameraPosition;
                    ax.CameraPosition(1)=tempCamPos(1)*cos(-pi/60)-tempCamPos(2)*sin(-pi/60);
                    ax.CameraPosition(2)=tempCamPos(1)*sin(-pi/60)+tempCamPos(2)*cos(-pi/60);
                end
                maze.scene=mod(maze.scene+3,4);
                moveDirect=[moveDirect(2:end,:);moveDirect(1,:)];
        end
        switch maze.scene
            case 0,ax.CameraPosition=[39.4959  -29.1496   71.8289];
            case 2,ax.CameraPosition=[-39.8792   27.4237   70.6419];
        end
        switch maze.scene
            case 0
                switch 1
                    case all(tempRolePos==changePos(role.pos,tempRolePos,0))
                        role.pos=changePos(role.pos,tempRolePos,0);

                    case specialChange(tempRolePos,[-1 2 -2],[0 1 0])
                    case specialChange(tempRolePos,[-2 1 -2],[-1 0 0])

                    case all(tempRolePos+[0 0 1]==changePos(role.pos,tempRolePos+[0 0 1],1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 1],1);
                    case all(tempRolePos+[0 0 -1]==changePos(role.pos,tempRolePos+[0 0 -1],-1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 -1],-1);
                end

            case 1
                switch 1
                    case all(tempRolePos+[0 0 1]==changePos(role.pos,tempRolePos+[0 0 1],1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 1],1);
                    case all(tempRolePos==changePos(role.pos,tempRolePos,0))
                        role.pos=changePos(role.pos,tempRolePos,0);
                    case all(tempRolePos+[0 0 -1]==changePos(role.pos,tempRolePos+[0 0 -1],-1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 -1],-1);
                end

            case 2
                switch 1
                    case all(tempRolePos==changePos(role.pos,tempRolePos,0))
                        role.pos=changePos(role.pos,tempRolePos,0);

                    case specialChange(tempRolePos,[-3 1 3],[-1 0 0])
                    case specialChange(tempRolePos,[2 -2 -2],[0 -1 0])

                    case all(tempRolePos+[0 0 1]==changePos(role.pos,tempRolePos+[0 0 1],1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 1],1);
                    case all(tempRolePos+[0 0 -1]==changePos(role.pos,tempRolePos+[0 0 -1],-1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 -1],-1);
                end

            case 3
                switch 1
                    case all(tempRolePos+[0 0 1]==changePos(role.pos,tempRolePos+[0 0 1],1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 1],1);
                    case all(tempRolePos==changePos(role.pos,tempRolePos,0))
                        role.pos=changePos(role.pos,tempRolePos,0);
                    case all(tempRolePos+[0 0 -1]==changePos(role.pos,tempRolePos+[0 0 -1],-1))
                        role.pos=changePos(role.pos,tempRolePos+[0 0 -1],-1);
                end
        end

        delete(findobj('tag','role'));
        fill3(role.cubex+role.pos(1)-1,...
              role.cubey+role.pos(2)-1,...
              role.cubez+role.pos(3)-1,[0.65 0.65 0.87],'tag','role')
    end

function bool=specialChange(tempRolePos,spDir,Dir)
    bool=0;
    dir=[0 0 -1;0 0 0;0 0 1];
    switch 1
        case role.pos(3)~=1&&role.pos(3)+spDir(3)-1~=1&&sum(abs(tempRolePos-role.pos-Dir))==0&&all(role.pos+spDir+dir(1,:)==changePos(role.pos,role.pos+spDir+dir(1,:),-1))
            role.pos=changePos(role.pos,role.pos+spDir+dir(1,:),-1);bool=1;
        case role.pos(3)~=1&&role.pos(3)+spDir(3)~=1&&sum(abs(tempRolePos-role.pos-Dir))==0&&all(role.pos+spDir+dir(2,:)==changePos(role.pos,role.pos+spDir+dir(2,:),0))
            role.pos=changePos(role.pos,role.pos+spDir+dir(2,:),0);bool=1;
        case role.pos(3)~=1&&role.pos(3)+spDir(3)+1~=1&&sum(abs(tempRolePos-role.pos-Dir))==0&&all(role.pos+spDir+dir(3,:)==changePos(role.pos,role.pos+spDir+dir(3,:),1))
            role.pos=changePos(role.pos,role.pos+spDir+dir(3,:),1);bool=1;

        case role.pos(3)~=1&&role.pos(3)-spDir(3)+1~=1&&sum(abs(tempRolePos-role.pos+Dir))==0&&all(role.pos-spDir-dir(1,:)==changePos(role.pos,role.pos-spDir-dir(1,:),-1))
            role.pos=changePos(role.pos,role.pos-spDir-dir(1,:),1);bool=1;
        case role.pos(3)~=1&&role.pos(3)-spDir(3)~=1&&sum(abs(tempRolePos-role.pos+Dir))==0&&all(role.pos-spDir-dir(2,:)==changePos(role.pos,role.pos-spDir-dir(2,:),0))
            role.pos=changePos(role.pos,role.pos-spDir-dir(2,:),0);bool=1;
        case role.pos(3)~=1&&role.pos(3)-spDir(3)-1~=1&&sum(abs(tempRolePos-role.pos+Dir))==0&&all(role.pos-spDir-dir(3,:)==changePos(role.pos,role.pos-spDir-dir(3,:),1))
            role.pos=changePos(role.pos,role.pos-spDir-dir(3,:),-1);bool=1;
    end
end

function newPos=changePos(oriPos,objPos,ydir)
    newPos=oriPos;
    if all(objPos(1:2)>=1&objPos(1:2)<=10)&&objPos(3)<=7&&objPos(3)>=1
        switch ydir
            case 1
                if maze.(['layer',num2str(objPos(3))]).map(objPos(1),objPos(2))==0&&...
                   maze.(['layer',num2str(objPos(3)-1)]).map(objPos(1),objPos(2))==1&&...
                   (oriPos(3)+1>=8||maze.(['layer',num2str(oriPos(3)+1)]).map(oriPos(1),oriPos(2))==0)
                   newPos=objPos;
                end
            case 0
                if maze.(['layer',num2str(objPos(3))]).map(objPos(1),objPos(2))==0&&...
                   maze.(['layer',num2str(objPos(3)-1)]).map(objPos(1),objPos(2))==1
                   newPos=objPos;
                end
            case -1
                if maze.(['layer',num2str(objPos(3))]).map(objPos(1),objPos(2))==0&&...
                   maze.(['layer',num2str(objPos(3)-1)]).map(objPos(1),objPos(2))==1&&...
                   maze.(['layer',num2str(objPos(3)+1)]).map(objPos(1),objPos(2))==0
                   newPos=objPos;
                end
        end
    end
end

function plotcube(varargin)
% PLOTCUBE - Display a 3D-cube in the current axes
%
%   PLOTCUBE(EDGES,ORIGIN,ALPHA,COLOR) displays a 3D-cube in the current axes
%   with the following properties:
%   * EDGES : 3-elements vector that defines the length of cube edges
%   * ORIGIN: 3-elements vector that defines the start point of the cube
%   * ALPHA : scalar that defines the transparency of the cube faces (from 0
%             to 1)
%   * COLOR : 3-elements vector that defines the faces color of the cube
%
% Example:
%   >> plotcube([5 5 5],[ 2  2  2],.8,[1 0 0]);
%   >> plotcube([5 5 5],[10 10 10],.8,[0 1 0]);
%   >> plotcube([5 5 5],[20 20 20],.8,[0 0 1]);
% Default input arguments
inArgs = { ...
  [10 56 100] , ... % Default edge sizes (x,y and z)
  [10 10  10] , ... % Default coordinates of the origin point of the cube
  .7          , ... % Default alpha value for the cube's faces
  [1 0 0]       ... % Default Color for the cube
  };
% Replace default input arguments by input values
inArgs(1:nargin) = varargin;
% Create all variables
[edges,origin,alpha,clr] = deal(inArgs{:});
XYZ = { ...
  [0 0 0 0]  [0 0 1 1]  [0 1 1 0] ; ...
  [1 1 1 1]  [0 0 1 1]  [0 1 1 0] ; ...
  [0 1 1 0]  [0 0 0 0]  [0 0 1 1] ; ...
  [0 1 1 0]  [1 1 1 1]  [0 0 1 1] ; ...
  [0 1 1 0]  [0 0 1 1]  [0 0 0 0] ; ...
  [0 1 1 0]  [0 0 1 1]  [1 1 1 1]   ...
  };
XYZ = mat2cell(...
  cellfun( @(x,y,z) x*y+z , ...
    XYZ , ...
    repmat(mat2cell(edges,1,[1 1 1]),6,1) , ...
    repmat(mat2cell(origin,1,[1 1 1]),6,1) , ...
    'UniformOutput',false), ...
  6,[1 1 1]);
cellfun(@patch,XYZ{1},XYZ{2},XYZ{3},...
  repmat({clr},6,1),...
  repmat({'FaceAlpha'},6,1),...
  repmat({alpha},6,1)...
  );
view(3);
end
end

到此这篇关于Matlab实现简易纪念碑谷游戏的示例代码的文章就介绍到这了,更多相关Matlab纪念碑谷游戏内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 如何利用Matlab制作一款真正的拼图小游戏

    效果: 简单原理介绍: 1构造0,1矩阵作为每片拼图的透明度,可以构造出不规则形状的拼图(image函数有alphaData属性可以设置) jigsawMask=zeros(101*5,101*5); jigsawMask(102:404,102:404)=1; [xMesh,yMesh]=meshgrid(1:101*5,1:101*5); dis1=sqrt((xMesh-51).^2+(yMesh-253).^2); dis2=sqrt((xMesh-505+50).^2+(yMesh-2

  • Matlab实现别踩白块小游戏的示例代码

    目录 游戏效果 游戏说明 完整代码 pianoKeys.m(主函数) getMusic.m(用于获取音乐数据) 游戏效果 游戏说明 ‘A’,‘S’,‘D’,F’按键代表四条通路(点击S开始),按错按钮或黑块接触底限均为失败. 完整代码 分两个m文件,应放在同一文件夹 pianoKeys.m(主函数) function pianoKeys %======================%======== [v1,notes,fs]=getMusic;%读取音乐 %=================

  • 利用Matlab制作一款3D版2048小游戏

    其实逻辑和2维版本完全一样,就不进行详细解说了,直接看效果: 效果: 目前界面还不咋好看,期待大家的优化 还是键盘↑↓←→操作嗷 完整代码: function game20483D global squaremap global colorlist global fontsizelist global baseX baseY baseZ global barHdl textHdl global txtBest txtScore global best fig=figure('units','pi

  • 使用Matlab制作简易版八分音符酱游戏

    目录 效果 游戏方式 说明 工具箱主要部分代码 完整代码 效果 游戏方式 给电脑插上耳机后叫喊叭 ! 说明 1)使用此代码应首先安装: Audio Toolbox工具箱,博主使用的版本为: Audio Toolbox 版本 3.0 (R2021a) 2)为保证游戏加载完所有素材后再开始,故设置了加载完成界面后停滞3秒再开始运行游戏 若一进入界面就挂了,应是资源加载太久,请关掉窗口后尝试重新运行 工具箱主要部分代码 1)基础设置 这里懒得改了直接照抄的语音命令识别的截断数据,大家可以依据自己需要进

  • 基于Matlab制作一款简单的龙舟小游戏

    效果图: 没找到合适的背景就自己画了个,大家如果有更好看的可以换一下... 步骤 1 创建Axes及图片导入 窗口创建: Mainfig=figure('units','pixels','position',[50 100 760 400],... 'Numbertitle','off','menubar','none','resize','off',... 'name','dragonBoat'); axes('parent',Mainfig,'position',[0 0 1 1],...

  • MATLAB实现五子棋游戏(双人对战、可悔棋)

    本文实例为大家分享了MATLAB实现五子棋游戏的具体代码,供大家参考,具体内容如下 程序介绍: 1.此游戏只可用于双人对战. 2.棋盘颜色.棋盘格数.棋子颜色等参数均可自由设置 3.鼠标点击非棋盘区域可悔棋. 一.游戏界面 二.主程序及函数 1.主程序 %Author:LeiZhen %Date:2018-03-12 %此程序只下五子棋,并判断胜负关系 clear all; clc %定义颜色 Color_QiPanBack=[135,206,255]; Color_ChessLine=[100

  • 使用Matlab制作大富翁小游戏的过程详解

    目录 1.自定义头像及名称 2.买地.收费.破产 3.部分代码展示 gui_init.m self_init.m 4.修改记录 5.下载地址 大富翁大家都玩过,走到建筑的位置可以买地,第二圈走到买过的地可以升级,别人经过后需要付过路费,每次经过起点都会获得一定资金,玩到最后还没破产的就是胜者,这里我用MATLAB制作了一款MATLAB版的大富翁小游戏: 1.自定义头像及名称 点击方框内加号可换头像,点击文本区域可改昵称: 当然即使不换头像点击开始后,也会自动分配头像和名称: 2.买地.收费.破产

  • Matlab实现简易纪念碑谷游戏的示例代码

    按上下左右键(↑↓←→)移动物块 按AD键转动视角 游戏效果:如图所示原本无法通过的路径经过视角调整即可通过 完整代码 function maze4 global maze; global GUI; global role; GUI.fig=figure('units','pixels',... 'position',[350 100 500 500],... 'Numbertitle','off',... 'name','maze',... 'Color',[0 0 0],... 'resiz

  • Matlab实现贪吃蛇小游戏的示例代码

    由于老师说如果拿MATLAB制作出游戏或者有趣的动画的话.. 平时成绩可以拿满分 于是..开始尝试制作各种matlab小游戏 最初通过Alex的贪吃蛇学到了一些东西,然后制作了一个类似的俄罗斯方块在课堂上展示的(都是动的方块嗯哒). 后来自己也尝试写着玩了一些其他版本的贪吃蛇,并做出了一些改进. 补动图: 没错这就有点类似贪吃蛇大作战里的蛇啦 然后做出的改进包括: 在关闭窗口时不报错的设置,因为用了timer这个函数,在关闭图像时他会报错,我们就可以加入一个回调函数: set(gcf,'tag'

  • C++实现简易反弹小球游戏的示例代码

    目录 前言 一.显示静止的小球 二.小球下落 三.上下弹跳的小球 四.斜着弹跳的小球 五.控制小球弹跳的速度 六.完整代码 前言 我们利用printf 函数实现一个在屏幕上弹跳的小球,如图所示.弹跳的小球游戏比较简单.容易入门,也是反弹球消砖块.接金币.台球等很多游戏的基础. 完成游戏前需要掌握的语法知识:标识符.变量.常量.运算符与表达式,以及 printf.scanf.if-else.while.for 语句的用法. 正文部分我们会逐步进行讲解,前一部分是后一部分的基础,大家不要跳过阅读.

  • 利用Matlab制作三子棋游戏的示例代码

    效果: 注: 由于用uifigure和uiaxes写的会比较慢,改成常规的axes和figure会快很多. 完整代码: function OX_chess fig=uifigure('units','pixels',... 'position',[350 100 500 500],... 'Numbertitle','off',... 'name','OX_chess',... 'Color',[1 1 1],... 'resize','off',... 'menubar','none'); a

  • 基于Python编写简易版的天天跑酷游戏的示例代码

    写出来的效果图就是这样了: 下面就更新一下全部的代码吧 还是老样子先定义 import pygame,sys import random 写一下游戏配置 width = 1200            #窗口宽度 height = 508            #窗口高度 size = width, height    score=None              #分数 myFont=myFont1=None     #字体 surObject=None          #障碍物图片   

  • Python快速实现简易贪吃蛇小游戏的示例代码

    贪吃蛇(也叫做贪食蛇)游戏是一款休闲益智类游戏,有PC和手机等多平台版本.既简单又耐玩.该游戏通过控制蛇头方向吃蛋,从而使得蛇变得越来越长. 贪吃蛇游戏最初为单机模式,后续又陆续推出团战模式.赏金模式.挑战模式等多种玩法. 另外还有一种名为“贪吃蛇”钻井测井技术,是运用旋转导向系统.随钻测井系统等的油气田定向钻井.随钻测井技术,可完成海上“丛式井”和复杂油气层的开采需求,大幅降低油气田开发综合成本. 依然是基于pygame库,pip install pygame安装即可 完整代码如下: # 导入

  • WPF+ASP.NET SignalR实现简易在线聊天功能的示例代码

    目录 涉及知识点 什么是ASP.NET SignalR 在线聊天整体架构 ASP.NET SignalR在线聊天服务端 1. 创建ASP.NET Web API项目 2. 创建消息通知中心Hub 3. 注册服务和路由 4. ASP.NET SignalR中心对象生存周期 SignalR客户端 1. 安装SignalR客户端依赖库 2. 客户端消息接收发送 运行示例 在实际业务中,当后台数据发生变化,客户端能够实时的收到通知,而不是由用户主动的进行页面刷新才能查看,这将是一个非常人性化的设计.有没

  • 使用c#实现随机数猜数游戏的示例代码

    本文主要介绍了使用c#实现随机数猜数游戏,分享给大家,具体如下: using System;//在任何 C# 程序中的第一条语句都是:using System的意思是引用名称为baiSystem的命名空间 using System.Runtime.InteropServices.ComTypes;//c#语言的互操作服务, namespace ConsoleApp5//namespace 声明.一个 namespace 里包含了一系列的类. { class Program//定义类名 { sta

  • Python使用random模块实现掷骰子游戏的示例代码

    引入内容 根据人民邮电出版社出版的<Python程序设计现代设计方法>P102习题中的第7题--掷骰子游戏,进行代码编写. 题目要求 一盘游戏中,两人轮流掷骰子5次,并将每次掷出的点数累加,5局之后,累计点数较大者获胜,点数相同则为平局.根据此规则实现掷骰子游戏,并算出50盘之后的胜利者( 50盘中嬴得盘数最多的,即最终胜利者). 审题: 共有50盘游戏.一盘游戏有5局,每一局双方各掷骰子一次,5局结束以后统计分数,分数高的一方获胜.至此,一盘游戏结束.50盘游戏结束后,赢得盘数最多的一方为最

随机推荐