如何在Reworld里随机生成想要的物体

功能效果展示

运行环境

Win7,Win8,Win10

Reworld版本 体验版

vc_redist.x64 运行环境

针对零基础读者的补充

下载安装 Reworld对应版本

Reworld官网链接http://www.reworlder.com/

下载后安装后注册账号打开空地图

下载安装vc_redist.x64.rar运行环境

redist.x64下载链接

思路分析

我们想要随机生成物体,那么我们首先就要在工作区内添加所有我们想要生成的物体,然后放到服务器存储内,这样才能方便我们调用。我们已经有了这些物体,那我们如何调用呢,我选用的方法是制作一个UI,点击UI后,发生消息给服务器,这样我们就可以调用这些物体啦。如何产生随机性呢,我们可以在服务器脚本里设置一个随机数,这样物体就会随机的出现在工作区里了。

功能搭建

一、物体搭建过程
1.首先我们需要在工作区里面创建三个形状不同的零件,并且给这些零件分别命名为零件1,零件2,零件3。如下图所示:

2.创建完这些零件后,我们需要将他们复制到服务器存储里。如下图所示:

二、UI搭建过程
1.首先我们需要在界面初始化下创建一个2D容器界面,重命名为Init,然后在Init内创建按钮控件和文本控件,调整位置和大小。如下图所示:

2.我们在Init下创建一个客户端脚本,如下图所示:


编写客户端脚本如下:

GameUI.Init.按钮控件.OnClick:Connect(function()
    MessageEvent.FireServer("Init")
end)

三、创建服务器脚本逻辑
我们在服务器逻辑里创建一个服务器脚本。如下图所示:

编写服务器脚本如下:

local Prefabs = {}           --模型
Prefabs\[1\],Prefabs\[2\],Prefabs\[3\] = "零件1","零件2","零件3"
 
local ObjRandom = 0          --随机数
math.randomseed(tostring(os.time()):reverse():sub(1, 7))       --设置随机数
local Xset = 0
MessageEvent.ServerEventCallBack("Init"):Connect(function()
    ObjRandom = math.random(1,3)
    local obj = ServerStorage:GetChildByName(Prefabs\[ObjRandom\]):Clone()
    obj.Parent = WorkSpace
    Xset= Xset + 2
    obj.Position = Vector3.New(Xset,0,0)
end)

二、补充说明

1.__什么是工作区?

工作区中的对象是会被可视化显示到3D场景中的,并且只有在工作区中的对象才会发生物理交互。

2.__什么是服务器脚本?

只会在服务器运行的Lua脚本代码,用于编写服务器逻辑。

3.__什么是客户端脚本?

_只会在客户端执行的脚本,执行的逻辑和表现也只会在本地客户端展现;可在以下几个文件目录下自动执行,客户端脚本在“工作区”下不会自动执行,需要放在以下对象里面:
1. __客户端最先加载 。
2. 工作区中的角色模型玩家初始化中的角色初始化脚本,在运行后会自动移动到角色模型下。
3. 玩家列表中的玩家玩家初始化中的玩家初始化脚本,在运行后会自动移动到玩家下
4. 玩家玩家界面界面初始化的脚本,在运行后会自动移动到玩家界面下。
5. 玩家的背包,例如工具里面的。_

4.什么是服务器存储?

此服务为数据存储区,数据存储区中的零件等对象数据不会被实例化,不可见不进行物理交互;服务器存储中数据只能被服务器脚本调用实例化,也只能服务器脚本存储数据。

5.什么是2D容器界面?

2D容器界面是显示在玩家屏幕上的2DUI对象的主要存储对象。UI对象若要显示在编辑器中,必须作为容器控件的子级。

游戏运行后,存放在界面初始化_StarterUI下的界面会复制到玩家界面下,只有在玩家界面GameUI下的界面才能在游戏中显示。_

好了,接下来我们开始游戏,点击界面上生成这个按钮,就实现了随机生成物体这个功能啦。如果有什么问题或者有更好的实现方式,大家可以在下方积极交流讨论,我们也会参与进来和大家一起分享经验,期望能和大家共同进步~~

Image placeholder
Reworld
未设置
  81人点赞

没有讨论,发表一下自己的看法吧

推荐文章
如何在react加css样式?

react加css的3种方法:1.行内样式直接给对应的DOM元素添加style属性,遵循react的规则,写在{}当中。ThisisPage1!2.声明样式render(){   letmystyle

如何利用Reworld做一个一键吸空投箱的效果

功能效果展示运行环境Win7,Win8,Win10Reworld版本体验版vc_redist.x64运行环境针对零基础读者的补充下载安装Reworld对应版本Reworld官网链接:http://ww

3种可靠的物联网开发编程语言

物联网设备的普及程度持续上升,人们与物联网的联系愈加紧密。物联网为结合虚拟和现实世界提供了最大的平台。大多数支持IoT设备的命令都可以通过智能手机上的一个图标来实现。物联网的发展和成长不能归结为某一方

三种类型的物联网平台分析

企业依靠其物联网平台提供许多服务。其中最重要的是分析。通俗地说,物联网分析是一门科学和艺术,它试图在连接资产生成的海量数据中找到模式。MachNation的物联网平台测试实验室给出更详尽地定义,分析是

怎么在react中安装修饰器

怎么在react中安装修饰器在create-react-app下使用es7的@修饰器会报错''Supportfortheexperimentalsyntax'decorators-legacy'isn

怎么在react中使用weui

怎么在react中使用weui1、react没有安装的情况下:安装react和weuinpminstall--savereactreact-dom npminstall--saveweui@1.1.0

在react中怎么引用js

在react中怎么引用js推荐两种引入的方法,当然也可以自己编写一个JS类(ES6语法)实现动态插入JS到页面,然后在React项目引入。第一种:使用插件react-load-script如果没有安装

陶建辉:通过技术“Leave a dent in the world”

“让我们一起奔跑,去追求卓越而不是平庸的一生!”今年8月份北京涛思数据创始人CEO陶建辉以此为题在自己的公众号“爱倒腾的程序员”上重发旧文自勉,提醒自己,提醒团队,不忘初心。涛思数据创始人CEO陶建辉

《2019 Dell Technologies World》观后感

这是我第二次参加DellTechnologiesWorld大会:同样的时间、同样的地点、不一样的内容、不一样的感受!五一劳动节期间,一年一度的戴尔科技集团全球大会在拉斯维加斯隆重举行。今年是戴尔公司成

Udemy:人工智能是2020年职场最需要的技能之一

TensorFlow是过去三年中最受欢迎的技术技能,根据Udemy的数据在2016年至2019年之间呈指数增长。·除了Web开发框架,云计算和IT认证(包括AWS、CompTIA和Docker)之外,

你需要的前端知识收集好了,请查收!

github地址记录学习成长收获的知识,不断进步,Front-end-go-on目前包含的模块有 HTML基础 CSS基础 JS基础 数据结构基础 Http基础 JS代码练习 算法代码练习 CSS代码

react-native中IOS的webview和js层通信 - UIWebview

前言在9012的最后一篇写到了在rn中安卓的webview的通信原理,而作为0202年的第一篇,继续讨论上年rn中webview通信剩下的部分。背景:对于webview,了解过的人都知道在ios端会存

如何在cmd中下载react模板

如何在cmd中下载react模板打开cmd命令行窗口,输入npm-version,查看当前的npm版本如果npm版本是5.2以上版本,在cmd中输入npxcreate-react-appmy-app,

如何在idea中下载react

如何在idea中下载react1、首先安装Terminal插件File—>Settings—>Plugins搜索Terminal,打上勾,重启idea2、按下alt+f12打开Terminal工具3、

如何在浏览器中获取 Production Mode 的 React 实例

https://github.com/LiuuY/Blog...在ProductionMode下,React并没有暴露其实例。无论什么原因如果你要获取的话可以参考以下方法。条件浏览器安装了ReactD

workerman源码-workerman启动流程

前面我们跟着代码看了一遍workerman的初始化流程.但对于如何监听端口.等操作还没有具体的实现.我们这次就来看一下.workerman是如何监听端口并运行的.runAll在前面我们初始化方法过后,

如何在复杂的后端系统中保证数据库安全?

以技术为中心的时代,信息至关重要。数据库及其安全性已成为每个企业极具挑战性的任务。数据库可以包含关键信息,例如个人身份、信用卡信息、金融交易以及应用程序密码,这些都是对黑客和网络犯罪分子有价值的信息。

深度复盘GitHub发展史:如何在短短10年内改变了人们的编程方式?

前不久,微软以75亿美元的价格收购GitHub,引发了科技行业的关注。在短短的10年内,GitHub改变了人们的编程方式。不仅让编程变得更简单,还改变了软件开发者对编程的看法。GitHub是如何做到的

如何在生产环境中部署Kubernetes集群?

如果把kubernetes集群应用于生产环境中,需要做哪些准备?我们先要弄清楚一个词,什么是“生产就绪”?生产就绪,是我们经常听到的一个专业术语,大概意思是已经准备好并已处于即将生产的状态。但是,到底

如何在多云环境中管理数据?

在多云环境中建立数据治理策略没有灵丹妙药。在这里,我们将讨论为什么会有这种说法的原因,以及有关多云环境的IT领导者如何思考数据治理的一些方法。数据治理有点像健身:它不仅仅是一个目的,更是一个持续的过程

如何在JavaWeb中用css

如何在JavaWeb中用css一、css概念:CascadingStyleSheets层叠样式表层叠:多个样式可以作用在同一个html的元素上,同时生效二.、好处:1.功能强大2.将内容展示和样式控制

如何在css中让图片横向展开排列?

如何在css中让图片横向展开排列?1、首先添加一个div来存放所有的图片。2、然后隐藏div在纵向的滚动条,横向的滚动条设置为自动。3、最后设置divwhite-space:nowrap不换行即可。这

如何在JavaScript中操作数组?

JavaScript中的数组是什么?在开始之前,你需要先了解数组的真正含义。在JavaScript中,数组是一个用于存储不同数据类型的变量。它将不同的元素存储在一个盒子中,供以后使用。声明一个数组:l

Java如何在没有throws签名的函数中手动抛出异常

如果想在方法中抛出异常,像下面这样直接throw是不行的。publicvoidtest(){ thrownewException(); }这时编译器会给我们一个错误:Error:(101,13)jav

如何打包react生成的项目

如何打包react生成的项目1、点击开始-菜单-运行-cmd2、使用cd命令切换到react项目根目录3、执行npmrunbuild命令进行打包打包完成后会在项目目录下生成一个build文件夹,bui