From 71149462788e72a731bcb0a496f9ad220603f126 Mon Sep 17 00:00:00 2001 From: Eduardo Bart Date: Tue, 23 Oct 2012 17:15:59 -0200 Subject: [PATCH] Fix issue #112 --- modules/game_console/console.lua | 17 +++++++++++------ modules/game_textmessage/textmessage.lua | 4 ++++ 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/modules/game_console/console.lua b/modules/game_console/console.lua index d5a61079..b7677c17 100644 --- a/modules/game_console/console.lua +++ b/modules/game_console/console.lua @@ -350,21 +350,21 @@ function addTabText(text, speaktype, tab, creatureName) for letter = lastBlockEnd, dataBlock._start-1 do local tmpChar = string.byte(drawText:sub(letter, letter)) local fillChar = (tmpChar == 10 or tmpChar == 32) and string.char(tmpChar) or string.char(127) - + tmpText = tmpText .. string.rep(fillChar, letterWidth[tmpChar]) end tmpText = tmpText .. dataBlock.words end - + -- Fill the highlight label to the same size as default label local finalBlockEnd = (highlightData[(#highlightData/3-1)*3+2] or 1) for letter = finalBlockEnd, drawText:len() do local tmpChar = string.byte(drawText:sub(letter, letter)) local fillChar = (tmpChar == 10 or tmpChar == 32) and string.char(tmpChar) or string.char(127) - + tmpText = tmpText .. string.rep(fillChar, letterWidth[tmpChar]) end - + labelHighlight:setText(tmpText) end else @@ -544,6 +544,11 @@ function applyMessagePrefixies(name, level, message) end function onTalk(name, level, mode, message, channelId, creaturePos) + if mode == MessageModes.GamemasterBroadcast then + modules.game_textmessage.displayBroadcastMessage(name .. ': ' .. message) + return + end + if ignoreNpcMessages and mode == MessageModes.NpcFrom then return end if (mode == MessageModes.Say or mode == MessageModes.Whisper or mode == MessageModes.Yell or @@ -561,7 +566,7 @@ function onTalk(name, level, mode, message, channelId, creaturePos) end end end - + local staticText = StaticText.create() staticText:addMessage(name, mode, staticMessage) g_map.addThing(staticText, creaturePos, -1) @@ -583,7 +588,7 @@ function onTalk(name, level, mode, message, channelId, creaturePos) if speaktype.private then addPrivateText(composedMessage, speaktype, name, false, name) - if Options.getOption('showPrivateMessagesOnScreen') and speaktype ~= SpeakTypesSettings.privateNpcToPlayer then + if Options.getOption('showPrivateMessagesOnScreen') and speaktype ~= SpeakTypesSettings.privateNpcToPlayer then modules.game_textmessage.displayPrivateMessage(name .. ':\n' .. message) end else diff --git a/modules/game_textmessage/textmessage.lua b/modules/game_textmessage/textmessage.lua index 65e3fc08..1a53ea22 100644 --- a/modules/game_textmessage/textmessage.lua +++ b/modules/game_textmessage/textmessage.lua @@ -107,6 +107,10 @@ function displayGameMessage(text) displayMessage(MessageModes.Game, text) end +function displayBroadcastMessage(text) + displayMessage(MessageModes.Warning, text) +end + function clearMessages() for _i,child in pairs(messagesPanel:recursiveGetChildren()) do if child:getId():match('Label') then