Closed kaldonir closed 5 years ago
Thank your for raising a issue. I will try and get back to you as soon as possible. Regards @fgl27
I enable this for performance https://github.com/verlok/lazyload sems that is not working on yours TV.
can you debug using this? https://github.com/fgl27/smarttv-twitch/archive/master.zip
because the release does not give the proper logs as is most disable.
After the app finishes load dismiss the controls dialog, and press the key B or green, it will force a reload of the app.
then try to scroll down the page to see what happens on the console window.
after I need you to open the tab that show the html content and navigate to the thumbnail so we can see what is going on, open this frist
Then without exiting the "Live screen" open the live screen holder like this
Open "scene1" > "screens_holder" > "Live_scroll" > "stream_table_live" > "Live_row0" > "Live_cell0_0" > "Live_thumbdiv0_0" > "<div>"
scroll to see this
The "0_0" is the position so it can be different and any one from those will work.
What I wanna to see is if there is any error on the console, and if that tag from the img is there the data-was-processed="true"
because that is the trigger that tells that the image was loaded properly.
Try that and if need some help with the proces let me know.
I did use the master version, but that's all the output I get there.
This is a div for which no thumbnail has been loaded, the img
does not contain a data-was-process="true"
:
<div id="Live_thumbdiv18_0" class="stream_thumbnail_clip">
<div>
<img id="Live_img18_0" class="lazy stream_img" alt="" data-src="https://static-cdn.jtvnw.net/previews-ttv/live_user_jango_bichouu-640x360.jpg?0.06038071341118467" onerror="this.onerror=null;this.src=''">
</div>
<div id="Live_infodiv18_0" class="stream_text2">
<div>
<div id="Live_title18_0" class="stream_channel" style="width: 66%; display: inline-block;">
<i class="icon-circle live_icon" style="color: red;"></i> Jango_bichouu
</div>
<div id="Live_duration18_0" class="stream_info" style="width:33%; float: right; text-align: right; display: inline-block;">720p60 [FR]</div>
</div>
<div id="Live_createdon18_0" class="stream_info">[FlashLand] La Fin.</div>
<div id="Live_game18_0" class="stream_info">Playing Grand Theft Auto V</div>
<div id="Live_viewers18_0" class="stream_info">Since 01:49:39 for 4,138 Viewers</div>
</div>
</div>
I get the same console output as above.
Try again do this change first https://github.com/fgl27/smarttv-twitch/commit/17c427458af1ab9fc87208de104a1b72d648a03f
or redownload the source.
Let me know the result.
With this change I get the same result
OK I disable it for now. I push the changes close the release apk open again and close this if OK
So according to this, my TV does not support the Intersection Observer API, which is used by LazyLoad. For some reason, LazyLoad does not detect that this API is unavailable and the thumbnails won't load.
This discussion on the IntersectionObserver repo describes the necessary checks for availability of that API. I've implemented it in lazyload.js
, and with this, lazyload is disabled on my TV, while it is enabled e.g. in my Firefox.
var supportsIntersectionObserver = runningOnBrowser && "IntersectionObserver" in window
&& "IntersectionObserverEntry" in window
&& "intersectionRatio" in window.IntersectionObserverEntry.prototype
&& "isIntersecting" in window.IntersectionObserverEntry.prototype;
If this works for you as well, this might be the best solution for now?
Give me your version of lazy load so I can test
Here the normal way and the one you share both return false for me on my TV running Tizen 2.4, on the emulator both ways return true, the emulator is Tizen 5.0.
can you tell me the result of this on yours TV?
console.log('supportsIntersectionObserver ' + (runningOnBrowser && "IntersectionObserver" in window));
Is odd that it doesn't work because of that, that check must be resulting in true for some reason.
I will update again and push the changes let me know the result just for curiosity.
I push all changes if doesn't work on the release please let me know.
thanks.
console.log('supportsIntersectionObserver ' + (runningOnBrowser && "IntersectionObserver" in window));
This returned true
for me.
Yes, release works for me now. Thanks!
Yes very odd behavior, thank you for the help.
Since the update, no thumbnails are loading on my TV, there are only black rectangles for Games, Channels, Live Streams, Videos, Clips. Streams themselves play as expected, and I do get preview pictures when I look at my followed channels in the side bar
Visiting the
index.html
page in a webbrowser loads the thumbnails as expected.This is the console output when I start up the app on the TV, up to the point where I'd expect to see thumbnails of the most popular channels: