❤️ If you are interested in supporting the project, go to this link, any value is great help, thank you.
Based on edubart/otclient Rev: 2.760
- C++20
- Refactored/Optimized Rendering System
- Auto Reload Module (init.lua)
- Attached Effects System (to create aura, wings...) (code sample: effects.lua, outfit_618.lua, code test)
- Idle Animation Support
- Highlight Mouse Target (press shift to select any object)
- Crosshair
- Floor Shadowing
- Floor View Mode (Normal, Fade, Locked, Always, Always with transparency)
- Anti-Aliasing Mode Options (Note: Smooth Retro will consume a little more GPU)
- Floating Effects Option
- Optimized Terminal
- Refactored Walk System
- Support for more mouse buttons, for example 4 and 5
- Module Controller System (Code example)
- Some bugs fixed contained in edubart/otclient
- Client 12.85 ~ 12.92, 13.00 ~ 13.21 support (protobuf)
- Market has been rewritten to work only Canary
- Async Texture Loading
- Tile Widget
- Mobile Support @tuliomagalhaes & @BenDol
- Support Tibia 12.85/protobuf by @Nekiro
- Support Discord RPC by @SkullzOTS (Doesn't work with CMAKE)
- Action Bar by @DipSet
- Access to widget children via widget.childId by @Hugo0x1337
- Shader System Fix (CTRL + Y) by @FreshyPeshy
- Refactored Battle Module by @andersonfaaria
- Health&Mana Circle by @EgzoT, @GustavoBlaze, @Tekadon58 (GITHUB Project)
- Tibia Theme 1.2 by Zews (Forum Thread)
- Add option ADJUST_CREATURE_INFORMATION_BASED_ON_CROP_SIZE in config.h by @SkullzOTS
- Encryption System by @Mrpox (Note: This implementation is unsafe)
- To enable just go to config.h, set 1 in ENABLE_ENCRYPTION and change password on ENCRYPTION_PASSWORD
- To enable Encrypting by "--encrypt" change ENABLE_ENCRYPTION_BUILDER to 1 (by @TheMaoci). This allows to remove code of creating encrypted files off the production build
- To generate an encryption, just run the client with flag "--encrypt SET_YOUR_PASSWORD_HERE" and don't forget to change the password.
- you can also skip adding password to --encrypt command it automatically will be taken from config.h file (by @TheMaoci)
- Support HTTP/HTTPS/WS/WSS. by @alfuveam
- Discord RPC by @SkullzOTS
- Client Updater by @conde2
- Paste the API folder in your www folder (https://github.com/mehah/otclient/tree/main/tools/api)
- Create a folder called "files" in your www folder and paste init.lua, modules, data, and exe files
- Uncomment and change this line (https://github.com/mehah/otclient/blob/main/init.lua#L6)
- Colored text @conde2
- widget:setColoredText("{Colored text, #ff00ff} normal text")
- QR Code support, with auto generate it from string [@conde2]
- UIQrCode:
- code-border: 2
- code: Hail OTClient Redemption - Conde2 Dev
- UIQrCode:
- Smooth Walk Elevation Feature by @SkullzOTS
- View Feature: Gyazo
- To enable just go to modules/game_features/features.lua, and uncomment line 5 (g_game.enableFeature(GameSmoothWalkElevation)).
- Lua Debugger for VSCode see wiki @BenDol
- Shader with Framebuffer | (@SkullzOTS, @Mryukiimaru, @JeanTheOne, @KizaruHere)
- Bot V8 | (@luanluciano93, @SkullzOTS, @kokekanon, @FranciskoKing, @Kizuno18)
- Is adapted in 85%
- To enable it, it is necessary to remove/off the BOT_PROTECTION flag.
- VS Solution / CMAKE
- NOTE: BE AWARE THAT THERE ARE SERIOUS PROBLEMS, SUCH AS MEMORY LEAKS.
OTClient V8 (Features)
- Lighting System
- Floor Fading
- Path Finding
Otclient is an alternative Tibia client for usage with otserv. It aims to be complete and flexible, for that it uses LUA scripting for all game interface functionality and configurations files with a syntax similar to CSS for the client interface design. Otclient works with a modular system, this means that each functionality is a separated module, giving the possibility to users modify and customize anything easily. Users can also create new mods and extend game interface for their own purposes. Otclient is written in C++20 and heavily scripted in lua.
For a server to connect to, you can build your own with the forgottenserver or canary.
This is a fork of edubart's otclient. The objective of this fork it's to develop a runnable otclient on mobiles devices.
Tasks that need to do:
- Compile on Android devices
- Compile on Apple devices
- Adapt the UI reusing the existing lua code
Current compiling tutorials:
Compiled for Windows can be found here (but can be outdated):
NOTE: You will need to download spr/dat files on your own and place them in data/things/VERSION/
(i.e: data/things/1098/Tibia.spr
)
Beyond of it's flexibility with scripts, otclient comes with tons of other features that make possible the creation of new client side stuff in otserv that was not possible before. These include, sound system, graphics effects with shaders, modules/addons system, animated textures, styleable user interface, transparency, multi language, in game lua terminal, an OpenGL 2.0 ES engine that make possible to port to mobile platforms. Otclient is also flexible enough to create tibia tools like map editors just using scripts, because it wasn't designed to be just a client, instead otclient was designed to be a combination of a framework and tibia APIs.
If you are interested in compiling this project, just go to the wiki.
To build the image:
docker build -t mehah/otclient .
To run the built image:
# Disable access control for the X server.
xhost +
# Run the container image with the required bindings to the host devices and volumes.
docker run -it --rm \
--env DISPLAY \
--volume /tmp/.X11-unix:/tmp/.X11-unix \
--device /dev/dri \
--device /dev/snd mehah/otclient /bin/bash
# Enable access control for the X server.
xhost -
Try to ask questions in discord
Have found a bug? Please create an issue in our bug tracker
Otclient is made available under the MIT License, thus this means that you are free to do whatever you want, commercial, non-commercial, closed or open.