mirror of
https://github.com/SubtitleEdit/subtitleedit.git
synced 2024-10-28 15:02:35 +01:00
Added Timeline footage ascii format
This commit is contained in:
parent
f2b9c1ced7
commit
d8d5352c51
@ -358,6 +358,14 @@ namespace Nikse.SubtitleEdit.Forms
|
||||
format = asc;
|
||||
}
|
||||
}
|
||||
if (format == null)
|
||||
{
|
||||
var asc = new TimeLineFootageAscii();
|
||||
if (asc.IsMine(null, fileName))
|
||||
{
|
||||
format = asc;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (format == null)
|
||||
|
@ -157,6 +157,14 @@ namespace Nikse.SubtitleEdit.Forms
|
||||
asc.LoadSubtitle(_subtitle1, null, openFileDialog1.FileName);
|
||||
}
|
||||
}
|
||||
if (format == null)
|
||||
{
|
||||
var asc = new TimeLineFootageAscii();
|
||||
if (asc.IsMine(null, openFileDialog1.FileName))
|
||||
{
|
||||
asc.LoadSubtitle(_subtitle1, null, openFileDialog1.FileName);
|
||||
}
|
||||
}
|
||||
subtitleListView1.Fill(_subtitle1);
|
||||
subtitleListView1.SelectIndexAndEnsureVisible(0);
|
||||
subtitleListView2.SelectIndexAndEnsureVisible(0);
|
||||
|
@ -2133,6 +2133,21 @@ namespace Nikse.SubtitleEdit.Forms
|
||||
}
|
||||
}
|
||||
|
||||
if (format == null)
|
||||
{
|
||||
var asc = new TimeLineFootageAscii();
|
||||
if (asc.IsMine(null, fileName))
|
||||
{
|
||||
asc.LoadSubtitle(_subtitle, null, fileName);
|
||||
_oldSubtitleFormat = asc;
|
||||
SetCurrentFormat(Configuration.Settings.General.DefaultSubtitleFormat);
|
||||
SetEncoding(Configuration.Settings.General.DefaultEncoding);
|
||||
encoding = GetCurrentEncoding();
|
||||
justConverted = true;
|
||||
format = GetCurrentSubtitleFormat();
|
||||
}
|
||||
}
|
||||
|
||||
if (format == null)
|
||||
{
|
||||
var mtv = new TimeLineMvt();
|
||||
|
@ -36,6 +36,10 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||
|
||||
public override bool IsMine(List<string> lines, string fileName)
|
||||
{
|
||||
var asc = new TimeLineFootageAscii();
|
||||
if (fileName != null && asc.IsMine(null, fileName))
|
||||
return false;
|
||||
|
||||
var subtitle = new Subtitle();
|
||||
LoadSubtitle(subtitle, lines, fileName);
|
||||
return subtitle.Paragraphs.Count > _errorCount;
|
||||
@ -157,9 +161,9 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||
|
||||
private static TimeCode DecodeTimeCode(string[] parts)
|
||||
{
|
||||
string frames16 = parts[0];
|
||||
string frames = parts[1];
|
||||
return new TimeCode(0, 0, 0, FramesToMilliseconds(16 * int.Parse(frames16) + int.Parse(frames)));
|
||||
int frames16 = int.Parse(parts[0]);
|
||||
int frames = int.Parse(parts[1]);
|
||||
return new TimeCode(0, 0, 0, FramesToMilliseconds(16 * frames16 + frames));
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -71,6 +71,8 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||
Paragraph paragraph = null;
|
||||
var expecting = ExpectingLine.Number;
|
||||
_errorCount = 0;
|
||||
byte firstLineCode = 0;
|
||||
byte secondLineCode = 0;
|
||||
|
||||
subtitle.Paragraphs.Clear();
|
||||
IEnumerable<byte[]> byteLines = SplitBytesToLines(File.ReadAllBytes(fileName));
|
||||
@ -140,6 +142,21 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||
_errorCount += 100;
|
||||
return;
|
||||
}
|
||||
|
||||
if (paragraph.Text.Contains(Environment.NewLine))
|
||||
{
|
||||
if (secondLineCode == 0)
|
||||
secondLineCode = bytes[0];
|
||||
if (secondLineCode != bytes[0])
|
||||
_errorCount++;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (firstLineCode == 0)
|
||||
firstLineCode = bytes[0];
|
||||
if (firstLineCode != bytes[0])
|
||||
_errorCount++;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
213
src/Logic/SubtitleFormats/TimelineFootageAscii.cs
Normal file
213
src/Logic/SubtitleFormats/TimelineFootageAscii.cs
Normal file
@ -0,0 +1,213 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Text;
|
||||
using System.Text.RegularExpressions;
|
||||
using Nikse.SubtitleEdit.Core;
|
||||
|
||||
namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||
{
|
||||
/// <summary>
|
||||
/// Timeline Ascii export - THE MOVIE TITRE EDITOR - http://www.pld.ttu.ee/~priidu/timeline/ by priidu@pld.ttu.ee
|
||||
///
|
||||
/// Sample:
|
||||
/// 1.
|
||||
/// 41,10
|
||||
/// 46,10
|
||||
/// ±NE/SEVÎ
|
||||
/// ³ÂÍÅ/ÑÅÁß
|
||||
///
|
||||
/// 2.
|
||||
/// 49,05
|
||||
/// 51,09
|
||||
/// ±Viòð ir klât.
|
||||
/// ³Îí ïðèøåë.
|
||||
/// </summary>
|
||||
public class TimeLineFootageAscii : SubtitleFormat
|
||||
{
|
||||
|
||||
private static readonly Regex RegexTimeCode = new Regex(@"^\s*\d+,\d\d$", RegexOptions.Compiled);
|
||||
|
||||
private enum ExpectingLine
|
||||
{
|
||||
Number,
|
||||
TimeStart,
|
||||
TimeEnd,
|
||||
Text
|
||||
}
|
||||
|
||||
public override string Extension
|
||||
{
|
||||
get { return ".asc"; }
|
||||
}
|
||||
|
||||
public override string Name
|
||||
{
|
||||
get { return "Timeline footage ascii"; }
|
||||
}
|
||||
|
||||
public override bool IsTimeBased
|
||||
{
|
||||
get { return true; }
|
||||
}
|
||||
|
||||
public override bool IsMine(List<string> lines, string fileName)
|
||||
{
|
||||
if (fileName == null || !fileName.EndsWith(Extension, StringComparison.OrdinalIgnoreCase))
|
||||
return false;
|
||||
|
||||
var subtitle = new Subtitle();
|
||||
LoadSubtitle(subtitle, lines, fileName);
|
||||
return subtitle.Paragraphs.Count > _errorCount;
|
||||
}
|
||||
|
||||
public override string ToText(Subtitle subtitle, string title)
|
||||
{
|
||||
return string.Empty;
|
||||
}
|
||||
|
||||
public override void LoadSubtitle(Subtitle subtitle, List<string> lines, string fileName)
|
||||
{
|
||||
Paragraph paragraph = null;
|
||||
var expecting = ExpectingLine.Number;
|
||||
_errorCount = 0;
|
||||
byte firstLineCode = 0;
|
||||
byte secondLineCode = 0;
|
||||
|
||||
subtitle.Paragraphs.Clear();
|
||||
IEnumerable<byte[]> byteLines = SplitBytesToLines(File.ReadAllBytes(fileName));
|
||||
foreach (byte[] bytes in byteLines)
|
||||
{
|
||||
var line = Encoding.ASCII.GetString(bytes);
|
||||
if (line.EndsWith('.') && Utilities.IsInteger(line.TrimEnd('.')))
|
||||
{
|
||||
if (paragraph != null && !string.IsNullOrEmpty(paragraph.Text))
|
||||
subtitle.Paragraphs.Add(paragraph);
|
||||
paragraph = new Paragraph();
|
||||
expecting = ExpectingLine.TimeStart;
|
||||
}
|
||||
else if (paragraph != null && expecting == ExpectingLine.TimeStart && RegexTimeCode.IsMatch(line))
|
||||
{
|
||||
string[] parts = line.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
|
||||
if (parts.Length == 2)
|
||||
{
|
||||
try
|
||||
{
|
||||
var tc = DecodeTimeCode(parts);
|
||||
paragraph.StartTime = tc;
|
||||
expecting = ExpectingLine.TimeEnd;
|
||||
}
|
||||
catch
|
||||
{
|
||||
_errorCount++;
|
||||
expecting = ExpectingLine.Number;
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (paragraph != null && expecting == ExpectingLine.TimeEnd && RegexTimeCode.IsMatch(line))
|
||||
{
|
||||
string[] parts = line.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
|
||||
if (parts.Length == 2)
|
||||
{
|
||||
try
|
||||
{
|
||||
var tc = DecodeTimeCode(parts);
|
||||
paragraph.EndTime = tc;
|
||||
expecting = ExpectingLine.Text;
|
||||
}
|
||||
catch
|
||||
{
|
||||
_errorCount++;
|
||||
expecting = ExpectingLine.Number;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (paragraph != null && expecting == ExpectingLine.Text)
|
||||
{
|
||||
if (bytes.Length > 1)
|
||||
{
|
||||
// get text from encoding
|
||||
var enc = GetEncodingFromLanguage(bytes[0]);
|
||||
string s = enc.GetString(bytes, 1, bytes.Length - 1).Trim();
|
||||
|
||||
// italic text
|
||||
if (s.StartsWith('#'))
|
||||
s = "<i>" + s.Remove(0, 1) + "</i>";
|
||||
|
||||
paragraph.Text = (paragraph.Text + Environment.NewLine + s).Trim();
|
||||
if (paragraph.Text.Length > 2000)
|
||||
{
|
||||
_errorCount += 100;
|
||||
return;
|
||||
}
|
||||
|
||||
if (paragraph.Text.Contains(Environment.NewLine))
|
||||
{
|
||||
if (secondLineCode == 0)
|
||||
secondLineCode = bytes[0];
|
||||
if (secondLineCode != bytes[0])
|
||||
_errorCount++;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (firstLineCode == 0)
|
||||
firstLineCode = bytes[0];
|
||||
if (firstLineCode != bytes[0])
|
||||
_errorCount++;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (paragraph != null && !string.IsNullOrEmpty(paragraph.Text))
|
||||
subtitle.Paragraphs.Add(paragraph);
|
||||
|
||||
subtitle.Renumber();
|
||||
}
|
||||
|
||||
private IEnumerable<byte[]> SplitBytesToLines(byte[] bytes)
|
||||
{
|
||||
var list = new List<byte[]>();
|
||||
int start = 0;
|
||||
int index = 0;
|
||||
while (index < bytes.Length)
|
||||
{
|
||||
if (bytes[index] == 13)
|
||||
{
|
||||
int length = index - start;
|
||||
var lineBytes = new byte[length];
|
||||
Array.Copy(bytes, start, lineBytes, 0, length);
|
||||
list.Add(lineBytes);
|
||||
index += 2;
|
||||
start = index;
|
||||
}
|
||||
else
|
||||
{
|
||||
index++;
|
||||
}
|
||||
}
|
||||
return list;
|
||||
}
|
||||
|
||||
private static TimeCode DecodeTimeCode(string[] parts)
|
||||
{
|
||||
int frames16 = int.Parse(parts[0]);
|
||||
int frames = int.Parse(parts[1]);
|
||||
return new TimeCode(0, 0, 0, FramesToMilliseconds(16 * frames16 + frames));
|
||||
}
|
||||
|
||||
private Encoding GetEncodingFromLanguage(byte language)
|
||||
{
|
||||
if (language == 179) // Russian
|
||||
return Encoding.GetEncoding(1251);
|
||||
|
||||
if (language == 177) // Baltic
|
||||
return Encoding.GetEncoding(1257);
|
||||
|
||||
return Encoding.GetEncoding(1252);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
@ -150,6 +150,7 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||
|
||||
private double GetTimeCode(byte[] bytes, int timeCodeIndex)
|
||||
{
|
||||
//TODO: figure out how to get time code from these 7 bytes!
|
||||
if (bytes == null || bytes.Length < timeCodeIndex + 8)
|
||||
return 0;
|
||||
Console.WriteLine(bytes[timeCodeIndex + 0].ToString("X2") + " " +
|
||||
@ -160,7 +161,6 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||
bytes[timeCodeIndex + 5].ToString("X2") + " " +
|
||||
bytes[timeCodeIndex + 6].ToString("X2"));
|
||||
return ((bytes[timeCodeIndex + 5] << 24) + (bytes[timeCodeIndex + 4] << 16) + (bytes[timeCodeIndex + 3] << 8) + (bytes[timeCodeIndex + 2])) / 1800.0;
|
||||
// return (bytes[timeCodeIndex + 5] << 16) + (bytes[timeCodeIndex + 4] << 8) + (bytes[timeCodeIndex + 3]);
|
||||
}
|
||||
|
||||
private Encoding GetEncodingFromLanguage(string language)
|
||||
|
@ -902,6 +902,7 @@
|
||||
<Compile Include="Logic\Ocr\OcrImage.cs" />
|
||||
<Compile Include="Logic\Ocr\NOcrPoint.cs" />
|
||||
<Compile Include="Logic\Ocr\SpellCheckOcrTextResult.cs" />
|
||||
<Compile Include="Logic\SubtitleFormats\TimelineFootageAscii.cs" />
|
||||
<Compile Include="Logic\SubtitleFormats\TimelineAscii.cs" />
|
||||
<Compile Include="Logic\SubtitleFormats\TimelineMvt.cs" />
|
||||
<Compile Include="Logic\SubtitleFormats\Pns.cs" />
|
||||
|
Loading…
Reference in New Issue
Block a user