More on, in the unix vm, the behavior is the following:<br><br>when pressing p:<br><br>key: 112 char: 112 type: keyDown<br>key: 112 char: 112 type: keystroke<br>key: 112 char: 112 type: keyUp<br><br>when pressing shift + p (P):<br>
key: 254 char: 254 type: keyDown<br>key: 80 char: 80 type: keyDown<br>key: 80 char: 80 type: keystroke<br>key: 80 char: 80 type: keyUp<br><br><br>F1, after adding support for Function keys,<br>key: 16 char: 16 type: keyDown<br>
key: 16 char: 16 type: keyUp<br><br>While in the windows vm:<br><br>when pressing p (the problematic one):<br><br>key: 80 char: 80 type: keyDown<br>
key: 112 char: 112 type: keystroke<br>
key: 80 char: 80 type: keyUp<br>
<br>
when pressing shift + p (P) works the same, since P char value is the same as P virtual key value:<br>
<br>key: 16 char: 16 type: keyDown<br>
key: 80 char: 80 type: keyDown<br>
key: 80 char: 80 type: keystroke<br>
key: 80 char: 80 type: keyUp<br>
<br>
<br>
F1, without touching the code, shares the same keycode than p:<br><br>
key: 112 char: 112 type: keyDown<br>
key: 112 char: 112 type: keyUp<br>
<br>Guille<br><br><div class="gmail_quote">On Thu, Jan 26, 2012 at 11:43 AM, Guillermo Polito <span dir="ltr">&lt;<a href="mailto:guillermopolito@gmail.com">guillermopolito@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div>The question is:</div><div><br></div><div>Should KeyDown, KeyUp and KeyChar events for the same key produce the same keyCode?  I think yes.  Because the keyCode indicates the key pressed in the keyboard. Doesn&#39;t it?</div>

<div><br></div><div>Now, utf32Code should be only used on KeyChar events, and I don&#39;t care about them.</div><div><br></div><div>How does it work now?</div><div><br></div><div>(KeyDown, KeyUp) and KeyChar events send different keyCodes to the image.</div>

<div><br></div><div>Ok, right now works because in no place in the image keyDown: is handled, but that&#39;s no excuse :).</div><div><br></div><div>Regards,</div><div>Guille</div><div class="HOEnZb"><div class="h5"><div>
<br><div class="gmail_quote">On Thu, Jan 26, 2012 at 11:17 AM, Guillermo Polito <span dir="ltr">&lt;<a href="mailto:guillermopolito@gmail.com" target="_blank">guillermopolito@gmail.com</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Sure!<div><br></div><div>I&#39;m not generating Char events for F11 ;).  Since F11 does not generate Char events.</div>

<div><br></div><div>The problem is that the <i>p</i> key generates the same KeyDown event than F11 for the vm.  I&#39;m only fixing that:</div>
<div><br></div><div>KeyDown and KeyUp events for p key and F1 keys have different keyCodes.  I&#39;m not sure if there will still be collisions, but right now, they are with the code as it is.</div><div><br></div><div>Guille<br>


<br><div class="gmail_quote">On Thu, Jan 26, 2012 at 11:02 AM, Andreas Raab <span dir="ltr">&lt;<a href="mailto:andreas.raab@gmx.de" target="_blank">andreas.raab@gmx.de</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


 <br>
  
    
  
  <div bgcolor="#FFFFFF" text="#000000"><div><div>
    On 1/26/2012 14:52, Guillermo Polito wrote:
    <blockquote type="cite">
      <pre> </pre>
      <br>
      <fieldset></fieldset>
      <br>
      Hi!
      <div><br>
      </div>
      <div>I was playing to add Function Ket support in the windows vm
        (yep, always the same :P), and looking at the code, I saw this
        in the recordKeyboardEvent:</div>
      <div><br>
      </div>
      <div>
        <div>evt = (sqKeyboardEvent*) sqNextEventPut();</div>
        <div>  evt-&gt;type = EventTypeKeyboard;</div>
        <div>  evt-&gt;timeStamp = msg-&gt;time;</div>
        <div><b>  evt-&gt;charCode = keymap[keyCode &amp; 0xff];</b></div>
      </div>
      <div><b><br>
        </b></div>
      <div>the problem with that line is that KeyDown and KeyUp events
        send VirtualKeycodes as keycodes and the Char event sends a
        unicode char value.  And, it makes collisions, since for example</div>
      <div><br>
      </div>
      <div>$p char value is 112</div>
      <div>and F1 virtual code value is 112 too :P</div>
      <div><br>
      </div>
      <div><a href="http://msdn.microsoft.com/en-us/library/windows/desktop/ms646276%28v=vs.85%29.aspx" target="_blank">http://msdn.microsoft.com/en-us/library/windows/desktop/ms646276(v=vs.85).aspx</a>
      </div>
      <div><a href="http://msdn.microsoft.com/en-us/library/windows/desktop/ms646281%28v=vs.85%29.aspx" target="_blank">http://msdn.microsoft.com/en-us/library/windows/desktop/ms646281(v=vs.85).aspx</a>
      </div>
      <div><a href="http://msdn.microsoft.com/en-us/library/windows/desktop/dd375731%28v=vs.85%29.aspx" target="_blank">http://msdn.microsoft.com/en-us/library/windows/desktop/dd375731(v=vs.85).aspx</a>
      </div>
      <div><br>
      </div>
      <div>And so with other keys, having the same keycode in the image
        side with different keys...</div>
      <div><br>
      </div>
      <div>I&#39;m trying a solution like this, providing in a Char event
        the keycode without mapping to the image:</div>
      <div><br>
      </div>
      <div>...</div>
      <div>
        <div>    case WM_CHAR:</div>
        <div>    case WM_SYSCHAR:</div>
        <div>      /* Note: VK_RETURN is recorded as virtual key ONLY */</div>
        <div>      if(keyCode == 13) return 1;</div>
        <div>    <b>  charCode = keyCode;</b></div>
        <div>      pressCode = EventKeyChar;</div>
      </div>
      <div>     break</div>
      <div>...</div>
      <div> evt-&gt;timeStamp = msg-&gt;time;</div>
      <div>
        <div><b>  evt-&gt;charCode = charCode? charCode : keymap[keyCode
            &amp; 0xff];</b></div>
        <div>
            evt-&gt;pressCode = pressCode;</div>
      </div>
      <div>...</div>
      <div><br>
      </div>
      <div>changing only the bold lines, and It seems to work.</div>
      <div><br>
      </div>
      <div>What do you think?</div>
    </blockquote>
    <br></div></div>
    The change makes no sense (it will break most non-ascii input like
    accents, umlauts, etc). You really shouldn&#39;t be using character
    events for handling function keys. There is no &#39;F11 Character&#39; in
    any character encoding world-wide so trying to represent F11 as a
    character is completely futile. You need to use keyDown and keyUp
    events, since F11 &amp; friends are KEYs not CHARACTERs.<br>
    <br>
    Cheers,<br>
      - Andreas<br>
    <br>
    <br>
    <blockquote type="cite">
      <div>Guille</div>
    </blockquote>
  </div>

<br></blockquote></div><br></div>
</blockquote></div><br></div>
</div></div></blockquote></div><br>