Advertisement
Guest User

Untitled

a guest
Oct 22nd, 2012
229
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 9.31 KB | None | 0 0
  1. -- [[ INIT START ]] --
  2. --
  3. -- 88
  4. -- "" ,d
  5. -- 88
  6. -- ,adPPYba, 88 8b,dPPYba, 88,dPYba,,adPYba, ,adPPYYba, MM88MMM ,adPPYba,
  7. -- I8[ "" 88 88P' "Y8 88P' "88" "8a "" `Y8 88 a8P_____88
  8. -- `"Y8ba, 88 88 88 88 88 ,adPPPPP88 88 8PP"""""""
  9. -- aa ]8I 88 88 88 88 88 88, ,88 88, "8b, ,aa
  10. -- Author: `"YbbdP"' 88 88 88 88 88 `"8bbdP"Y8 "Y888 `"Ybbd8"'
  11. --
  12. -- Monitor My Hunting!
  13. --
  14. -- Version: 1.0
  15. -- Created: 7.09.2012
  16. -- Last update: 18.09.2012
  17. --
  18.  
  19. MONITOR_MY_HUNTING = MONITOR_MY_HUNTING or {
  20. SCRIPT_NAME = "Monitor My Hunting",
  21. SCRIPT_VERSION = "1.0",
  22.  
  23. CLEARED_STATS = false,
  24. INITIALIZED = false,
  25. }
  26.  
  27. MONITOR_MY_HUNTING.SHOW_ALL_ITEMS = false
  28. MONITOR_MY_HUNTING.ITEMS_LIST = {
  29. {NAME = "gold coin", VALUE = 1},
  30. {NAME = "life crystal", VALUE = 500},
  31. {NAME = "small sapphire", VALUE = 250},
  32. {NAME = "green mushroom", VALUE = 100},
  33. {NAME = "frosty heart", VALUE = 280},
  34. {NAME = "strange helmet", VALUE = 500},
  35. {NAME = "ice rapier", VALUE = 1000},
  36. {NAME = "shard", VALUE = 2000},
  37. {NAME = "tower shield", VALUE = 8000},
  38. {NAME = "dragon slayer", VALUE = 15000},
  39. {NAME = "royal helmet", VALUE = 30000},
  40. {NAME = "dragon scale mail", VALUE = 40000},
  41. {NAME = "spellbook of enlightenment", VALUE = 4000},
  42. }
  43.  
  44. MONITOR_MY_HUNTING.SHOW_ALL_SUPPLIES = false
  45. MONITOR_MY_HUNTING.SUPPLIES_LIST = {
  46. {NAME = "strong mana potion", PRICE = 80},
  47. {NAME = "prismatic bolt", PRICE = 20},
  48. }
  49. -- [[ DO NOT CHANGE ANYTHING BELOW THIS LINE. ]] --
  50.  
  51. MONITOR_MY_HUNTING.TEMP_ITEMS_LIST = MONITOR_MY_HUNTING.TEMP_ITEMS_LIST or {}
  52. MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST = MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST or {}
  53. MONITOR_MY_HUNTING.COLORS = MONITOR_MY_HUNTING.COLORS or {
  54. BLACK = rgbcolor(1, 1, 1),
  55. ORANGE = rgbcolor(255, 165, 0),
  56. BLUE = rgbcolor(30, 144, 255),
  57. CORNSILK = rgbcolor(205, 200, 177),
  58. WHITE = rgbcolor(255, 255, 255),
  59. GREEN = rgbcolor(107, 142, 35),
  60. RED = rgbcolor(178, 34, 34),
  61. }
  62.  
  63. local function CreateMessageObject(MESSAGE_DATA)
  64. if (type(MESSAGE_DATA) ~= "userdata") then
  65. return setmetatable({__data = {TYPE = -1, TIME_STAMP = -1, SENDER_NAME = "", SENDER_LEVEL = -1, CONTENT = ""}}, MessageMetaTable)
  66. else
  67. return setmetatable({__data = {TYPE = MESSAGE_DATA.type, TIME_STAMP = Misc.ConvertToSeconds(string.sub(MESSAGE_DATA.text, 1, 5)), SENDER_NAME = MESSAGE_DATA.sender, SENDER_LEVEL = tonumber((tostring(string.match(MESSAGE_DATA.text, ".+ (%b[]): .+")):gsub("[^%d]", ""))) or 0, CONTENT = string.sub(MESSAGE_DATA.text, 7)}}, MessageMetaTable)
  68. end
  69. end
  70.  
  71. local function addtextshadow(DISPLAY_TEXT, X_OFFSET, Y_OFFSET, FONT_COLOR)
  72. setfontcolor(MONITOR_MY_HUNTING.COLORS.BLACK)
  73. addtext(DISPLAY_TEXT, X_OFFSET + 1, Y_OFFSET + 1)
  74. setfontcolor(FONT_COLOR)
  75. addtext(DISPLAY_TEXT, X_OFFSET, Y_OFFSET)
  76. end
  77. -- [[ INIT END ]] --
  78.  
  79. if (not Stats.Update()) then
  80. local SERVER_LOG_MESSAGES = getnewmessages("Server Log")
  81. local SERVER_LOG_MESSAGES_COUNT = SERVER_LOG_MESSAGES.count - 1
  82.  
  83. for INDEX = 0, SERVER_LOG_MESSAGES_COUNT do
  84. local MESSAGE_OBJECT = CreateMessageObject(SERVER_LOG_MESSAGES[SERVER_LOG_MESSAGES_COUNT - INDEX])
  85.  
  86. if (MESSAGE_OBJECT:Type() == 19 and MESSAGE_OBJECT:Content():lower():match("^loot of")) then
  87. local LOOT_INFO = Message.ParseLootMessage(MESSAGE_OBJECT, true)
  88.  
  89. if (#LOOT_INFO.NAME > 0) then
  90. Stats.__data.MONSTERS_KILLED[LOOT_INFO.NAME] = (Stats.__data.MONSTERS_KILLED[LOOT_INFO.NAME] or 0) + 1
  91.  
  92. for _, LOOT_ITEM in ipairs(LOOT_INFO.ITEMS) do
  93. if (Stats.__data.ITEMS_LOOTED[LOOT_ITEM.ID]) then
  94. Stats.__data.ITEMS_LOOTED[LOOT_ITEM.ID].QUANTITY = Stats.__data.ITEMS_LOOTED[LOOT_ITEM.ID].QUANTITY + LOOT_ITEM.QUANTITY
  95. else
  96. Stats.__data.ITEMS_LOOTED[LOOT_ITEM.ID] = {ID = LOOT_ITEM.ID, NAME = LOOT_ITEM.NAME, QUANTITY = LOOT_ITEM.QUANTITY, VALUE = Item.GetValue(LOOT_ITEM.ID)}
  97. end
  98. end
  99. end
  100. end
  101. end
  102. end
  103.  
  104. local RESET_ITEMS_AND_SUPPLIES = #MONITOR_MY_HUNTING.ITEMS_LIST ~= #MONITOR_MY_HUNTING.TEMP_ITEMS_LIST or #MONITOR_MY_HUNTING.SUPPLIES_LIST ~= #MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST
  105.  
  106. if (not RESET_ITEMS_AND_SUPPLIES) then
  107. for INDEX, LOOT_ITEM in ipairs(MONITOR_MY_HUNTING.ITEMS_LIST) do
  108. if (LOOT_ITEM.NAME ~= MONITOR_MY_HUNTING.TEMP_ITEMS_LIST[INDEX].NAME or LOOT_ITEM.VALUE ~= MONITOR_MY_HUNTING.TEMP_ITEMS_LIST[INDEX].VALUE) then
  109. RESET_ITEMS_AND_SUPPLIES = true
  110. break
  111. end
  112. end
  113. end
  114.  
  115. if (not RESET_ITEMS_AND_SUPPLIES) then
  116. for INDEX, SUPPLY_ITEM in ipairs(MONITOR_MY_HUNTING.SUPPLIES_LIST) do
  117. if (SUPPLY_ITEM.NAME ~= MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST[INDEX].NAME or SUPPLY_ITEM.PRICE ~= MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST[INDEX].PRICE) then
  118. RESET_ITEMS_AND_SUPPLIES = true
  119. break
  120. end
  121. end
  122. end
  123.  
  124. if (not MONITOR_MY_HUNTING.INITIALIZED or RESET_ITEMS_AND_SUPPLIES) then
  125. if (not MONITOR_MY_HUNTING.CLEARED_STATS) then
  126. Stats.Clear(CLEAR_STATS_ALL)
  127. Stats.Update()
  128.  
  129. MONITOR_MY_HUNTING.CLEARED_STATS = true
  130. end
  131.  
  132. MONITOR_MY_HUNTING.TEMP_ITEMS_LIST, MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST = {}, {}
  133.  
  134. for _, LOOT_ITEM in ipairs(MONITOR_MY_HUNTING.ITEMS_LIST) do
  135. local LOOT_ITEM_ID = Item.GetID(type(LOOT_ITEM.NAME) ~= "table" and LOOT_ITEM.NAME or unpack(LOOT_ITEM.NAME))
  136.  
  137. Stats.AddItemsLooted(LOOT_ITEM_ID, 0, LOOT_ITEM.VALUE)
  138. table.insert(MONITOR_MY_HUNTING.TEMP_ITEMS_LIST, {ID = LOOT_ITEM_ID, NAME = LOOT_ITEM.NAME, VALUE = LOOT_ITEM.VALUE})
  139. end
  140.  
  141. for _, SUPPLY_ITEM in ipairs(MONITOR_MY_HUNTING.SUPPLIES_LIST) do
  142. local SUPPLY_ITEM_ID = Item.GetID(type(SUPPLY_ITEM.NAME) ~= "table" and SUPPLY_ITEM.NAME or unpack(SUPPLY_ITEM.NAME))
  143.  
  144. Stats.AddSuppliesUsed(SUPPLY_ITEM_ID, 0, SUPPLY_ITEM.PRICE)
  145. table.insert(MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST, {ID = SUPPLY_ITEM_ID, NAME = SUPPLY_ITEM.NAME, PRICE = SUPPLY_ITEM.PRICE})
  146. end
  147.  
  148. MONITOR_MY_HUNTING.INITIALIZED = true
  149. end
  150.  
  151. setposition(Client.ClientWindow().left + 10, Client.WorldWindow().top + 180)
  152.  
  153. local Y_POSITION, INDEX, ITEMS_LOOTED_WORTH, SUPPLIES_USED_WORTH = 30, 0, 0, 0
  154.  
  155. addtextshadow(sprintf("%s v%s", MONITOR_MY_HUNTING.SCRIPT_NAME:upper(), MONITOR_MY_HUNTING.SCRIPT_VERSION), 10, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.ORANGE)
  156.  
  157. Y_POSITION = Y_POSITION + 20
  158.  
  159. addtextshadow("ITEMS LOOTED", 10, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.BLUE)
  160.  
  161. Y_POSITION = Y_POSITION + 20
  162.  
  163. for _, LOOT_ITEM in pairs(Stats.GetItemsLooted()) do
  164. if ((MONITOR_MY_HUNTING.SHOW_ALL_ITEMS or table.find(MONITOR_MY_HUNTING.TEMP_ITEMS_LIST, LOOT_ITEM.ID, "ID")) and LOOT_ITEM.QUANTITY > 0) then
  165. addtextshadow(((#LOOT_ITEM.NAME > 17 and sprintf("%s...", string.match(string.sub(LOOT_ITEM.NAME, 1, 17), "(.-)%s?$"))) or LOOT_ITEM.NAME):ucwords(), 10, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.CORNSILK)
  166. addtextshadow(sprintf("%s (%sK)", Misc.FormatNumber(LOOT_ITEM.QUANTITY), tostring(math.floor(LOOT_ITEM.VALUE * LOOT_ITEM.QUANTITY / 100) / 10)), 140, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.WHITE)
  167.  
  168. INDEX, ITEMS_LOOTED_WORTH = INDEX + 1, ITEMS_LOOTED_WORTH + (LOOT_ITEM.VALUE * LOOT_ITEM.QUANTITY)
  169. end
  170. end
  171.  
  172. addtextshadow("Total:", 10, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.WHITE)
  173. addtextshadow(sprintf("%s GPs", Misc.FormatNumber(ITEMS_LOOTED_WORTH)), 10 + 35, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.ORANGE)
  174.  
  175. Y_POSITION = Y_POSITION + 20
  176.  
  177. addtextshadow("SUPPLIES USED", 10, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.BLUE)
  178.  
  179. Y_POSITION = Y_POSITION + 20
  180.  
  181. for _, SUPPLY_ITEM in pairs(Stats.GetSuppliesUsed()) do
  182. if ((MONITOR_MY_HUNTING.SHOW_ALL_SUPPLIES or table.find(MONITOR_MY_HUNTING.TEMP_SUPPLIES_LIST, SUPPLY_ITEM.ID, "ID")) and SUPPLY_ITEM.QUANTITY > 0) then
  183. addtextshadow(((#SUPPLY_ITEM.NAME > 17 and sprintf("%s...", string.match(string.sub(SUPPLY_ITEM.NAME, 1, 17), "(.-)%s?$"))) or SUPPLY_ITEM.NAME):ucwords(), 10, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.CORNSILK)
  184. addtextshadow(sprintf("%s (%sK)", Misc.FormatNumber(SUPPLY_ITEM.QUANTITY), tostring(math.floor(SUPPLY_ITEM.PRICE * SUPPLY_ITEM.QUANTITY / 100) / 10)), 140, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.WHITE)
  185.  
  186. INDEX, SUPPLIES_USED_WORTH = INDEX + 1, SUPPLIES_USED_WORTH + (SUPPLY_ITEM.PRICE * SUPPLY_ITEM.QUANTITY)
  187. end
  188. end
  189.  
  190. addtextshadow("Total:", 10, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.WHITE)
  191. addtextshadow(sprintf("%s GPs", Misc.FormatNumber(SUPPLIES_USED_WORTH)), 10 + 35, Y_POSITION + (INDEX * 16), MONITOR_MY_HUNTING.COLORS.ORANGE)
  192.  
  193. Y_POSITION = Y_POSITION + 20
  194.  
  195. addtextshadow(sprintf("%s: %s GPs (%s K/H)", ((ITEMS_LOOTED_WORTH >= SUPPLIES_USED_WORTH and ("PROFIT")) or ("WASTE")), Misc.FormatNumber(ITEMS_LOOTED_WORTH - SUPPLIES_USED_WORTH), tostring(math.floor(((ITEMS_LOOTED_WORTH - SUPPLIES_USED_WORTH) * 3600) / (System.HuntingTime() / 1000) / 100) / 10)), 10, Y_POSITION + (INDEX * 16), ITEMS_LOOTED_WORTH >= SUPPLIES_USED_WORTH and MONITOR_MY_HUNTING.COLORS.GREEN or MONITOR_MY_HUNTING.COLORS.RED)
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement