广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >Matlab实现简易纪念碑谷游戏的示例代码
  • 965
分享到

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

2024-04-02 19:04:59 965人浏览 安东尼
摘要

按上下左右键(↑↓←→)移动物块 按AD键转动视角 游戏效果:如图所示原本无法通过的路径经过视角调整即可通过 完整代码 function

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

按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纪念碑谷游戏内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Matlab实现简易纪念碑谷游戏的示例代码

本文链接: https://www.lsjlt.com/news/141206.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • Matlab实现简易纪念碑谷游戏的示例代码
    按上下左右键(↑↓←→)移动物块 按AD键转动视角 游戏效果:如图所示原本无法通过的路径经过视角调整即可通过 完整代码 function...
    99+
    2022-11-13
  • Matlab怎么实现简易纪念碑谷游戏
    本文小编为大家详细介绍“Matlab怎么实现简易纪念碑谷游戏”,内容详细,步骤清晰,细节处理妥当,希望这篇“Matlab怎么实现简易纪念碑谷游戏”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。按上下左右键(&...
    99+
    2023-06-29
  • C++实现简易反弹小球游戏的示例代码
    目录前言一、显示静止的小球二、小球下落三、上下弹跳的小球四、斜着弹跳的小球五、控制小球弹跳的速度六、完整代码前言 我们利用printf 函数实现一个在屏幕上弹跳的小球,如图所示。弹跳...
    99+
    2022-11-13
  • C语言实现简易贪吃蛇游戏的示例代码
    目录前言一、构造小蛇二、小蛇的移动三、控制小蛇移动四、判断游戏失败五、吃食物增加长度六、完整代码前言 实现一个经典的小游戏——贪吃蛇,如图所示。读者可以先自己...
    99+
    2022-11-13
    C语言贪吃蛇游戏 C语言贪吃蛇 C语言 游戏
  • Matlab实现贪吃蛇小游戏的示例代码
    由于老师说如果拿MATLAB制作出游戏或者有趣的动画的话。。 平时成绩可以拿满分 于是。。开始尝试制作各种matlab小游戏 最初通过Alex的贪吃蛇学到了一些东西,然后制作了一个类...
    99+
    2022-11-13
  • Python快速实现简易贪吃蛇小游戏的示例代码
    贪吃蛇(也叫做贪食蛇)游戏是一款休闲益智类游戏,有PC和手机等多平台版本。既简单又耐玩。该游戏通过控制蛇头方向吃蛋,从而使得蛇变得越来越长。  贪吃蛇游戏最初为单机模式,后...
    99+
    2022-11-11
  • Matlab实现别踩白块小游戏的示例代码
    目录游戏效果游戏说明完整代码pianoKeys.m(主函数)getMusic.m(用于获取音乐数据)游戏效果 游戏说明 ‘A’,‘S&rsqu...
    99+
    2022-11-13
  • Java实现简单的五子棋游戏示例代码
    目录项目结构核心代码ArrComparator.java类ChessMap.java类ChessPanel.java类效果图展示项目结构 这个是在网上找的资源,出处记不得了,记录一下...
    99+
    2022-11-13
  • Java实现升级版布谷鸟闯关游戏的示例代码
    目录前言主要设计功能截图代码实现游戏启动类核心类线程类用于重复绘图总结前言 《布谷鸟闯关-升级版》是一个基于java的布谷鸟闯关游戏,鼠标左键点击控制鸟的位置穿过管道间的缝隙,需要做...
    99+
    2022-11-13
  • 基于Python编写简易版的天天跑酷游戏的示例代码
    写出来的效果图就是这样了: 下面就更新一下全部的代码吧 还是老样子先定义 import pygame,sys import random 写一下游戏配置 width = 1200...
    99+
    2022-11-13
  • Python实现小游戏的源代码示例
    这篇文章将为大家详细讲解有关Python实现小游戏的源代码示例,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、21点数字小游戏展示:首先配置文件的源码:'''配置文件'&...
    99+
    2023-06-14
  • Python实现简易凯撒密码的示例代码
    目录概念及原理实现过程破解原理及实现概念及原理 根据百度百科上的解释,凯撒密码是一种古老的加密算法。 密码的使用最早可以追溯到古罗马时期,《高卢战记》有描述恺撒曾经使用密码来传递信息...
    99+
    2022-11-11
  • Java实现经典游戏打砖块游戏的示例代码
    目录前言主要设计功能截图代码实现游戏核心类小球类砖块类总结前言 《JAVA打砖块》游戏是自制的游戏。玩家操作一根萤幕上水平的“棒子”,让一颗不断弹来弹去的&l...
    99+
    2022-11-13
  • C语言实现简单的贪吃蛇游戏的示例代码
    目录运行效果代码一个简单的贪吃蛇游戏本来代码就不多,在保证可读性的情况下,很容易就控制在100以内了。 运行效果 代码 #include <Windows.h> #in...
    99+
    2023-01-12
    C语言实现贪吃蛇游戏 C语言贪吃蛇游戏 C语言贪吃蛇
  • C#实现简易画图板的示例代码
    编程环境 VS2019、C# 画板功能演示 实现简单画图 打开功能 可打开jpg格式的文件 保存功能 可将绘画的内容保存为jpg文件 颜色选择功能 用户可自由选择所需的颜色...
    99+
    2022-11-12
  • Qt实现简易计时器的示例代码
    目录一、项目介绍二、项目基本配置三、UI界面设计四、主程序实现4.1 mainwindow.h头文件4.2 mainwindow.cpp源文件五、效果演示一、项目介绍 计时器实现四个...
    99+
    2022-11-13
  • Java实现扑克牌游戏的示例代码
    目录一、三人扑克二、具体实现Card类生成52张牌打乱顺序发牌三、完整代码一、三人扑克 想不想带上好朋友来上一局三人扑克呢。 二、具体实现 Card类 定义一个花色color变量和...
    99+
    2022-11-13
  • Python实现21点小游戏的示例代码
    目录游戏玩法代码 - v1测试代码 - v2测试游戏玩法 游戏玩法: 该游戏由 2 到 6 个人玩,使用除大小王之外的 52 张牌, 游戏者的目标是使手中的牌的点数之和不超过 21 ...
    99+
    2022-11-11
  • Java实现经典游戏FlappyBird的示例代码
    目录前言主要设计功能截图代码实现游戏启动类核心类工具类总结前言 《布谷鸟闯关-简单版》是一个基于java的布谷鸟闯关游戏,摁上键控制鸟的位置穿过管道间的缝隙,需要做碰撞检测,监听键盘...
    99+
    2022-11-13
  • Java实现经典游戏2048的示例代码
    目录前言主要设计功能截图代码实现界面布局类业务逻辑类总结前言 2014年Gabriele Cirulli利用周末的时间写2048这个游戏的程序,仅仅只是好玩而已。他想用一种不同的视觉...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作