Skip to content

Latest commit

 

History

History
77 lines (67 loc) · 3.97 KB

README.md

File metadata and controls

77 lines (67 loc) · 3.97 KB

MTA Framework 💡

🍎 This is a framework for Multi Theft Auto: San Andreas and is designed for easy interacting with MTA element-based functions.

🎉The reason I released this framework is because I would like to save hours of working on scripting. Finally, I am glad to provide the MTA Framework, and everyone is welcome to adjust the code and help make it better by editting the code, adding functions or events.

Usage 🖌️

  • FONTS

    • Fonts can be called anywhere on client side, by default they are not allocated in memory until they are called with a function - if the type and size is correct the font is returned and allocates to memory, when the font is returned from memory - they are not created again.
    • Fonts can be delocated from memory by calling FONTS.deleteAllFonts()
    • Fonts can be easily added in fonts.lua file by scheme:
      local fontTypes = {
          [ name ] = path, -- font type accesed by FONTS[ size ].TYPE_HERE
          ["regular"] = "assets/fonts/Roboto-Regular.ttf", -- FONTS[ size ].regular
          ["bold"] = "assets/fonts/Roboto-Bold.ttf", -- FONTS[ 10 ].bold
          ["light"] = "assets/fonts/Roboto-Light.ttf", -- FONTS[ 12 ].light
      }
  • TEXTURES

    • Textures can be called anywhere on client side, by default they are not allocated in memory until they are called with a function.
    • Textures are automatically delocated from memory if they are not called for 10 seconds.
    • Textures can delocated from memory by calling TEXTURES.deleteAllTextures()
    • Textures can be easily called using TEXTURES[ path ] for example TEXTURES[ "assets/images/background.png" ]
  • Events (eg. onClientVehicleEnter)

    • Events can be added easily in events.lua file by scheme:
      Events = {
          {
              name = "onClientVehicleEnter", -- Name of event (required)
              attachedTo = root, -- Element to event is attached (optional, default: resourceRoot)
              exec = function(player, seat) -- Event executor (required)
              end,
          }
      }
  • Remote Events

    • Remote events can be added easily using under scheme as follow, triggered via triggerEvent, triggerClientEvent and many more MTA functions...
    • Events can be added easily in events.lua file by scheme:
      RemoteEvents = {
          {
              name = "client.example:context", -- Name of remote event (required)
              allowedRemote = false, -- Does remote execution is allowed by trigger[...]Event (optional, default: true)
              attachedTo = root, -- Element to event is attached (optional, default: resourceRoot)
              exec = function(arg1, arg2, ...) -- Event executor (required)
              end,
          }
      }
  • Cache

    • Cached data can be stored in CacheData table which is accessible from whole code (Data stored client-side cannot be accessed from server-side and vice versa).
  • DX Library

    • Functions to draw rounded reactangles:
      • dxDrawRoundedRectangle(x, y, rx, ry, color, radius)
      • dxDrawRoundedLeftRectangle(x, y, rx, ry, color, radius)
      • dxDrawRoundedTopRectangle(x, y, rx, ry, color, radius)
      • dxDrawRoundedBottomRectangle(x, y, rx, ry, color, radius)
  • Utils

    • Useful functions:
      • isMouseIn( x, y, width, height )
      • isEventHandlerAdded( sEventName, pElementAttachedTo, func )
      • formatNumber(number, [ sep = ',' ])
  • GUI:

    • gui.lua contains values sx - screen width, sy - screen height, sxh - half of screen width, syh - half of height width, zoom - zoom for scaling purposes (player resolution divided by fullhd resolution). These values can be used anywhere on client side code.

Contribution ❤️

The most powerful feature of open source projects is developers community❤️. Everyone is welcome and will be written below 🔥.

Thanks for your support.❤️