Backspace bug again in 5.3 b5!

Hi,

(I have posted these in Unity 5.3 beta forum too, sorry for 2x)
Backspace bug was fixed in 5.1.3, but now it is here again.

  • (700861) - WebGL: Fixed backspace key navigating away from page in Chrome.

Please fix it in the next beta.

I have used SetNextControlName for Tab button, but it is working only in Unity editor.
Please fix it in the next beta.

I would like to use Enter button in the browsers after I have used the last inputField.
If it is possible, please fix it.

Thanks for all.

So you can reproduce it with the exact same steps as listed on the report with 5.3b6?
I tried this just now but can not do it.

Sorry, but I didn’t understand your ask.
(Where can I find 5.3b6?)
You can try my project. On the first screen you will land on the login screen.
(The WebGL page is imported with iframe, but without iframe is the same!)

http://terberendezo.alexbutor.hu
user: admin
pass: designer

Thanks.

The b6 build is coming soon. But can you please submit a new bug report with a minimal repro project if possible?
I think I can see what the issue is on your page but I can’t make this happen in a project I made.

Please ping the case number here after you submitted it.

I have solved;)

The problem is I have imported the Unity build index file with iFrame and I added the Event script code to the master page not to the Unity build index file.

This code is blocking “backspace” and you would stay in your project and if you add script to your inputField than you can use “tab” and “enter” buttons too.

<script type="text/javascript">
        window.addEventListener('keydown', function (e) {
            if (e.keyCode === 8 || e.keyCode === 9 || e.keyCode === 13 ) {
                if (e.target === document.body) {
                    e.preventDefault();
                }
            }
        }, true);
    </script>

Here you can see where I pasted this.

<!doctype html>
<html lang="en-us">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>Unity WebGL Player | Irodabútor - Térberendező beta28</title>
    <link rel="stylesheet" href="TemplateData/style.css">
    <link rel="shortcut icon" href="TemplateData/favicon.ico" />
    <script src="TemplateData/UnityProgress.js"></script>

    <script type="text/javascript">
        window.addEventListener('keydown', function (e) {
            if (e.keyCode === 8 || e.keyCode === 9 || e.keyCode === 13 ) {
                if (e.target === document.body) {
                    e.preventDefault();
                }
            }
        }, true);
    </script>

  </head>
  <body class="template">
    <p class="header"><span>Unity WebGL Player | </span>Irodabútor - Térberendező beta28</p>
    <div class="template-wrap clear">
      <canvas class="emscripten" id="canvas" oncontextmenu="event.preventDefault()" height="600px" width="960px"></canvas>
      

      <div class="fullscreen"><img src="TemplateData/fullscreen.png" width="38" height="38" alt="Fullscreen" title="Fullscreen" onclick="SetFullscreen(1);" /></div>
    </div>
    <p class="footer">« created with <a href="http://unity3d.com/" title="Go to unity3d.com">Unity</a> »</p>
    <script type='text/javascript'>
  var Module = {
    TOTAL_MEMORY: 314572800,
    errorhandler: null,            // arguments: err, url, line. This function must return 'true' if the error is handled, otherwise 'false'
    compatibilitycheck: null,
    dataUrl: "Release/T-WebGL.data",
    codeUrl: "Release/T-WebGL.js",
    memUrl: "Release/T-WebGL.js.mem",
  };
</script>
<script src="Release/UnityLoader.js"></script>

  </body>
</html>

I hope my solution will help for anyone else.

ONE MORE THING!

In my last post I added together the keyCodes, but the OR function isn’t working in java, therefor I separated them.

<!doctype html>
<html lang="en-us">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>Unity WebGL Player | Irodabútor - Térberendező beta28</title>
    <link rel="stylesheet" href="TemplateData/style.css">
    <link rel="shortcut icon" href="TemplateData/favicon.ico" />
    <script src="TemplateData/UnityProgress.js"></script>
    <script type="text/javascript">
        window.addEventListener('keydown', function (e) {
            if (e.keyCode === 8) {
                if (e.target === document.body) {
                    e.preventDefault();
                }
            }
        }, true);
    </script>
    <script type="text/javascript">
        window.addEventListener('keydown', function (e) {
            if (e.keyCode === 9) {
                if (e.target === document.body) {
                    e.preventDefault();
                }
            }
        }, true);
    </script>
    <script type="text/javascript">
        window.addEventListener('keydown', function (e) {
            if (e.keyCode === 13) {
                if (e.target === document.body) {
                    e.preventDefault();
                }
            }
        }, true);
    </script>


  </head>
  <body class="template">
    <p class="header"><span>Unity WebGL Player | </span>Irodabútor - Térberendező beta28</p>
    <div class="template-wrap clear">
      <canvas class="emscripten" id="canvas" oncontextmenu="event.preventDefault()" height="600px" width="960px"></canvas>
      

      <div class="fullscreen"><img src="TemplateData/fullscreen.png" width="38" height="38" alt="Fullscreen" title="Fullscreen" onclick="SetFullscreen(1);" /></div>
    </div>
    <p class="footer">« created with <a href="http://unity3d.com/" title="Go to unity3d.com">Unity</a> »</p>
    <script type='text/javascript'>
  var Module = {
    TOTAL_MEMORY: 314572800,
    errorhandler: null,            // arguments: err, url, line. This function must return 'true' if the error is handled, otherwise 'false'
    compatibilitycheck: null,
    dataUrl: "Release/T-WebGL.data",
    codeUrl: "Release/T-WebGL.js",
    memUrl: "Release/T-WebGL.js.mem",
  };
</script>
<script src="Release/UnityLoader.js"></script>

  </body>
</html>

Whit this will work ENTER button:
(only for old GUI system)
The “passwordLog” is the last inputField and if you press ENTER, then you can submit.

if (Event.current.isKey && Event.current.keyCode == KeyCode.Return && GUI.GetNameOfFocusedControl () == "passwordLog")
            {
//do something
}

Whit this will work TAB button, only one jump to last inputField.
(only for old GUI system)

GUI.SetNextControlName("loginUsername");
            GUI.Label(new Rect(Screen.width/2+50,Screen.height/2-60,220,20),"Felhasználó",LabelBold);
            userLog = GUI.TextField (new Rect (Screen.width/2+50, Screen.height/2-40, 220, 30), userLog, 25, inputField);
            GUI.SetNextControlName("passwordLog");
            if (GUI.GetNameOfFocusedControl () == string.Empty) {
                GUI.FocusControl ("userLog");
            }

            if (Event.current.isKey && Event.current.keyCode == KeyCode.Tab &&
                GUI.GetNameOfFocusedControl () == "loginUsername")
            {
                GUI.FocusControl ("passwordLog");
            }

Just try out my project in second comment in any browser.
(In the right circle(BELÉPÉS) is working just now.)