Feature #4421
Subtitles - add support for NTSC EIA-608/708 (text subtitles)
0%
Description
Normal subtitles works fine but i can't get subtitles for hearing impaired working when using other profiles than 'pass' of some reason.
This happens on all types of subtitles what i can see.
Tried various players VLC, Kodi etc and when i check info there is no subtitle track but if i open same channel with pass profile it works.
Would be nice to get that working.
Files
History
Updated by Jaroslav Kysela over 7 years ago
Please, give more info about the subtitle type. What does VLC say in the codec info when you use 'pass' muxer (profile)?
Updated by Andreas Fornberg over 7 years ago
Here is screenshot with pass profile
Here is one with matroska profile
It's same thing with HTSP and transcoding.
Updated by Andreas Fornberg over 7 years ago
Same thing also happens on some streams with closed captions for hearing impaired.
Updated by Jaroslav Kysela over 7 years ago
OK, it looks that the source for subtitles is teletext. If it's FTA channel, could you grab the .ts for the service (pass profile) - about 60 seconds (make sure that there are subtitles present) ? Attach the file to this bug.
Updated by Andreas Fornberg over 7 years ago
Probably it's flagged as hearing impaired or something.
Same thing with closed caption on US channels.
Updated by Andreas Fornberg over 7 years ago
Here is a file with US Closed Captions
Updated by Poul Kalff over 7 years ago
I'm from Denmark, we also use teletext for subtitles, and I see the same as you do.... I guess teletext is filtered in MKV..? But what do you wish to achieve? I record to .ts, then use ccextractor to extract subtitles to .srt and then mux them together to .mkv...... It's pretty cumbersome, but at least doable, and it can be automated....
Updated by Poul Kalff over 7 years ago
I mean, teletext-stream is or seems to be filtered/not included when a stream is muxed into mkv by tvheadend...
Updated by Jaroslav Kysela over 7 years ago
TVH should parse the TELETEXT stream and grab only TEXT subtitles.
Note for me: attached source code from ccextractor
Updated by Andreas Fornberg over 7 years ago
Jaroslav Kysela wrote:
Please, reupload your .ts files (comment 4).
File with Teletext that not works
https://dropfile.to/6HGQGnu
File with US Closed Caption that not works
https://dropfile.to/xtvDLBW
Updated by Andreas Fornberg over 7 years ago
Uploaded to another place.
This one keeps the file for 30 days.
File with Teletext that not works
https://ufile.io/ypnma
File with US Closed Caption that not works
https://ufile.io/9xvc3
Updated by Mark Clarkstone over 7 years ago
Andreas Fornberg wrote:
Have you looked anything on this yet?
Just so you know & not left wondering, Jaroslav is currently away.
Updated by Andreas Fornberg over 7 years ago
Ok i didn't know he was away.
And to comment that other link this is not related to that.
I want support for some types of subtitles for hearing impaired that tvheadend not works.
Normal subtitles works without problems.
Updated by Andreas Fornberg over 7 years ago
The only way to make them work is using pass stream profile and that doesn't work with Kodi client.
Updated by Andreas Fornberg over 7 years ago
Mediainfo shows me this for file with closed caption.
Text #1
ID : 101 (0x65)-CC1
Menu ID : 1 (0x1)
Format : EIA-608
Muxing mode : SCTE 128 / DTVCC Transport
Muxing mode, more info : Muxed in Video #1
Duration : 2mn 37s
Bit rate mode : Constant
Stream size : 0.00 Byte (0%)
Text #2
ID : 101 (0x65)-1
Menu ID : 1 (0x1)
Format : EIA-708
Muxing mode : SCTE 128 / DTVCC Transport
Muxing mode, more info : Muxed in Video #1
Duration : 2mn 37s
Bit rate mode : Constant
Stream size : 0.00 Byte (0%)
Updated by saen acro over 7 years ago
Andreas Fornberg wrote:
Ok i didn't know he was away.
And to comment that other link this is not related to that.
I want support for some types of subtitles for hearing impaired that tvheadend not works.
Normal subtitles works without problems.
kodi support multiple subtitles are you try to switch?
Updated by Andreas Fornberg over 7 years ago
Problem is that there is no subtitles.
VLC with pass profile shows subtitles.
I think it's some special hearing impaired flag because subtitles works on most channels.
Updated by Andreas Fornberg over 7 years ago
If i play same stream with HTSP or transcoding in both Kodi or VLC it doesn't show subtitles and there is no subtitles you can select.
It's only possible with pass profile on those channels it happens on.
Read this thread from beginning and you understand more.
Updated by Andreas Fornberg over 7 years ago
And look at the screenshots and you will see one of them shows subtitles with pass profile and the other one not with same channel.
Updated by Jaroslav Kysela over 7 years ago
Ok, EIA-608 subtitles are not supported yet: https://en.wikipedia.org/wiki/EIA-608
Updated by Jaroslav Kysela over 7 years ago
- Tracker changed from Bug to Feature
- Subject changed from Subtitles to Subtitles - add support for NTSC EIA-608 (text subtitles)
Updated by Andreas Fornberg over 7 years ago
Jaroslav Kysela wrote:
Ok, EIA-608 subtitles are not supported yet: https://en.wikipedia.org/wiki/EIA-608
Ok but it's still a problem on SVT channels that are subtitled as screenshot shows earlier.
In that case it's Teletext.
Updated by Andreas Fornberg over 7 years ago
mediainfo shows both EIA-608 & EIA-708 i guess the later one is a newer standard.
Updated by Jaroslav Kysela over 7 years ago
- Subject changed from Subtitles - add support for NTSC EIA-608 (text subtitles) to Subtitles - add support for NTSC EIA-608/708 (text subtitles)
Updated by Robert Cameron about 7 years ago
I think this is a bit misleading. Currently, Tvheadend supports Closed Captions, as it can merely pass the stream along unmodified; it is up to your viewing/playback software to be able to decode the Closed Captions in the video stream. I believe what the real issue is that Closed Captions are generally lost when having Tvheadend transcode the video stream.
EIA-608 (NTSC CC) and CEA-708 (ATSC DTVCC) are transmitted in the video stream encoded in the vertical blanking interval (VBI). The reason that transcoded streams from Tvheadend do not support these "subtitles" is that the data is lost in the transcoding of the video stream. In order to implement some type of full support for Closed Captions, Tvheadend would need to extract the CC data from the VBI before it transcodes the video stream and save it into a suitable/compatible format: SubRip (SRT) or [Advanced] SubStation Alpha (ASS/SSA) for Matroska (MKV) containers, or MPEG-4 Timed Text for MP4 containers. MPEG Transport Stream (TS) containers present a different problem as teletext/subtitles in those are usually bitmap images (similar to DVD IDX/SUB subtitles), and would require rasterizing the text into bitmap images before inserting them into the container.
Two programs that handle the extraction of Closed Caption data rather well are Zapping (zapping.sourceforge.net) and CCExtractor (ccextractor.org). Zapping includes several standalone tools for reading the CC data, and additional provides libzvbi (zapping.sourceforge.net/ZVBI) as a library to facilitate supporting them in other applications. I am uncertain if CCExtractor provides a separate library (or has its functions separated from the program logic to make creation of one easier). Both projects support the older EIA-608 NTSC CCs, as well as the newer/current CEA-708 ATSC DTVCCs.
Ffmpeg also has initial/beta support of CC extraction. I am unsure of how it is exposed (if at all) through libav*. I do know that when using it from the commandline, it essentially requires either 2 passes, or including the input twice (`ffmpeg -i <input> -i <input> ...`), as the filter needed to extract the CC data only outputs the video stream and the CC data as a subtitle stream; the audio stream(s) are ignored/discarded for the extraction.
Updated by Andreas Fornberg about 7 years ago
Problem is that clients like Kodi can't use the pass option and it doesn't work with HTSP either.
And as i said in beginning in this thread it's same problem with Teletext subtitles on some channels so it's not only Closed Caption. For example SVT channels in Sweden that have teletext for hearing impaired.
Updated by Robert Cameron about 7 years ago
Andreas Fornberg wrote:
Problem is that clients like Kodi can't use the pass option and it doesn't work with HTSP either.
And as i said in beginning in this thread it's same problem with Teletext subtitles on some channels so it's not only Closed Caption. For example SVT channels in Sweden that have teletext for hearing impaired.
Actually, you can create a transcode profile that uses avlib/TS container, and uses a copy for all codecs. This creates what is essentially a pass profile that is supported by HTSP in Kodi. In this manner, all audio streams/languages are passed along, and the video stream is intact, allowing Kodi to parse the Closed Captions too. (This is what I use for my clients at home.)
Updated by Robert Cameron about 7 years ago
... actually I lied.
I'm using the built-in Matroska container support, and passing all streams as "copy codec type". This is profile for Live/HTSP streaming in Kodi. Recording is using "pass", which has no problems when playing back recordings, as Kodi presently doesn't use HTSP for playing recordings, only for Live TV.
Updated by Jaroslav Kysela about 7 years ago
Just a note: zapping.sourceforge.net has ZVBI library to extract closed caption: http://zapping.sourceforge.net/ZVBI/
Updated by Robert Cameron about 7 years ago
Jaroslav Kysela wrote:
Just a note: zapping.sourceforge.net has ZVBI library to extract closed caption: http://zapping.sourceforge.net/ZVBI/
And another (although I haven't browsed the source at all to see how complete it is or how useful it might be in this situation): https://github.com/szatmary/libcaption
Updated by Andreas Fornberg about 7 years ago
Robert Cameron wrote:
Andreas Fornberg wrote:
Problem is that clients like Kodi can't use the pass option and it doesn't work with HTSP either.
And as i said in beginning in this thread it's same problem with Teletext subtitles on some channels so it's not only Closed Caption. For example SVT channels in Sweden that have teletext for hearing impaired.Actually, you can create a transcode profile that uses avlib/TS container, and uses a copy for all codecs. This creates what is essentially a pass profile that is supported by HTSP in Kodi. In this manner, all audio streams/languages are passed along, and the video stream is intact, allowing Kodi to parse the Closed Captions too. (This is what I use for my clients at home.)
No it doesn't because Kodi doesn't support Teletext.
Teletext only works with HTSP profile in Kodi.
Updated by Andreas Fornberg about 7 years ago
For other type of subtitles it works directly in Kodi what i have seen.
Updated by Andreas Fornberg about 7 years ago
Just tried using matroska as profile and it doesn't work either for livetv only transcoding and HTSP works.
Updated by Andreas Fornberg about 7 years ago
Got it working now forgot to give access to that profile.
But still not working with just copy everything either.
It removes the closed caption streams.
Updated by Jaroslav Kysela about 7 years ago
It should work only if you use MPEG-TS passthrough (or spawn) muxer, in all other cases this extra information is removed in the stream parsers. TVH should probably use zvbi library for this job.
Updated by Andreas Fornberg about 7 years ago
Jaroslav Kysela wrote:
It should work only if you use MPEG-TS passthrough (or spawn) muxer, in all other cases this extra information is removed in the stream parsers. TVH should probably use zvbi library for this job.
Kodi doesn't support passthrough profile
And i can't see why it should't be there with HTSP profile like the other subtitles. Teletext subtitles on SVT channels doesn't work either probably because it's flagged differently.
Updated by Jaroslav Kysela about 7 years ago
In most profiles, TVH parses the MPEG-TS stream and puts all info to "frame" data container which is called internally as packet. One packet is one picture for video or one period of audio. Those decoded stream data are without any extra ones, so if the broadcaster broadcasts something extra in the video stream and TVH does not have appropriate parser, it is discarded. The HTSP protocol works with packets. I hope that I put more light to this issue.
Updated by Andreas Fornberg about 7 years ago
So why do i have DVB and Teletext on most channels then with HTSP but not on SVT? I understand they are different in some way and from beginning when i created this as a bug i though it was same issue with closed captions.
Updated by Robert Cameron about 7 years ago
Andreas Fornberg wrote:
So why do i have DVB and Teletext on most channels then with HTSP but not on SVT? I understand they are different in some way and from beginning when i created this as a bug i though it was same issue with closed captions.
Because ffmpeg can handle dvb_teletext subtitles, but does not really support EIA-608/CEA-708 subtitles. It can pass the data through with libx264 back into the video stream, or it can (sort of) extract it with a pseudo-/virtual- input driver, but the former is not really a part of ffmpeg and may depend upon your build of libx264, and the latter is quite experimental.
You may be able to get more features and support by building your own copy of ffmpeg, and enabling all of the features/libraries you may need. Then build your own copy of Tvheadend, and link Tvheadend dynamically against your custom-built copy of ffmpeg instead of using Tvheadend's built-in version.
Updated by Jaroslav Kysela about 7 years ago
TVH has build-in support for DVB subtitles and TEXT subtitles in TELETEXT (European standard). So they should work with HTSP. The EIA subtitles are not directly supported in TVH yet.
Updated by Andreas Fornberg about 7 years ago
Jaroslav Kysela wrote:
TVH has build-in support for DVB subtitles and TEXT subtitles in TELETEXT (European standard). So they should work with HTSP. The EIA subtitles are not directly supported in TVH yet.
Not for SVT channels as i showed you in begging of this thread.
Look on the screenshots.
Updated by Jaroslav Kysela about 7 years ago
It's endless loop. The passthrough MPEG-TS profile does not change the stream (no parsers / packet handling is done in TVH). Comment #46. So external applications can do own decoding. Again, this subtitle info is NOT in HTSP profile output - so Kodi or other HTSP client cannot decode something non-existent.
Updated by Andreas Fornberg about 7 years ago
What i don't understand why does it remove Teletext subtitles on some channels like SVT but works perfectly on all others?
I can't see any difference between them it shoule work with HTSP profile but it does only work with pass profile.
In VLC i can use pass profile and then it works but i want to be able to use Kodi and there i can't use pass profile.
Updated by Andreas Fornberg about 7 years ago
This is important for hearing impaired people like me.
And for others it's good if you watch something late and need to have volume low.
Updated by Andreas Fornberg about 7 years ago
mediainfo shows this on that sample i recorded earlier
Text
ID : 6204 (0x183C)-100
Menu ID : 1 (0x1)
Format : Teletext
Language : Swedish
Updated by Andreas Fornberg about 7 years ago
Normally SVT have subtitles burned in the picture but if you want subtitles on swedish programs you need to activate teletext subtitles. On the channel it works on it's not burned in but standard subtitles with either teletext or DVB subtitles and there it works as it should.
Updated by Andreas Fornberg about 7 years ago
Robert Cameron wrote:
Andreas Fornberg wrote:
So why do i have DVB and Teletext on most channels then with HTSP but not on SVT? I understand they are different in some way and from beginning when i created this as a bug i though it was same issue with closed captions.
Because ffmpeg can handle dvb_teletext subtitles, but does not really support EIA-608/CEA-708 subtitles. It can pass the data through with libx264 back into the video stream, or it can (sort of) extract it with a pseudo-/virtual- input driver, but the former is not really a part of ffmpeg and may depend upon your build of libx264, and the latter is quite experimental.
You may be able to get more features and support by building your own copy of ffmpeg, and enabling all of the features/libraries you may need. Then build your own copy of Tvheadend, and link Tvheadend dynamically against your custom-built copy of ffmpeg instead of using Tvheadend's built-in version.
As i tried to explain and as screenshot in beginning of this thread shows it's Teletext and not Closed Caption.
I did mention it was same problem with closed caption later and after that this got renamed to feature for closed caption.
I welcome that ofcourse it's planned for 4.6 but this SVT problem with Teletext that already are supported should be easy to fix.
Updated by Sim Salabim over 2 years ago
Hello,
Any chance there was progress on this topic (EIA-608 and 708 closed captions)? Please let me know if it is not likely that we will ever see support for this. Thank you.
Updated by Andreas Fornberg over 2 years ago
Sim Salabim wrote:
Hello,
Any chance there was progress on this topic (EIA-608 and 708 closed captions)? Please let me know if it is not likely that we will ever see support for this. Thank you.
This works for me atleast with pass ot htsp option.
Maybe problems with transcoding.
This thread was first started by me because it was not showing Teletext subtitles always for Swedish channels.
I think the problem is when it's flagged hearing impaired or something.
Updated by Andreas Fornberg over 2 years ago
Sim Salabim wrote:
Hello,
Any chance there was progress on this topic (EIA-608 and 708 closed captions)? Please let me know if it is not likely that we will ever see support for this. Thank you.
This works for me atleast with pass ot htsp option.
Maybe problems with transcoding.
This thread was first started by me because it was not showing Teletext subtitles always for Swedish channels.
I think the problem is when it's flagged hearing impaired or something.
I donät know why this issue was renamed to something else that is another issue.
Updated by Andreas Fornberg over 2 years ago
Or maybe it's only working with pass i don't remember haven't checked this for a while.