You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
1. Download KBEngine(a MMOG engine of server):
Download(KBEngine):
https://github.com/kbengine/kbengine/releases/latest
Build(KBEngine):
http://www.kbengine.org/docs/build.html
Installation(KBEngine):
http://www.kbengine.org/docs/installation.html
2. Use git to get the plugin(client) and demo-assets(server):
In the kbengine_unity3d_demo directory:
* Git command: git submodule update --init --remote
* Or use TortoiseGit(menu): TortoiseGit -> Submodule Update:
* Or manually get the plugin(client) and demo-assets(server)
Download plugin(client):
https://github.com/kbengine/kbengine_unity3d_plugins/releases/latest
unzip and copy to "Assets/plugins/kbengine/kbengine_unity3d_plugins"
Download demo-assets(server):
https://github.com/kbengine/kbengine_demos_assets/releases/latest
unzip and copy to "kbengine/" (The root directory server engine, such as $KBE_ROOT)
3. Copy "kbengine_unity3d_demo\kbengine_demos_assets" to "kbengine\" root directory
Configure Demo(Optional):
Change the login address:
kbengine_unity3d_demo\Scripts\kbe_scripts\clientapp.cs -> ip
kbengine_unity3d_demo\Scripts\kbe_scripts\clientapp.cs -> port
Start the Servers:
Ensure that the "kbengine_unity3d_demo\kbengine_demos_assets" has been copied to the "kbengine\" directory
Reference:Start
Check the startup status:
If successful will find log "Components::process(): Found all the components!".
Otherwise, please search the "ERROR" keyword in logs, according to the error description to try to solve.
(More: http://www.kbengine.org/docs/startup_shutdown.html)
Start server:
Windows:
kbengine\kbengine_demos_assets\start_server.bat
Linux:
kbengine\kbengine_demos_assets\start_server.sh
(More: http://www.kbengine.org/docs/startup_shutdown.html)
Start the Client:
Directly start(U3DEditor or Executable file).
(Build Client:Unity Editor -> File -> Build Settings -> PC, MAC & Linux Standalone.)
Navmesh-navigation(Optional):
The server to use recastnavigation navigation.
Recastnavigation generated navigation mesh (Navmeshs) placed on the:
kbengine\kbengine_demos_assets\res\spaces\*
Generation Navmeshs:
https://github.com/kbengine/unity3d_nav_critterai
Structure and interpretation:
The relationship between plug-ins(KBE) and U3D and servers:
Plug-in and servers: Responsible for processing and server network packet. account login/logout process.
By server notification logic entities are created and destroyed. Processing synchronous logical entity attribute data. etc.
Plug-in and U3D: The plug-in will trigger some events to the U3D graphics layer, the graphics layer determines whether to capture some events,
get data to render performance (for example: create a monster, a NPC move-speed increase, HP changes).
U3D graphics layer will input the event trigger to the plug-in layer (for example: the player moved, hit the relive button UI),
the plug-in logic script layer determines whether the need to transfer to the server. etc.
Plugins\kbengine\kbengine_unity3d_plugins:
Client plug-in core codes.
Scripts\kbe_scripts:
KBE client logic scripts(in this implementation of the server side of the entity script, the entity's bag data structure, skills in client condition checks, etc.).
Scripts\kbe_scripts\Account.cs:
Corresponds to the client side of the KBE server account entity.
Scripts\kbe_scripts\Avatar.cs:
Corresponds to the client side of the KBE server avatar entity.
Scripts\kbe_scripts\Monster.cs:
Corresponds to the client side of the KBE server monster entity.
Scripts\kbe_scripts\clientapp.cs:
In the system of KBE abstraction of a client APP, which contains the KBE client plug-in initialization and destruction, etc.
Scripts\kbe_scripts\interfaces:
Corresponding to the module defined in KBE(entity_defs\interfaces).
Scripts\u3d_scripts:
Unity graphics layer (including scene rendering, UI, object, character model, monster model).
Scripts\u3d_scripts\GameEntity.cs:
Monster/NPC or player script (management model and animation, etc.).
Scripts\u3d_scripts\World.cs:
Manage a map of the game script, for example: to create a specific 3D monster into the scene.
Scripts\u3d_scripts\UI.cs:
the game's UI processing script.
Scenes\start.unity:
Start the scene, which starts to enter the game.
Scenes\_scenes\login.unity:
login map.
Scenes\_scenes\selavatars.unity:
Game character selection map.
Scenes\_scenes\world.unity:
A map of the scene in the game.