如何在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如果没有安装

生成 Go 随机字串

在这篇文章中,我们将介绍如何创建一个函数,它将允许我们在Go代码中生成任意长度的随机字符串。为此,我们将编写一个简短的rand包来包装math/rand包,并提供以下两个功能: StringWith

Go编程语言教程_1.3. Golang的Hello World

你好,世界!是任何编程语言中的第一个基本程序。让我们使用以下步骤用Go语言编写第一个程序: 首先打开Go编译器。在Go语言中,该程序以.go扩展名保存,它是UTF-8文本文件。 现在,首先在程序中添加

gRPC-Go 和 Java 的一次 HelloWorld(十)

都说grpc是跨语言的一个rpc框架,当团队内部有多种流行编程语言时,那么grpc可以为他们提供通信,今天我们就通过一个HelloWorld来看看Java和Go是怎么通信的,一起实践吧,只有亲身实践才

Go语言高级编程_1.2 Hello, World 的革命

1.2Hello,World的革命 在创世纪章节中我们简单介绍了Go语言的演化基因族谱,对其中来自于贝尔实验室的特有并发编程基因做了重点介绍,最后引出了Go语言版的“Hello,World”程序。其实

献给 Hello World!的建筑师 (写于版主第一天)

写在前面的话时长13周,终于坚持下来了。感觉这个过程就是一个几度想放弃,但又“真香”的过程,期待更多人坚持下来,加油!实习版主的历程当时为什么选择申请实习版主,老实说我是受上一任版主@Epona影响的

陶建辉:通过技术“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)之外,

web开发需要的构件

所需要内容 客户端浏览器 超文本标记语言HTML 层叠样式表CSS控制页面的外观 客户端脚本编程语言 wbe服务器,主要功能提供网上信息浏览服务 服务器脚本编程语言 数据库管理系统

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

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端会存

REST framework JWT Auth

JWT认证的REST框架 概述 这个包提供对DjangoRESTframework的JSONWebToken认证支持。 需要满足条件 Python(2.7,3.3,3.4,3.5) Django(1.

【翻译】REST framework JWT Auth

JWT认证的REST框架原文链接概述这个包提供对DjangoRESTframework的JSONWebToken认证支持。需要满足条件Python(2.7,3.3,3.4,3.5) Django(1.

一步步教你如何在 Django REST API 中构建使用 JWT 验证

基于令牌的身份验证,允许后端服务与前端(无论是web端,原生移动端或其他端)分离,并驻留在不同域中。JSONWebTokens(JWT)是一种流行的令牌认证实现,在本文中,我们使用它来验证,通过Dj

如何在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在前面我们初始化方法过后,

{