Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Light not working on Epson device - webgl_interactive_cubes #12592

Closed
3 of 13 tasks
cloud4every1 opened this issue Nov 6, 2017 · 30 comments
Closed
3 of 13 tasks

Light not working on Epson device - webgl_interactive_cubes #12592

cloud4every1 opened this issue Nov 6, 2017 · 30 comments

Comments

@cloud4every1
Copy link

cloud4every1 commented Nov 6, 2017

I'm using Chrome 59.0.3071.125 on an android 5.1.1 device (Epson Moverio BT-300) and it looks like that the lights are not working correctly.
Simple test when running the webgl_interactive_cubes example, all cubes are black beside the one active/selected. Same issue on webgl_geometry_colors, webgl_geometry_colors_blender examples.

webgl_geometry_colors_lookuptable is working limited as colors are visible but detailed structure is not visible and colors are not as shiny as on other devices.
Also MeshLambertMaterial document page shows a black canvas on the device instead of the blue shaded torusKnot. When changing the ambient light of the scene or the emission of the MeshLambertMaterial to a color it is at least flat visible (no 3d effect). Refraction and reflection are working. When using the 'gras' map the torus becomes visible in a 3d manner.

I did also several other tests and it seems that only Materials which are light independent (MeshNormalMaterial, textures) are rendered correct. Either shadows are not visible or the geometry stays black.

Console does not show any error.

  • Dev
  • r87
  • ...
Browser
  • All of them
  • Chrome
  • Firefox
  • Internet Explorer
OS
  • All of them
  • Windows
  • macOS
  • Linux
  • Android
  • iOS
Hardware Requirements (graphics card, VR Device, ...)
@cloud4every1
Copy link
Author

Attached some sample outputs to show the problem.

Documentation about the TorusKnotGeometry
screenshot-1509986063953

Screenshot of the webgl_geometry_colors_lookuptable example
screenshot-1509986488991

Screenshot of the webgl_interactive_cubes example
screenshot-1509986612609

@moraxy
Copy link
Contributor

moraxy commented Nov 6, 2017

Any error messages in the developer console?
Nevermind, just saw the note.

Does http://webglreport.com/ say something's off?

@cloud4every1
Copy link
Author

I double checked the remote developer console but nothing. As I used the official Websites Three.js version is already 88. But the same problem is for 87.
Based on the webglreport.com the browser supports WebGL 1 & 2.
For WebGL2 it mentions that 88 of 88 functions are implemented.

screenshot-webglreport-bt300
screenshot-1510039293599
screenshot-1510039349469

@Mugen87
Copy link
Collaborator

Mugen87 commented Nov 7, 2017

Do you have this problem with other WebGL applications, too? For example are the demos of babylon.js rendered correctly?

@cloud4every1
Copy link
Author

With babylon.js everything I tested so far is working fine.
babylon GUI, displacement MAP, Constructive Solid Geometries, Charting, Multimaterial, Lights, ...

@Mugen87
Copy link
Collaborator

Mugen87 commented Nov 7, 2017

Can you please test some three.js demos with mobile Firefox? Same problem?

@cloud4every1
Copy link
Author

Sure, I will!
However, i tested already with the default browser and same issue. But i will test with other browsers as well.

@cloud4every1
Copy link
Author

Tested with Firefox 52.0.2 and same problem with three.js but works fine with babylon.js

@Mugen87
Copy link
Collaborator

Mugen87 commented Nov 7, 2017

It's really hard to find the root cause of the problem if there are no error messages and warnings. TBH, i've no idea what's going wrong...

@cloud4every1
Copy link
Author

cloud4every1 commented Nov 7, 2017

Maybe there are some points in the code I could check, if they will be executed?
Will there be any device specific parameters checked for this?

I wrote a small test page where I could enable/disable Ambiente, Spot and Directional Light. It contains a plain, a cube and a Sphere. All three with MeshLambertMaterial.

// Plane var planeGeometry = new THREE.PlaneGeometry(60,20); var planeMaterial = new THREE.MeshLambertMaterial( {color:0xffffff}); var plane = new THREE.Mesh(planeGeometry,planeMaterial); // Cube var cubeGeometry = new THREE.BoxGeometry(4,4,4); var cubeMaterial = new THREE.MeshLambertMaterial({color:0xff0000}); var cube = new THREE.Mesh(cubeGeometry, cubeMaterial); // Sphere var sphereGeometry = new THREE.SphereGeometry(4,20,20); var sphereMaterial = new THREE.MeshLambertMaterial({color:0x7777ff}); var sphere = new THREE.Mesh(sphereGeometry,sphereMaterial);

Ambient Light makes the plane, and the sphere visible, the Cube stays black.
100% the same as on the normal devices.
All other lights (Spot, Directional) does not show any effect on the device.
Maybe this brings some more "light" into the problem :-)

BT-300 with all lights on
screenshot-1510066618225

Chrome on MacOS with all lights on.
snapshot-chrome-alllights

Chrome only Ambient Light on:
screenshot-chrome-ambientlight

@mrdoob
Copy link
Owner

mrdoob commented Nov 7, 2017

@kenrussell Any known issues with Intel HD Graphics for Atom x5/x7?

@cloud4every1
Copy link
Author

There are more observations with this, as I might not have chosen an optimal material color.
When changing the color of the sphere to
var sphereMaterial = new THREE.MeshLambertMaterial({color:0xff7777});
the color changes (still only for ambient light - for all other lights every object is black).
However, on other devices it stays blue like the white plane. So possible the materials do have a problem and not the light?

screenshot-1510068521910

Additionally the boolean values of the data.GUI seems not to be coloured like normal

@cloud4every1
Copy link
Author

I have tested further with this problem and found that in r69 the lights have been working.

@cloud4every1
Copy link
Author

I tested many more version and found that r73 is the last one where it works fine. With r74 and onwards the lights seems not to be considered during the rendering on this device.

@cloud4every1
Copy link
Author

cloud4every1 commented Nov 9, 2017

As @mrdoob mentioned, it is a Intel HD Graphics for Atom x5/x7 graphic card that seems to have the problem. Could I run any special tests i.e. fragment shader via the ShaderMaterial?
I tried a simple one from the three.js cookbook, which works but is not light dependent:

    <script id="simple-fragment" type="x-shader/x-fragment">
    varying vec3 vNormal;
    uniform float delta;
    uniform float mNear;
    uniform float mFar;
    float PI = 3.14159265358979323846264;
    void main()
    {
        float depth = gl_FragCoord.z / gl_FragCoord.w;
        float depthColor = smoothstep( mNear, mFar, depth );
        gl_FragColor = vec4(abs(sin(delta + 0.7*PI) + cos(normalize(vNormal).x)/2.0) - depthColor,
                            abs(sin(delta + 1.0*PI) + cos(normalize(vNormal).y)/2.0) - depthColor,
                            abs(sin(delta + 1.2*PI) + cos(normalize(vNormal).z)/2.0) - depthColor, 1.0);
    }
    </script>

@mrdoob
Copy link
Owner

mrdoob commented Nov 9, 2017

I tested many more version and found that r73 is the last one where it works fine. With r74 and onwards the lights seems not to be considered during the rendering on this device.

Thanks! That's super helpful! I'll investigate a bit today.

@WestLangley
Copy link
Collaborator

WestLangley commented Nov 9, 2017

@cloud4every1 Does this Array of Structs test pass on your device?

https://www.khronos.org/registry/webgl/sdk/tests/conformance/glsl/misc/shader-with-array-of-structs-uniform.html?webglVersion=%5Bobject%20Object%5D

We now pass lights uniform data to the GPU as an array of structs.

@cloud4every1
Copy link
Author

Yes, passes successfully
khronos-org

Can we debug it somehow?

@cloud4every1
Copy link
Author

The device should get the following glsl fragment shader program to render the MeshLambertMaterial. I captured it from the WebGLShader/WebGLProgram function on the device.
MeshLambertMaterial-Shader.txt
May you do see something there? Something I could debug and provide details? Input / Output ... let me know! thanks!!

@kenrussell
Copy link

@mrdoob no specific known issues with Intel HD Graphics for Atom x5/x7. If you can boil this down into a small test case we will happily incorporate it into the WebGL conformance suite and tell Intel about it.

@mrdoob
Copy link
Owner

mrdoob commented Nov 10, 2017

@cloud4every1 Do you mind running all the conformance tests in the device?

https://www.khronos.org/registry/webgl/sdk/tests/webgl-conformance-tests.html

@cloud4every1
Copy link
Author

cloud4every1 commented Nov 12, 2017

Currently I'm working through this script but several tests fail and some does lead to 'WebGL snagit'. This is why I have to split the test up into several section to get the result for all (that does not lead to snagit's) tests.
All the results with "1 tests failed" are typically the one that have been skipped. The script does not mark them in another way in the output file, thats a bit sad. On the other hand you clearly see what have been skipped as all this tests are in the file with the "1 tests failed". All test that are ok are not in the result file.

The first part of the script till all/conformance/glsl shows the following errors:

webgl-conformance-2.0.1 (1)-Attrib-Extensions.txt

conformance/attribs/gl-vertex-attrib-unconsumed-out-of-bounds.html: 32 tests failed conformance/extensions/webgl-compressed-texture-astc.html: 14540 tests failed

the second file contains the all/conformance/glsl/bugs section. I skiped everything before and after as well some specific test cases (array-struct, sampler-struct as well as temp-expressions-should-not-crash) as they have lead to snagits.

webgl-conformance-2.0.1 (6)-glsl-bugs.txt

conformance/glsl/bugs/sampler-array-struct-function-arg.html: 1 tests failed conformance/glsl/bugs/sampler-struct-function-arg.html: 1 tests failed conformance/glsl/bugs/unary-minus-operator-float-bug.html: 2 tests failed conformance/glsl/bugs/undefined-index-should-not-crash.html: 2 tests failed conformance/glsl/bugs/uniforms-should-not-lose-values.html: 2 tests failed conformance/glsl/bugs/varying-arrays-should-not-be-reversed.html: 2 tests failed conformance/glsl/bugs/vector-scalar-arithmetic-inside-loop.html: 2 tests failed conformance/glsl/bugs/vector-scalar-arithmetic-inside-loop-complex.html: 2 tests failed

Third is the rest of the conformance/glsl section:
webgl-conformance-2.0.1 (7)-glsl.txt

@cloud4every1
Copy link
Author

The fourth file starts with "all/conformance/limits" including all "all/conformance/ogles" results
webgl-conformance-2.0.1 (9)-ogles.txt

conformance/ogles/GL/faceforward/faceforward_001_to_006.html: 2 tests failed conformance/ogles/GL/struct/struct_049_to_056.html: 2 tests failed

The fifth file contains the rest of the "all/conformance/" section
webgl-conformance-2.0.1 (10)-conformance.txt

conformance/renderbuffers/renderbuffer-initialization.html: 4 tests failed

Next contains the end "all/conformance2" section of the test.
webgl-conformance-2.0.1 (11)-conformance2.txt

@cloud4every1
Copy link
Author

Now the rest of the testcases. Browser crashes in the deqp - shadertexturefilter section. So I skipped this section as well.

From deqp/data/gles3/shaders/arrays.html till fbcolorbuffer:
webgl-conformance-2.0.1 (13)-deqp-fbcolorbuffer.txt

From runall/deqp/functional/gles3/fboinvalidate
till framebufferblit:
webgl-conformance-2.0.1 (14)-deqp-frambufferbit.txt

From primitiverestart till shaderoperator:
webgl-conformance-2.0.1 (15)-deqp-shaderoperator.txt

Only shadertexturefunction:
webgl-conformance-2.0.1 (16)-deqp-shadertexturefunction.txt

Only shadertextureformat:
webgl-conformance-2.0.1 (17)-deqp-shadertextureformat.txt

And then the rest starting from texturefiltering:
webgl-conformance-2.0.1 (18)-deqp-rest.txt

Hope this helps. If you need detailed error reports for some use cases let me know.
Many thanks for your help!!

@mrdoob
Copy link
Owner

mrdoob commented Nov 15, 2017

@kenrussell anything useful there?

@kenrussell
Copy link

Sorry but I can't tell from the results of a WebGL conformance run. The thing that's really needed is to figure out what part of the shader is executing differently on this device, and then to create a minimized test case from that. Sorry but that's the only way we will make progress on this bug.

@mrdoob
Copy link
Owner

mrdoob commented Nov 16, 2017

@cloud4every1
Copy link
Author

Hi, not exactly, it is a BT-300, newer model with higher resolution but in general same technology.
https://tech.moverio.epson.com/en/bt-300/document.html

@Mugen87
Copy link
Collaborator

Mugen87 commented Jul 18, 2018

@mrdoob
Copy link
Owner

mrdoob commented Jul 27, 2018

Closing this for now. We can open it again if the device is passes the tests @Mugen87 mentioned.

@mrdoob mrdoob closed this as completed Jul 27, 2018
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants