Hello & Welcome to our community. Is this your first visit? Register
Follow us on
Follow us on Facebook Follow us on Twitter Watch us on YouTube


MMOCoin

Likes Likes:  0
Results 1 to 5 of 5

Thread: Lua made easy!

  1. #1
    Contributor
    runiker's Avatar
    Join Date
    Jul 2008
    Posts
    170
    Post Thanks / Like
    Rep Power
    18
    Reputation
    113

    Lua made easy!


    Register to remove this ad
    Hello and welcome to the new and improved guide to lua.
    I will split this into parts to make it easier to understand. This
    Guide uses color coding on a lot of the text just so you can see
    What is what.


    1. understanding lua as a whole
    2. Registering the events
    3. the events themselves
    4. registering events inside events
    5. Tables
    6. Pre-made lua scripts
    7. Portal making 101
    8. key points of new guide

    Understanding LUA as a whole

    LUA is much more then just world of warcraft it is the base of many games. For this Instance we will be just looking at Lua on wow because it would just be easier that Way and less time consuming. First off there are two main parts of lua The part that registers the event found at the bottom and the part that IS The event. The part that registers the event MUST be at the bottom of the script And must be the same name as the event itself. The event should always begain With the same name as the register.




    Registering the events
    The events I have listed are here for your Convenience. All you have to do is change The “Npc spawn ID” to the id that spawns The npc you want this script for As well as The “Name” Needs to be changed to the name of the creature. This part of the LUA Must be placed at the bottom.

    RegisterUnitEvent (Npc Spawn ID, 1, "Name_Entercombat")
    Using this will make the event happen when the player enters combat with the Npc that has this script enabled.

    RegisterUnitEvent (Npc Spawn ID, 2, "Name_Leavecombat")
    Using this will make the event happen when the player leaves combat with the Npc that has this script enabled.

    RegisterUnitEvent(Npc Spawn ID, 3, "Name_Killtarget")
    Using this will make the event happen when the Npc who has this script kills its target

    RegisterUnitEvent (Npc Spawn ID, 4, "Name_Died")T
    his event will happen when the npc has died

    RegisterUnitEvent (Npc Spawn ID, 5, "Name_AItick")
    Not sure yet???

    RegisterUnitEvent (Npc Spawn ID, 6, "Name_Spawn")
    This will happen when the npc is spawned

    RegisterUnitEvent (Npc Spawn ID, 7, "Name_Gossip")
    Not sure yet??

    RegisterUnitEvent (Npc Spawn ID, 8, "Name_waypoint")
    This will happen when player reaches waypoint

    RegisterUnitEvent (Npc Spawn ID, 9, "Name_leavelimbo")
    Not sure yet

    RegisterUnitEvent (Npc Spawn ID, 10, "Name_playerenter")
    This will happen when player reachs waypoint.

    RegisterGossipEvent(Npc Id , 1, "On_Gossip")(Npc Id, 2,"Gossip_Submenus")
    Makes a menu for those who know how to make a teleporter.


    RegisterGameObjectEvent (PORTALGUID, 2, "Nameofportal_onUse")
    Used for teleporting a player using a game object.

    ---note you will need at least one per event you would like to do
    so if you wanted to make the npc do something on waypoint AND
    combat you would need to make two making the bottom look like this



    RegisterUnitEvent (Npc Spawn ID, 1, "Name_Entercombat")
    RegisterUnitEvent (Npc Spawn ID, 8, "Name_waypoint")


    The events themselves

    pUnit:SendChatMessage(<type>, <language>, message)
    The npc will say the message (look at type and/or language codes to change)

    pUnit:MoveTo(x, y, z, o)
    This will move the npc to the xyzo location (look at the xyz part of the guide)

    pUnit:CastSpell(spellID)
    This will make the npc cast the spell with the spell id (look at thottbot for more spell ids)

    pUnit:FullCastSpell(spellID)
    Makes the npc cast a spell with full casting time (look at thottbot for more spell ids)

    pUnit:SpawnGameObject(entryID, x, y, z, o, duration)
    This will spawn a game object then despawn it after the time time is in milliseconds. (look at the xyz part of the guide)

    pUnit:SpawnCreature(entryID, x, y, z, o, faction, duration)
    This will spawn a npc then despawn it after the time, time is in milliseconds. (look at the xyz part of the guide)

    pUnit:PlaySoundToSet(soundID)
    This will play a sound to the area

    pUnit:SetMovementType(movementType)
    This will tell the npc how to move (movement types are fly and walk)

    pUnit:SetHealthPct(value)
    This will make the npcs health at specified percent

    pUnit:SetNPCFlags(flags)
    This will mark a flag on npc

    pUnit:SetModel(modelID)
    This will change the display of the npc

    pUnit:SetScale(scale)
    This will change the scale of npc

    pUnit:SetFaction(factionID)
    This will change the faction of the npc

    pUnit:SetModel(Display id)
    This will change the display of the npc


    -------This ends the the ones that I know work and work well---------
    -------Use the below ones only if you know what you are doing-----

    pUnit:SendAreaTriggerMessage(message)

    pUnit:KnockBack(dx, dy, affect1, affect2)

    pUnit:MarkQuestObjectiveAsComplete(questID, objective)
    Marks an objective of a quest as complete.

    pUnit:LearnSpell(spellID)
    Adds a spell to a unit.

    pUnit:UnlearnSpell(spellID)
    Removes a spell from a unit.

    pUnitespawn(delay, respawn)
    Despawns a unit after delay milliseconds and respawns it after respawn milliseconds.

    pUnit:PlaySoundToSet(soundID)
    Plays a sound to the surrounding area.

    pUnit:RemoveAura(auraID)
    Removes an aura from a unit.

    pUnit:StopMovement(time)
    Stops a unit from moving for time milliseconds.

    pMisc:AddItem(itemID, count)
    Adds a quantity of items to a unit.

    pUnit:RemoveItem(itemID, count)
    Removes a quantity of items from a unit.

    pUnit:CreateCustomWaypointMap()
    Creates a custom waypoint map.

    pUnit:CreateWaypoint(x, y, z, o, waitTime, flags, modelID)
    Adds a waypoint to the custom waypoint map.

    pUnitestroyCustomWaypointMap()
    Destroys a created custom waypoint map.

    pUnit:MoveToWaypoint(waypointID)
    Tells a unit to move to a particular waypoint.

    pUnit:SetCombatCapable(value)
    If value is 1 the unit cannot attack.

    pUnit:SetHealthPct(value)
    Sets the unit's health percentage.

    pUnit:SetNPCFlags(flags)
    Sets the NPC flags of a unit.

    pUnit:SetModel(modelID)
    Sets the model (display ID) of a unit.

    pUnit:SetScale(scale)
    Sets the scale (size) of a unit.

    pUnit:SetFaction(factionID)
    Sets the faction of a unit.

    pUnit:SetTauntedBy(unit)
    Sets the unit that taunted the current unit.

    pUnit:SetSoulLinkedWith(unit)
    Sets the unit that is soul linked with this unit.

    ---------Known to not work on some patch's use at risk--------

    pUnit:SendBroadcastMessage(message)
    This will broadcast the message across the whole server

    pUnit:Emote(emoteID)
    Tells a unit to perform an emote.

    pUnit:FullCastSpellOnTarget(spellID, unitTarget)
    Makes npc cast a spell on target. (look at thottbot for more spell ids)

    pUnit:CastSpellOnTarget(spellID, unitTarget)
    Cast spell on target (look at thottbot for more spell ids)

    pMisc:Teleport (MAPID, X, Y, Z)
    Teleports player to the map with x, y, z

    pUnit:GossipCreateMenu(100, player)
    Creates the menu itself

    pUnit:GossipMenuAddItem(player, 0, "Horde Cities", 1, 0)
    Add an item to the menu

    pUnit:GossipSendMenu(player)
    Sends player to this part of the menu

    Changing the red to what you need

    Spell-this can be found on thottbot or Wowhead it’s the last numbers of the page of spell
    Type-use the premade table I have made below
    Language-use the premade table I have made below
    Scale-this is how big you want it to get by multiplying it
    Modelid-this is the display id of the mob
    Flag-this can be found on *******
    Value-% at wich you would like the npc’s health
    Momenttype-you can pick fly or walk
    Soundid-you can find on *******
    Entryid- this is the same as the number used to spawn it
    Duration-how long until this is undone
    Faction- what faction would you like it
    Message-enter your message here
    X,Y,Z,O- these are found by typing .gps inside the server itself at the location you want.]
    Emoteid- The id of the emote search ******* for these
    Displayid- display id of what you want it to look like
    Time- Time is in milliseconds


    The Advanced if commands Use these commands if you want
    Whatever is between the then and the end Tags to work
    only when it is a yes.



    GetName()
    This will return the units name

    GetX()
    This will return the units X position.

    GetY()
    This will return the units Y position.

    GetZ()
    This will return the units Z position.

    GetO()
    This will return the units orientation.

    IsPlayer() then
    This will make the commands below it work only If the target is a player

    IsCreature() then
    This will make the commands below work if the target is a creature

    ☼HasFinishedQuest(questID) then
    This will work only if the target has finished quest id

    ☼GetItemCount(itemID)<#then
    This will tell if how many of the items player has

    ☼GetHealthPct()<%then
    This will tell it to only do it if the health is at a percent

    ☼GetUnitBySqlId(sqlID)then
    Returns a unit from the sql ID.

    ☼GetClosestPlayer() then
    This will target the nearest player

    ☼GetRandomPlayer(flags)
    Returns a random in-range unit that is a player.
    The flag is to check what type of random

    - GetRandomPlayer(0) = Random Player
    - GetRandomPlayer(1) = Random in Short-Range
    - GetRandomPlayer(2) = Random in Mid-Range
    - GetRandomPlayer(3) = Random in Long-Range
    - GetRandomPlayer(4) = Random with Mana
    - GetRandomPlayer(5) = Random with Rage
    - GetRandomPlayer(6) = Random With Energy
    - GetRandomPlayer(7) = Random NOT Main-Tank


    ☼GetRandomFriend()
    Returns a random in-range unit that is a player and is friendly towards the current player.

    ☼GetMainTank()
    Returns the main tank (most hated).

    ☼GetAddTank()
    Returns the add tank (second most hated).

    ☼GetTauntedBy()
    Returns the player that taunted the unit.


    ☼GetSoulLinkedWith()
    Returns the unit that is set as the soul link for this unit.



    Registering events inside events

    RegisterUnitEvent(225501, 1, "Vanity_OnCombat")
    Is to register the event itself but if you wanted to make
    Events inside an event you would use
    Unit:RegisterEvent("Vanity_Phase1",1000, 0)
    And then for the sub event you would use
    function Vanity_Phase1(Unit, event)lets put them all together to show
    you what I mean. Hope this helps out people wondering about two part
    events.


    ---code----
    function Vanity_Phase1(Unit, event)
    if Unit:GetHealthPct() < 95 then
    Unit:RemoveEvents()
    Unit:SendChatMessage(11, 0, "You think you can beat me")
    Unit:RegisterEvent("Vanity_Phase2",1000, 0)
    end
    end



    function Vanity_Phase2(Unit, event)
    if Unit:GetHealthPct() < 80 then
    Unit:RemoveEvents()
    Unit:CastSpell(22436)
    end
    end


    function Vanity_OnCombat(Unit, event)
    Unit:SendChatMessage(11, 0, "Do i have to kill you are no equal?")
    Unit:RegisterEvent("Vanity_Phase1",1000, 0)
    Unit:RegisterEvent("Vanity_Phase2",1000, 0)
    end

    ---end of code-----


    Tables and codes
    <Language>0 = UNIVERSAL
    1 = ORCISH
    2 = DARNASSIAN
    3 = TAURAHE
    6 = DWARVISH
    7 = COMMON
    8 = DEMONIC
    9 = TITAN
    10 = THELASSIAN
    11 = DRACONIC
    12 = KALIMAG
    13 = GNOMISH
    14 = TROLL
    33 = GUTTERSPEAK
    35 = DRAENEI<Talk>-1 = ADDON
    0 = SAY
    1 = PARTY
    2 = RAID
    3 = GUILD
    4 = OFFICER
    5 = YELL
    6 = WHISPER
    7 = WHISPER_INFORM
    8 = EMOTE
    9 = TEXT_EMOTE
    10 = SYSTEM
    11 = MONSTER_SAY
    12 = MONSTER_YELL

    13 = MONSTER_WHISPER
    14 = CHANNEL
    16 = CHANNEL_JOIN
    17 = CHANNEL_LEAVE
    18 = CHANNEL_LIST
    19 = CHANNEL_NOTICE
    20 = CHANNEL_NOTICE_USER
    21 = AFK
    22 = DND
    23 = COMBAT_LOG
    24 = IGNORED
    25 = SKILL32 = LOOT
    83 = BATTLEGROUND_EVENT
    87 = RAIDLEADER
    88 = RAIDWARNING



    › See More: Lua made easy!
    Last edited by runiker; 19-08-08 at 06:28 AM.



  2. Related Threads - Scroll Down after related threads if you are only interested to view replies for above post/thread

  3. #2
    Founder
    Apple's Avatar
    Join Date
    Jul 2008
    Location
    HeaveN
    Posts
    15,916
    Post Thanks / Like
    Rep Power
    10
    Reputation
    295
    Nice one runiker +Rep





  4. #3
    Scout
    Soulja02's Avatar
    Join Date
    Aug 2008
    Location
    localhost
    Posts
    26
    Post Thanks / Like
    Rep Power
    17
    Reputation
    37
    cheer runiker

  5. #4
    Grunt
    Wolfly's Avatar
    Join Date
    Aug 2008
    Location
    Estonia
    Posts
    33
    Post Thanks / Like
    Rep Power
    17
    Reputation
    19
    If I wanted a Gameobject to spawn a random of creature from a selection of four, what would I need to do to make it choose from the four?

  6. #5
    Beginner

    Join Date
    May 2010
    Posts
    5
    Post Thanks / Like
    Rep Power
    15
    Reputation
    1

    Register to remove this ad
    Truly [Epic] Thanks man

 

 

Visitors found this page by searching for:

Lua made easy

lua hmade easylua menu made easylua made asy
SEO Blog

Tags for this Thread

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •  
All times are GMT -5. The time now is 05:31 PM.
Powered by vBulletin® Copyright ©2000-2024, Jelsoft Enterprises Ltd.
See More links by ForumSetup.net. Feedback Buttons provided by Advanced Post Thanks / Like (Lite) - vBulletin Mods & Addons Copyright © 2024 DragonByte Technologies Ltd.
vBulletin Licensed to: MMOPro.org