Module:Utilities: Difference between revisions
Jump to navigation
Jump to search
m px parameterized, default to 15 |
m no px provided not working |
||
Line 23: | Line 23: | ||
-- If the image exists exists, return it back enclosed in brackets, else return a blank string | -- If the image exists exists, return it back enclosed in brackets, else return a blank string | ||
function p.get_image_file(image_file_name, px) | function p.get_image_file(image_file_name, px) | ||
image_file = mw.title.new(image_file_name) | image_file = mw.title.new(image_file_name) | ||
if image_file and image_file.exists then | if image_file and image_file.exists then |
Revision as of 03:08, 18 September 2024
Overview
Utility functions that serve any miscellaneous purpose
Functions
get_slot_color
Retrieve's the color of a certain slot/category in any color format (default hex), formerly known in english as Weapon, Vitality, and Spirit, though their unlocalized names are Weapon, Armor, and Tech. Utilized by Template:SlotColor
Parameters
- slot - slot key, options are Weapon, Armor, and Tech
- color_format - color format - Defaults to hex. Valid options are hex, rgb, hsl, cmyk
- no_wrap - (OPTIONAL) - Defaults to false. Set to true to remove prefixes and postfixes of '#' from hex, or 'rgb()', 'hsl()', and 'cmyk()' from the other formats. May be useful for altering the values dynamically
- debug_mode - (OPTIONAL) - Defaults to false. Used mostly for documentation purposes
Examples
See examples at Template:SlotColor
local p = {};
--round_to_significant_figures(12345.6789, 3) -- Output: 12300
--round_to_significant_figures(0.0012345, 2) -- Output: 0.0012
--round_to_significant_figures(-98765, 4) -- Output: -98760
function p.round_to_sig_fig(num, n)
if num == 0 then
return 0
end
-- Calculate the order of magnitude (log10 returns the logarithm base 10)
local order_of_magnitude = math.floor(math.log10(math.abs(num)))
-- Scale the number to move the significant digits into the integer part
local scale = math.pow(10, n - 1 - order_of_magnitude)
-- Round the scaled number and then scale it back
local rounded_num = math.floor(num * scale + 0.5) / scale
return rounded_num
end
-- If the image exists exists, return it back enclosed in brackets, else return a blank string
function p.get_image_file(image_file_name, px)
image_file = mw.title.new(image_file_name)
if image_file and image_file.exists then
image_file_name = "[[" .. image_file_name .. "|" .. px .. "px]]"
else
image_file_name = ''
end
return image_file_name
end
return p