Difference between revisions of "OnConversation"

From NWN Lexicon
Jump to: navigation, search
Line 26: Line 26:
  
 
<nwscript>
 
<nwscript>
// When we here shout 100, we hear anything (See SetListeningPattern),  
+
// When we here shout 100, we hear anything (See SetListeningPattern),  
// and we can check if they spoke the right password.
+
// and we can check if they spoke the right password.
+
 
void main()
+
void main()
{
+
{
    // Get the number
+
    // Get the number
    int nMatch = GetListenPatternNumber();
+
    int nMatch = GetListenPatternNumber();
+
 
    // If nMatch is -1, it means we were clicked on
+
    // If nMatch is -1, it means we were clicked on
    if(nMatch == -1)
+
    if(nMatch == -1)
    {
+
    {
        SpeakString("Stop touching me!");
+
        SpeakString("Stop touching me!");
    }
+
    }
    // We only check for the password if nMatch is 100, IE: "**"
+
    // We only check for the password if nMatch is 100, IE: "**"
    else if(nMatch == 100)
+
    else if(nMatch == 100)
    {
+
    {
        // Get string they spoke (Set up via.
+
        // Get string they spoke (Set up via.
        // SetListenPattern(OBJECT_SELF, "**", 100); )
+
        // SetListenPattern(OBJECT_SELF, "**", 100); )
        // We will get it in capitals (so not case sensitive).
+
        // We will get it in capitals (so not case sensitive).
        // * Note: GetMatchedSubstring will only be 1 value for **,  
+
        // * Note: GetMatchedSubstring will only be 1 value for **,  
        //    so we get the 0 value for it.
+
        //    so we get the 0 value for it.
        string sSpoken = GetStringUpperCase(GetMatchedSubstring(0));
+
        string sSpoken = GetStringUpperCase(GetMatchedSubstring(0));
+
 
        // The password is "happy".
+
        // The password is "happy".
        if(FindSubString(sSpoken, "HAPPY") &gt;= 0)
+
        if(FindSubString(sSpoken, "HAPPY") &gt;= 0)
        {
+
        {
            SpeakString("You got the password correct!");
+
            SpeakString("You got the password correct!");
        }
+
        }
    }
+
    }
}
+
}
 
</nwscript>
 
</nwscript>
  

Revision as of 01:41, 26 August 2012

OnConversation

The script attached to this event fires whenever the dialogue with another creature ends or when a shout is heard. PC's speaking can fire this, and is a good way of getting them to specifically answer a riddle or password.


Trigger

The creature has been clicked on for conversation or someone has audibly spoken.


Function(s)

GetMatchedSubstring(int nString) will return a string heard, or part of the string heard that triggered the event (If you use * in the setup).


Remarks

By default, if the creature has been clicked on for conversation, it will stop what it is doing and begin dialogue (if it can). Otherwise the script checks to see if a spoken (sometimes typed) phrase is recognizeable and if the creature has been set up to recognize combat shouts. Only if the creature is listening (SetListening) will this event fire at all. Once the creature is set to listening, they will only hear things set by SetListeningPattern. The script nw_g0_conversat will fire if there is no OnConversation script supplied, and will start thier conversation if it is someone clicking on them. This also applies to PC's, and you can see for yourself when they face you and speak thier hello voicechat, in game, by using "Conversation" on them.


Example

// When we here shout 100, we hear anything (See SetListeningPattern), 
// and we can check if they spoke the right password.
 
void main()
{
    // Get the number
    int nMatch = GetListenPatternNumber();
 
    // If nMatch is -1, it means we were clicked on
    if(nMatch == -1)
    {
        SpeakString("Stop touching me!");
    }
    // We only check for the password if nMatch is 100, IE: "**"
    else if(nMatch == 100)
    {
        // Get string they spoke (Set up via.
        // SetListenPattern(OBJECT_SELF, "**", 100); )
        // We will get it in capitals (so not case sensitive).
        // * Note: GetMatchedSubstring will only be 1 value for **, 
        //    so we get the 0 value for it.
        string sSpoken = GetStringUpperCase(GetMatchedSubstring(0));
 
        // The password is "happy".
        if(FindSubString(sSpoken, "HAPPY") &gt;= 0)
        {
            SpeakString("You got the password correct!");
        }
    }
}

See Also

functions: 

GetMatchedSubstring()