mirror of
https://github.com/SubtitleEdit/subtitleedit.git
synced 2024-11-21 18:52:36 +01:00
Merge branch 'main' of https://github.com/SubtitleEdit/subtitleedit
This commit is contained in:
commit
95c12f5e03
@ -4,6 +4,7 @@
|
|||||||
4.0.9 (xth December 2024) BETA
|
4.0.9 (xth December 2024) BETA
|
||||||
* NEW:
|
* NEW:
|
||||||
* Add "Move all shot changes" shortcuts - thx acetilo
|
* Add "Move all shot changes" shortcuts - thx acetilo
|
||||||
|
* Add DeepLX translate - thx rifatozkancomtr
|
||||||
* IMPROVED:
|
* IMPROVED:
|
||||||
* Update Portuguese translation - thx hugok79
|
* Update Portuguese translation - thx hugok79
|
||||||
* Update Bulgarian translation - thx Калин
|
* Update Bulgarian translation - thx Калин
|
||||||
@ -33,6 +34,7 @@
|
|||||||
* Fix wrong dialog info text in FCE
|
* Fix wrong dialog info text in FCE
|
||||||
* Fix for divide by zero in TTS
|
* Fix for divide by zero in TTS
|
||||||
* Fix bug in "Change casing" - thx Hlsgs
|
* Fix bug in "Change casing" - thx Hlsgs
|
||||||
|
* Fix enter in textbox in FCE - thx p1nkyy/Roger
|
||||||
|
|
||||||
|
|
||||||
4.0.8 (6th September 2024)
|
4.0.8 (6th September 2024)
|
||||||
|
@ -2435,6 +2435,7 @@
|
|||||||
<Word from="spasli" to="spasili" />
|
<Word from="spasli" to="spasili" />
|
||||||
<Word from="spavaćeš" to="spavat ćeš" />
|
<Word from="spavaćeš" to="spavat ćeš" />
|
||||||
<Word from="spavaćete" to="spavat ćete" />
|
<Word from="spavaćete" to="spavat ćete" />
|
||||||
|
<Word from="Spavaću" to="Spavat ću" />
|
||||||
<Word from="speluje" to="sriče" />
|
<Word from="speluje" to="sriče" />
|
||||||
<Word from="speluju" to="sriču" />
|
<Word from="speluju" to="sriču" />
|
||||||
<Word from="spelujte" to="sričite" />
|
<Word from="spelujte" to="sričite" />
|
||||||
@ -4007,6 +4008,8 @@
|
|||||||
<LinePart from="bez svesti" to="bez svijesti" />
|
<LinePart from="bez svesti" to="bez svijesti" />
|
||||||
<LinePart from="Bez obzira što" to="Bez obzira na to što" />
|
<LinePart from="Bez obzira što" to="Bez obzira na to što" />
|
||||||
<LinePart from="bez obzira što" to="bez obzira na to što" />
|
<LinePart from="bez obzira što" to="bez obzira na to što" />
|
||||||
|
<LinePart from="Biću dobro" to="Bit ću dobro" />
|
||||||
|
<LinePart from="Biće u redu" to="Bit će u redu" />
|
||||||
<LinePart from="biću iskren" to="bit ću iskren" />
|
<LinePart from="biću iskren" to="bit ću iskren" />
|
||||||
<LinePart from="Biće mi" to="Bit će mi" />
|
<LinePart from="Biće mi" to="Bit će mi" />
|
||||||
<LinePart from="Biće on" to="Bit će on" />
|
<LinePart from="Biće on" to="Bit će on" />
|
||||||
@ -5575,6 +5578,7 @@
|
|||||||
<RegEx find="oslj?ep" replaceWith="oslijep" />
|
<RegEx find="oslj?ep" replaceWith="oslijep" />
|
||||||
<RegEx find="sj?etić" replaceWith="sjetit ć" />
|
<RegEx find="sj?etić" replaceWith="sjetit ć" />
|
||||||
<RegEx find="osb" replaceWith="osob" />
|
<RegEx find="osb" replaceWith="osob" />
|
||||||
|
<RegEx find="oskb" replaceWith="osob" />
|
||||||
<RegEx find="ot[čć]i" replaceWith="odči" />
|
<RegEx find="ot[čć]i" replaceWith="odči" />
|
||||||
<RegEx find="otse" replaceWith="odsje" />
|
<RegEx find="otse" replaceWith="odsje" />
|
||||||
<RegEx find="otstak" replaceWith="otak" />
|
<RegEx find="otstak" replaceWith="otak" />
|
||||||
@ -5825,6 +5829,7 @@
|
|||||||
<RegEx find="vsj" replaceWith="vaj" />
|
<RegEx find="vsj" replaceWith="vaj" />
|
||||||
<RegEx find="vsn" replaceWith="van" />
|
<RegEx find="vsn" replaceWith="van" />
|
||||||
<RegEx find="([zZ])amenit" replaceWith="$1amijenit" />
|
<RegEx find="([zZ])amenit" replaceWith="$1amijenit" />
|
||||||
|
<RegEx find="zamjs" replaceWith="zmajs" />
|
||||||
<RegEx find="zankin" replaceWith="zank" />
|
<RegEx find="zankin" replaceWith="zank" />
|
||||||
<RegEx find="zanš" replaceWith="znaš" />
|
<RegEx find="zanš" replaceWith="znaš" />
|
||||||
<RegEx find="zaklać" replaceWith="zaklat ć" />
|
<RegEx find="zaklać" replaceWith="zaklat ć" />
|
||||||
@ -5843,9 +5848,7 @@
|
|||||||
<RegEx find="(?<![Oo]bra|o)zova([lton])" replaceWith="zira$1" />
|
<RegEx find="(?<![Oo]bra|o)zova([lton])" replaceWith="zira$1" />
|
||||||
<RegEx find="zpr" replaceWith="spr" />
|
<RegEx find="zpr" replaceWith="spr" />
|
||||||
<RegEx find="zref" replaceWith="zrel" />
|
<RegEx find="zref" replaceWith="zrel" />
|
||||||
<RegEx find="zsk" replaceWith="zak" />
|
<RegEx find="zs([kgnp])" replaceWith="za$1" />
|
||||||
<RegEx find="zsn" replaceWith="zan" />
|
|
||||||
<RegEx find="zsp" replaceWith="zap" />
|
|
||||||
<RegEx find="zqp" replaceWith="zap" />
|
<RegEx find="zqp" replaceWith="zap" />
|
||||||
<RegEx find="zuslov" replaceWith="zuvjet" />
|
<RegEx find="zuslov" replaceWith="zuvjet" />
|
||||||
<RegEx find="zvešć" replaceWith="zvest ć" />
|
<RegEx find="zvešć" replaceWith="zvest ć" />
|
||||||
|
@ -3188,6 +3188,8 @@ Continue?</RestoreDefaultSettingsMsg>
|
|||||||
<AutoContinue>Auto-continue</AutoContinue>
|
<AutoContinue>Auto-continue</AutoContinue>
|
||||||
<Regenerate>Regenerate</Regenerate>
|
<Regenerate>Regenerate</Regenerate>
|
||||||
<Speed>Speed</Speed>
|
<Speed>Speed</Speed>
|
||||||
|
<Stability>Stability</Stability>
|
||||||
|
<Similarity>Similarity</Similarity>
|
||||||
</TextToSpeech>
|
</TextToSpeech>
|
||||||
<TimedTextSmpteTiming>
|
<TimedTextSmpteTiming>
|
||||||
<Title>SMPTE timing</Title>
|
<Title>SMPTE timing</Title>
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
using Nikse.SubtitleEdit.Core.Common;
|
using Nikse.SubtitleEdit.Core.Common;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using static System.Net.WebRequestMethods;
|
|
||||||
|
|
||||||
namespace Nikse.SubtitleEdit.Core.AudioToText
|
namespace Nikse.SubtitleEdit.Core.AudioToText
|
||||||
{
|
{
|
||||||
|
98
src/libse/AutoTranslate/DeepLXTranslate.cs
Normal file
98
src/libse/AutoTranslate/DeepLXTranslate.cs
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Net;
|
||||||
|
using System.Net.Http;
|
||||||
|
using System.Threading;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Nikse.SubtitleEdit.Core.Common;
|
||||||
|
using Nikse.SubtitleEdit.Core.Translate;
|
||||||
|
|
||||||
|
namespace Nikse.SubtitleEdit.Core.AutoTranslate
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// DeepLX translator - see https://github.com/OwO-Network/DeepLX
|
||||||
|
/// </summary>
|
||||||
|
public class DeepLXTranslate : IAutoTranslator
|
||||||
|
{
|
||||||
|
private string _apiUrl;
|
||||||
|
private HttpClient _client;
|
||||||
|
|
||||||
|
public static string StaticName { get; set; } = "DeepLX translate";
|
||||||
|
public override string ToString() => StaticName;
|
||||||
|
public string Name => StaticName;
|
||||||
|
public string Url => "https://github.com/OwO-Network/DeepLX";
|
||||||
|
public string Error { get; set; }
|
||||||
|
public int MaxCharacters => 1500;
|
||||||
|
|
||||||
|
public void Initialize()
|
||||||
|
{
|
||||||
|
if (string.IsNullOrEmpty(Configuration.Settings.Tools.AutoTranslateDeepLXUrl))
|
||||||
|
{
|
||||||
|
Configuration.Settings.Tools.AutoTranslateDeepLXUrl = "http://localhost:1188";
|
||||||
|
}
|
||||||
|
_apiUrl = Configuration.Settings.Tools.AutoTranslateDeepLXUrl;
|
||||||
|
|
||||||
|
_client = new HttpClient();
|
||||||
|
_client.BaseAddress = new Uri(_apiUrl.Trim().TrimEnd('/'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<TranslationPair> GetSupportedSourceLanguages()
|
||||||
|
{
|
||||||
|
return new DeepLTranslate().GetSupportedSourceLanguages();
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<TranslationPair> GetSupportedTargetLanguages()
|
||||||
|
{
|
||||||
|
return new DeepLTranslate().GetSupportedTargetLanguages();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Task<string> Translate(string text, string sourceLanguageCode, string targetLanguageCode, CancellationToken cancellationToken)
|
||||||
|
{
|
||||||
|
var postContent = new FormUrlEncodedContent(new[]
|
||||||
|
{
|
||||||
|
new KeyValuePair<string, string>("text", text),
|
||||||
|
new KeyValuePair<string, string>("target_lang", targetLanguageCode),
|
||||||
|
new KeyValuePair<string, string>("source_lang", sourceLanguageCode),
|
||||||
|
});
|
||||||
|
var result = _client.PostAsync("/v2/translate", postContent, cancellationToken).Result;
|
||||||
|
var resultContent = result.Content.ReadAsStringAsync().Result;
|
||||||
|
|
||||||
|
if (!result.IsSuccessStatusCode)
|
||||||
|
{
|
||||||
|
SeLogger.Error("DeepLTranslate error: " + resultContent);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (result.StatusCode == HttpStatusCode.Forbidden)
|
||||||
|
{
|
||||||
|
Error = resultContent;
|
||||||
|
throw new Exception("Forbidden! " + Environment.NewLine + Environment.NewLine + resultContent);
|
||||||
|
}
|
||||||
|
|
||||||
|
var resultList = new List<string>();
|
||||||
|
var parser = new JsonParser();
|
||||||
|
var x = (Dictionary<string, object>)parser.Parse(resultContent);
|
||||||
|
foreach (var k in x.Keys)
|
||||||
|
{
|
||||||
|
if (x[k] is List<object> mainList)
|
||||||
|
{
|
||||||
|
foreach (var mainListItem in mainList)
|
||||||
|
{
|
||||||
|
if (mainListItem is Dictionary<string, object> innerDic)
|
||||||
|
{
|
||||||
|
foreach (var transItem in innerDic.Keys)
|
||||||
|
{
|
||||||
|
if (transItem == "text")
|
||||||
|
{
|
||||||
|
var s = innerDic[transItem].ToString();
|
||||||
|
resultList.Add(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return Task.FromResult(string.Join(Environment.NewLine, resultList));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -354,7 +354,7 @@ namespace Nikse.SubtitleEdit.Core.Common
|
|||||||
public TimeCode AlignToFrame()
|
public TimeCode AlignToFrame()
|
||||||
{
|
{
|
||||||
var ts = TimeSpan.FromMilliseconds(Math.Round(TotalMilliseconds, MidpointRounding.AwayFromZero));
|
var ts = TimeSpan.FromMilliseconds(Math.Round(TotalMilliseconds, MidpointRounding.AwayFromZero));
|
||||||
var frames = Math.Round(ts.Milliseconds / (TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate));
|
var frames = SubtitleFormat.MillisecondsToFrames(ts.Milliseconds);
|
||||||
TimeSpan ts2;
|
TimeSpan ts2;
|
||||||
if (frames >= Configuration.Settings.General.CurrentFrameRate - 0.001)
|
if (frames >= Configuration.Settings.General.CurrentFrameRate - 0.001)
|
||||||
{
|
{
|
||||||
|
@ -520,10 +520,10 @@ namespace Nikse.SubtitleEdit.Core.ContainerFormats.Matroska
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private string GetChapterName(Element ChapterDisplay)
|
private string GetChapterName(Element chapterDisplay)
|
||||||
{
|
{
|
||||||
Element element;
|
Element element;
|
||||||
while (_stream.Position < ChapterDisplay.EndPosition && (element = ReadElement()) != null)
|
while (_stream.Position < chapterDisplay.EndPosition && (element = ReadElement()) != null)
|
||||||
{
|
{
|
||||||
if (element.Id == ElementId.ChapString)
|
if (element.Id == ElementId.ChapString)
|
||||||
{
|
{
|
||||||
@ -671,11 +671,7 @@ namespace Nikse.SubtitleEdit.Core.ContainerFormats.Matroska
|
|||||||
return _subtitleRip;
|
return _subtitleRip;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose() => Dispose(true);
|
||||||
{
|
|
||||||
Dispose(true);
|
|
||||||
GC.SuppressFinalize(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void Dispose(bool disposing)
|
private void Dispose(bool disposing)
|
||||||
{
|
{
|
||||||
@ -686,7 +682,6 @@ namespace Nikse.SubtitleEdit.Core.ContainerFormats.Matroska
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void ReadSegmentInfoAndTracks()
|
private void ReadSegmentInfoAndTracks()
|
||||||
{
|
{
|
||||||
// go to segment
|
// go to segment
|
||||||
|
@ -111,7 +111,7 @@ namespace Nikse.SubtitleEdit.Core.Forms
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool FixConnectedSubtitles(Paragraph leftParagraph = null, Paragraph rightParagraph = null)
|
private bool FixConnectedSubtitles(Paragraph leftParagraph = null, Paragraph rightParagraph = null, bool checkConnected = true)
|
||||||
{
|
{
|
||||||
if (leftParagraph == null || rightParagraph == null)
|
if (leftParagraph == null || rightParagraph == null)
|
||||||
{
|
{
|
||||||
@ -140,7 +140,7 @@ namespace Nikse.SubtitleEdit.Core.Forms
|
|||||||
|
|
||||||
var subtitlesAreConnected = distance < Configuration.Settings.BeautifyTimeCodes.Profile.ConnectedSubtitlesTreatConnected;
|
var subtitlesAreConnected = distance < Configuration.Settings.BeautifyTimeCodes.Profile.ConnectedSubtitlesTreatConnected;
|
||||||
|
|
||||||
if (subtitlesAreConnected)
|
if (subtitlesAreConnected || !checkConnected)
|
||||||
{
|
{
|
||||||
var newLeftOutCueFrame = MillisecondsToFrames(leftParagraph.EndTime.TotalMilliseconds);
|
var newLeftOutCueFrame = MillisecondsToFrames(leftParagraph.EndTime.TotalMilliseconds);
|
||||||
var newRightInCueFrame = MillisecondsToFrames(rightParagraph.StartTime.TotalMilliseconds);
|
var newRightInCueFrame = MillisecondsToFrames(rightParagraph.StartTime.TotalMilliseconds);
|
||||||
@ -539,6 +539,17 @@ namespace Nikse.SubtitleEdit.Core.Forms
|
|||||||
bestRightInCueFrame = newRightInCueFrame;
|
bestRightInCueFrame = newRightInCueFrame;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Re-check if, with the new cues, the subtitles are actually connected
|
||||||
|
var newDistance = FramesToMilliseconds(bestRightInCueFrame) - FramesToMilliseconds(bestLeftOutCueFrame);
|
||||||
|
if (newDistance < Configuration.Settings.BeautifyTimeCodes.Profile.ConnectedSubtitlesTreatConnected)
|
||||||
|
{
|
||||||
|
// Yes, so handle using the designated function, ignoring its check connected check
|
||||||
|
// (because otherwise it would have handled it before going into the FixChainableSubtitles function)
|
||||||
|
FixConnectedSubtitles(leftParagraph, rightParagraph, checkConnected: false);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// Check cases
|
// Check cases
|
||||||
var isLeftOutCueOnShotChange = IsCueOnShotChange(bestLeftOutCueFrame, false);
|
var isLeftOutCueOnShotChange = IsCueOnShotChange(bestLeftOutCueFrame, false);
|
||||||
var isRightInCueOnShotChange = IsCueOnShotChange(bestRightInCueFrame, true);
|
var isRightInCueOnShotChange = IsCueOnShotChange(bestRightInCueFrame, true);
|
||||||
|
@ -2359,6 +2359,18 @@ namespace Nikse.SubtitleEdit.Core.Settings
|
|||||||
settings.Tools.TextToSpeechElevenLabsLanguage = subNode.InnerText;
|
settings.Tools.TextToSpeechElevenLabsLanguage = subNode.InnerText;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
subNode = node.SelectSingleNode("TextToSpeechElevenLabsStability");
|
||||||
|
if (subNode != null)
|
||||||
|
{
|
||||||
|
settings.Tools.TextToSpeechElevenLabsStability = Convert.ToDouble(subNode.InnerText, CultureInfo.InvariantCulture);
|
||||||
|
}
|
||||||
|
|
||||||
|
subNode = node.SelectSingleNode("TextToSpeechElevenLabsSimilarity");
|
||||||
|
if (subNode != null)
|
||||||
|
{
|
||||||
|
settings.Tools.TextToSpeechElevenLabsSimilarity = Convert.ToDouble(subNode.InnerText, CultureInfo.InvariantCulture);
|
||||||
|
}
|
||||||
|
|
||||||
subNode = node.SelectSingleNode("TextToSpeechAzureApiKey");
|
subNode = node.SelectSingleNode("TextToSpeechAzureApiKey");
|
||||||
if (subNode != null)
|
if (subNode != null)
|
||||||
{
|
{
|
||||||
@ -9034,6 +9046,8 @@ namespace Nikse.SubtitleEdit.Core.Settings
|
|||||||
xmlWriter.WriteElementString("TextToSpeechElevenLabsApiKey", settings.Tools.TextToSpeechElevenLabsApiKey);
|
xmlWriter.WriteElementString("TextToSpeechElevenLabsApiKey", settings.Tools.TextToSpeechElevenLabsApiKey);
|
||||||
xmlWriter.WriteElementString("TextToSpeechElevenLabsModel", settings.Tools.TextToSpeechElevenLabsModel);
|
xmlWriter.WriteElementString("TextToSpeechElevenLabsModel", settings.Tools.TextToSpeechElevenLabsModel);
|
||||||
xmlWriter.WriteElementString("TextToSpeechElevenLabsLanguage", settings.Tools.TextToSpeechElevenLabsLanguage);
|
xmlWriter.WriteElementString("TextToSpeechElevenLabsLanguage", settings.Tools.TextToSpeechElevenLabsLanguage);
|
||||||
|
xmlWriter.WriteElementString("TextToSpeechElevenLabsStability", settings.Tools.TextToSpeechElevenLabsStability.ToString(CultureInfo.InvariantCulture));
|
||||||
|
xmlWriter.WriteElementString("TextToSpeechElevenLabsSimilarity", settings.Tools.TextToSpeechElevenLabsSimilarity.ToString(CultureInfo.InvariantCulture));
|
||||||
xmlWriter.WriteElementString("TextToSpeechAzureApiKey", settings.Tools.TextToSpeechAzureApiKey);
|
xmlWriter.WriteElementString("TextToSpeechAzureApiKey", settings.Tools.TextToSpeechAzureApiKey);
|
||||||
xmlWriter.WriteElementString("TextToSpeechAzureRegion", settings.Tools.TextToSpeechAzureRegion);
|
xmlWriter.WriteElementString("TextToSpeechAzureRegion", settings.Tools.TextToSpeechAzureRegion);
|
||||||
xmlWriter.WriteElementString("TextToSpeechPreview", settings.Tools.TextToSpeechPreview.ToString(CultureInfo.InvariantCulture));
|
xmlWriter.WriteElementString("TextToSpeechPreview", settings.Tools.TextToSpeechPreview.ToString(CultureInfo.InvariantCulture));
|
||||||
|
@ -58,6 +58,7 @@ namespace Nikse.SubtitleEdit.Core.Settings
|
|||||||
public string AutoTranslateSeamlessM4TUrl { get; set; }
|
public string AutoTranslateSeamlessM4TUrl { get; set; }
|
||||||
public string AutoTranslateDeepLApiKey { get; set; }
|
public string AutoTranslateDeepLApiKey { get; set; }
|
||||||
public string AutoTranslateDeepLUrl { get; set; }
|
public string AutoTranslateDeepLUrl { get; set; }
|
||||||
|
public string AutoTranslateDeepLXUrl { get; set; }
|
||||||
public string AutoTranslatePapagoApiKeyId { get; set; }
|
public string AutoTranslatePapagoApiKeyId { get; set; }
|
||||||
public string AutoTranslatePapagoApiKey { get; set; }
|
public string AutoTranslatePapagoApiKey { get; set; }
|
||||||
public string AutoTranslateDeepLFormality { get; set; }
|
public string AutoTranslateDeepLFormality { get; set; }
|
||||||
@ -102,6 +103,8 @@ namespace Nikse.SubtitleEdit.Core.Settings
|
|||||||
public string TextToSpeechAzureRegion { get; set; }
|
public string TextToSpeechAzureRegion { get; set; }
|
||||||
public string TextToSpeechElevenLabsModel { get; set; }
|
public string TextToSpeechElevenLabsModel { get; set; }
|
||||||
public string TextToSpeechElevenLabsLanguage { get; set; }
|
public string TextToSpeechElevenLabsLanguage { get; set; }
|
||||||
|
public double TextToSpeechElevenLabsStability { get; set; }
|
||||||
|
public double TextToSpeechElevenLabsSimilarity { get; set; }
|
||||||
public bool TextToSpeechPreview { get; set; }
|
public bool TextToSpeechPreview { get; set; }
|
||||||
public bool TextToSpeechCustomAudio { get; set; }
|
public bool TextToSpeechCustomAudio { get; set; }
|
||||||
public bool TextToSpeechCustomAudioStereo { get; set; }
|
public bool TextToSpeechCustomAudioStereo { get; set; }
|
||||||
@ -470,6 +473,7 @@ namespace Nikse.SubtitleEdit.Core.Settings
|
|||||||
AutoTranslateLibreUrl = "http://localhost:5000/";
|
AutoTranslateLibreUrl = "http://localhost:5000/";
|
||||||
AutoTranslateSeamlessM4TUrl = "http://localhost:5000/";
|
AutoTranslateSeamlessM4TUrl = "http://localhost:5000/";
|
||||||
AutoTranslateDeepLUrl = "https://api-free.deepl.com/";
|
AutoTranslateDeepLUrl = "https://api-free.deepl.com/";
|
||||||
|
AutoTranslateDeepLUrl = "http://localhost:1188";
|
||||||
ChatGptUrl = "https://api.openai.com/v1/chat/completions";
|
ChatGptUrl = "https://api.openai.com/v1/chat/completions";
|
||||||
ChatGptPrompt = "Translate from {0} to {1}, keep punctuation as input, do not censor the translation, give only the output without comments:";
|
ChatGptPrompt = "Translate from {0} to {1}, keep punctuation as input, do not censor the translation, give only the output without comments:";
|
||||||
ChatGptModel = ChatGptTranslate.Models[0];
|
ChatGptModel = ChatGptTranslate.Models[0];
|
||||||
@ -488,6 +492,8 @@ namespace Nikse.SubtitleEdit.Core.Settings
|
|||||||
AnthropicPrompt = "Translate from {0} to {1}, keep sentences in {1} as they are, do not censor the translation, give only the output without comments:";
|
AnthropicPrompt = "Translate from {0} to {1}, keep sentences in {1} as they are, do not censor the translation, give only the output without comments:";
|
||||||
AnthropicApiModel = AnthropicTranslate.Models[0];
|
AnthropicApiModel = AnthropicTranslate.Models[0];
|
||||||
TextToSpeechAzureRegion = "westeurope";
|
TextToSpeechAzureRegion = "westeurope";
|
||||||
|
TextToSpeechElevenLabsSimilarity = 0.5;
|
||||||
|
TextToSpeechElevenLabsStability = 0.5;
|
||||||
AutoTranslateMaxBytes = 2000;
|
AutoTranslateMaxBytes = 2000;
|
||||||
TextToSpeechAddToVideoFile = true;
|
TextToSpeechAddToVideoFile = true;
|
||||||
TranslateAllowSplit = true;
|
TranslateAllowSplit = true;
|
||||||
|
@ -131,11 +131,6 @@ namespace Nikse.SubtitleEdit.Core.SubtitleFormats
|
|||||||
return frames.ToString(CultureInfo.InvariantCulture);
|
return frames.ToString(CultureInfo.InvariantCulture);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TimeCode DecodeTimeCode(string timePart)
|
private static TimeCode DecodeTimeCode(string timePart) => new TimeCode(FramesToMilliseconds(int.Parse(timePart)));
|
||||||
{
|
|
||||||
int milliseconds = (int)Math.Round(TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate * int.Parse(timePart));
|
|
||||||
return new TimeCode(milliseconds);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,14 +24,7 @@ namespace Nikse.SubtitleEdit.Core.SubtitleFormats
|
|||||||
var minutes = int.Parse(parts[1]);
|
var minutes = int.Parse(parts[1]);
|
||||||
var seconds = int.Parse(parts[2]);
|
var seconds = int.Parse(parts[2]);
|
||||||
var frames = int.Parse(parts[3]);
|
var frames = int.Parse(parts[3]);
|
||||||
|
return new TimeCode(hour, minutes, seconds, FramesToMillisecondsMax999(frames));
|
||||||
int milliseconds = (int)Math.Round(((TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate) * frames));
|
|
||||||
if (milliseconds > 999)
|
|
||||||
{
|
|
||||||
milliseconds = 999;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new TimeCode(hour, minutes, seconds, milliseconds);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string ToText(Subtitle subtitle, string title)
|
public override string ToText(Subtitle subtitle, string title)
|
||||||
|
@ -1522,8 +1522,7 @@ namespace Nikse.SubtitleEdit.Core.SubtitleFormats
|
|||||||
|
|
||||||
private static void WriteTime(Stream fs, TimeCode timeCode)
|
private static void WriteTime(Stream fs, TimeCode timeCode)
|
||||||
{
|
{
|
||||||
double totalMilliseconds = timeCode.TotalMilliseconds;
|
int frames = MillisecondsToFrames(timeCode.TotalMilliseconds);
|
||||||
int frames = (int)Math.Round(totalMilliseconds / (TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate));
|
|
||||||
fs.WriteByte((byte)(frames / 256 / 256));
|
fs.WriteByte((byte)(frames / 256 / 256));
|
||||||
fs.WriteByte((byte)(frames / 256));
|
fs.WriteByte((byte)(frames / 256));
|
||||||
fs.WriteByte((byte)(frames % 256));
|
fs.WriteByte((byte)(frames % 256));
|
||||||
@ -1644,8 +1643,8 @@ namespace Nikse.SubtitleEdit.Core.SubtitleFormats
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
subtitle.Paragraphs.Add(p);
|
subtitle.Paragraphs.Add(p);
|
||||||
p.StartTime.TotalMilliseconds = (TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate) * startFrame;
|
p.StartTime.TotalMilliseconds = FramesToMilliseconds(startFrame);
|
||||||
p.EndTime.TotalMilliseconds = (TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate) * endFrame;
|
p.EndTime.TotalMilliseconds = FramesToMilliseconds(endFrame);
|
||||||
p.Text = string.Join(Environment.NewLine, new[] { line1, line2 }.Select(l => l.TrimEnd()).Where(l => !string.IsNullOrWhiteSpace(l)));
|
p.Text = string.Join(Environment.NewLine, new[] { line1, line2 }.Select(l => l.TrimEnd()).Where(l => !string.IsNullOrWhiteSpace(l)));
|
||||||
}
|
}
|
||||||
if (boxType >= 0xa0 && boxType <= 0xa9 && !string.IsNullOrEmpty(p.Text)) // box
|
if (boxType >= 0xa0 && boxType <= 0xa9 && !string.IsNullOrEmpty(p.Text)) // box
|
||||||
|
@ -48,7 +48,7 @@ namespace Nikse.SubtitleEdit.Core.SubtitleFormats
|
|||||||
{
|
{
|
||||||
string s;
|
string s;
|
||||||
var ts = p.Duration.TimeSpan;
|
var ts = p.Duration.TimeSpan;
|
||||||
var frames = Math.Round(ts.Milliseconds / (TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate));
|
var frames = MillisecondsToFrames(ts.Milliseconds);
|
||||||
if (frames >= Configuration.Settings.General.CurrentFrameRate - 0.001)
|
if (frames >= Configuration.Settings.General.CurrentFrameRate - 0.001)
|
||||||
{
|
{
|
||||||
s = $"{ts.Seconds + 1:00}:{0:00}";
|
s = $"{ts.Seconds + 1:00}:{0:00}";
|
||||||
|
@ -62,14 +62,7 @@ namespace Nikse.SubtitleEdit.Core.SubtitleFormats
|
|||||||
int minutes = buffer[index + 1];
|
int minutes = buffer[index + 1];
|
||||||
int seconds = buffer[index + 2];
|
int seconds = buffer[index + 2];
|
||||||
int frames = buffer[index + 3];
|
int frames = buffer[index + 3];
|
||||||
|
return new TimeCode(hour, minutes, seconds, FramesToMillisecondsMax999(frames));
|
||||||
int milliseconds = (int)Math.Round(TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate * frames);
|
|
||||||
if (milliseconds > 999)
|
|
||||||
{
|
|
||||||
milliseconds = 999;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new TimeCode(hour, minutes, seconds, milliseconds);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void LoadSubtitle(Subtitle subtitle, List<string> lines, string fileName)
|
public override void LoadSubtitle(Subtitle subtitle, List<string> lines, string fileName)
|
||||||
|
@ -72,17 +72,8 @@ namespace Nikse.SubtitleEdit.Core.SubtitleFormats
|
|||||||
subtitle.Renumber();
|
subtitle.Renumber();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static string EncodeTimeCode(TimeCode time)
|
private static string EncodeTimeCode(TimeCode time) => MillisecondsToFrames(time.TotalMilliseconds).ToString();
|
||||||
{
|
|
||||||
long frames = (long)(time.TotalMilliseconds / (TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate));
|
|
||||||
return frames.ToString();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static TimeCode DecodeTimeCode(string timePart)
|
|
||||||
{
|
|
||||||
int milliseconds = (int)Math.Round(TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate * int.Parse(timePart));
|
|
||||||
return new TimeCode(milliseconds);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
private static TimeCode DecodeTimeCode(string timePart) => new TimeCode(FramesToMilliseconds(int.Parse(timePart)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -560,17 +560,12 @@ namespace Nikse.SubtitleEdit.Forms.AudioToText
|
|||||||
Configuration.Settings.Tools.WhisperPostProcessingFixShortDuration,
|
Configuration.Settings.Tools.WhisperPostProcessingFixShortDuration,
|
||||||
Configuration.Settings.Tools.WhisperPostProcessingSplitLines);
|
Configuration.Settings.Tools.WhisperPostProcessingSplitLines);
|
||||||
|
|
||||||
|
UpdateLog();
|
||||||
|
SeLogger.WhisperInfo(textBoxLog.Text);
|
||||||
if (transcript == null || transcript.Paragraphs.Count == 0)
|
if (transcript == null || transcript.Paragraphs.Count == 0)
|
||||||
{
|
{
|
||||||
UpdateLog();
|
|
||||||
SeLogger.WhisperInfo(textBoxLog.Text);
|
|
||||||
IncompleteModelName = comboBoxModels.Text;
|
IncompleteModelName = comboBoxModels.Text;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
UpdateLog();
|
|
||||||
SeLogger.WhisperInfo(textBoxLog.Text);
|
|
||||||
}
|
|
||||||
|
|
||||||
timer1.Stop();
|
timer1.Stop();
|
||||||
|
|
||||||
@ -1054,8 +1049,8 @@ namespace Nikse.SubtitleEdit.Forms.AudioToText
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
var rawText = FileUtil.ReadAllLinesShared(srtFileName, Encoding.UTF8);
|
var rawText = FileUtil.ReadAllLinesShared(vttFileName, Encoding.UTF8);
|
||||||
new WebVTT().LoadSubtitle(sub, rawText, srtFileName);
|
new WebVTT().LoadSubtitle(sub, rawText, vttFileName);
|
||||||
outputText?.Add($"Loading result from {vttFileName}{Environment.NewLine}");
|
outputText?.Add($"Loading result from {vttFileName}{Environment.NewLine}");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -610,6 +610,7 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
listView1.Select();
|
listView1.Select();
|
||||||
|
|
||||||
AcceptButton = buttonNextFinish;
|
AcceptButton = buttonNextFinish;
|
||||||
|
textBoxListViewText.AcceptsReturn = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void FixLargeFonts()
|
private void FixLargeFonts()
|
||||||
|
@ -10,7 +10,7 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
{
|
{
|
||||||
public partial class ImportUnknownFormat : Form
|
public partial class ImportUnknownFormat : Form
|
||||||
{
|
{
|
||||||
public Subtitle ImportedSubitle { get; private set; }
|
public Subtitle ImportedSubtitle { get; private set; }
|
||||||
private readonly Timer _refreshTimer = new Timer();
|
private readonly Timer _refreshTimer = new Timer();
|
||||||
|
|
||||||
public ImportUnknownFormat(string fileName)
|
public ImportUnknownFormat(string fileName)
|
||||||
@ -47,10 +47,10 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
private void GeneratePreviewReal()
|
private void GeneratePreviewReal()
|
||||||
{
|
{
|
||||||
var uknownFormatImporter = new UnknownFormatImporter { UseFrames = radioButtonTimeCodeFrames.Checked };
|
var uknownFormatImporter = new UnknownFormatImporter { UseFrames = radioButtonTimeCodeFrames.Checked };
|
||||||
ImportedSubitle = uknownFormatImporter.AutoGuessImport(textBoxText.Lines.ToList());
|
ImportedSubtitle = uknownFormatImporter.AutoGuessImport(textBoxText.Lines.ToList());
|
||||||
groupBoxImportResult.Text = string.Format(LanguageSettings.Current.ImportText.PreviewLinesModifiedX, ImportedSubitle.Paragraphs.Count);
|
groupBoxImportResult.Text = string.Format(LanguageSettings.Current.ImportText.PreviewLinesModifiedX, ImportedSubtitle.Paragraphs.Count);
|
||||||
SubtitleListview1.Fill(ImportedSubitle);
|
SubtitleListview1.Fill(ImportedSubtitle);
|
||||||
if (ImportedSubitle.Paragraphs.Count > 0)
|
if (ImportedSubtitle.Paragraphs.Count > 0)
|
||||||
{
|
{
|
||||||
SubtitleListview1.SelectIndexAndEnsureVisible(0);
|
SubtitleListview1.SelectIndexAndEnsureVisible(0);
|
||||||
}
|
}
|
||||||
|
@ -5394,7 +5394,7 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
return DialogResult.No;
|
return DialogResult.No;
|
||||||
}
|
}
|
||||||
|
|
||||||
MessageBox.Show("Ups - save original does not support this format - please go to Github and create an issue!");
|
MessageBox.Show("Oops - save original does not support this format - please go to Github and create an issue!");
|
||||||
}
|
}
|
||||||
|
|
||||||
string allText = subAlt.ToText(format);
|
string allText = subAlt.ToText(format);
|
||||||
@ -13408,7 +13408,7 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
{
|
{
|
||||||
var seconds = (int)numericUpDownDuration.Value;
|
var seconds = (int)numericUpDownDuration.Value;
|
||||||
var frames = (int)Math.Round((Convert.ToDouble(numericUpDownDuration.Value) % 1.0 * 100.0));
|
var frames = (int)Math.Round((Convert.ToDouble(numericUpDownDuration.Value) % 1.0 * 100.0));
|
||||||
return seconds * TimeCode.BaseUnit + frames * (TimeCode.BaseUnit / Configuration.Settings.General.CurrentFrameRate);
|
return seconds * TimeCode.BaseUnit + SubtitleFormat.FramesToMilliseconds(frames);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ((double)numericUpDownDuration.Value * TimeCode.BaseUnit);
|
return ((double)numericUpDownDuration.Value * TimeCode.BaseUnit);
|
||||||
@ -18638,9 +18638,9 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
{
|
{
|
||||||
if (form.ShowDialog(this) == DialogResult.OK)
|
if (form.ShowDialog(this) == DialogResult.OK)
|
||||||
{
|
{
|
||||||
if (form.ImportedSubitle?.Paragraphs.Count > 0)
|
if (form.ImportedSubtitle?.Paragraphs.Count > 0)
|
||||||
{
|
{
|
||||||
_subtitle = form.ImportedSubitle;
|
_subtitle = form.ImportedSubtitle;
|
||||||
_fileName = null;
|
_fileName = null;
|
||||||
SubtitleListview1.Fill(_subtitle, _subtitleOriginal);
|
SubtitleListview1.Fill(_subtitle, _subtitleOriginal);
|
||||||
SetTitle();
|
SetTitle();
|
||||||
|
16
src/ui/Forms/Ocr/OCRSpellCheck.Designer.cs
generated
16
src/ui/Forms/Ocr/OCRSpellCheck.Designer.cs
generated
@ -206,6 +206,7 @@
|
|||||||
//
|
//
|
||||||
// textBoxWord
|
// textBoxWord
|
||||||
//
|
//
|
||||||
|
this.textBoxWord.FocusedColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
this.textBoxWord.Font = new System.Drawing.Font("Tahoma", 9F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
this.textBoxWord.Font = new System.Drawing.Font("Tahoma", 9F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||||
this.textBoxWord.Location = new System.Drawing.Point(6, 19);
|
this.textBoxWord.Location = new System.Drawing.Point(6, 19);
|
||||||
this.textBoxWord.Name = "textBoxWord";
|
this.textBoxWord.Name = "textBoxWord";
|
||||||
@ -250,9 +251,9 @@
|
|||||||
//
|
//
|
||||||
// buttonChangeAllWholeText
|
// buttonChangeAllWholeText
|
||||||
//
|
//
|
||||||
this.buttonChangeAllWholeText.Location = new System.Drawing.Point(6, 115);
|
this.buttonChangeAllWholeText.Location = new System.Drawing.Point(6, 117);
|
||||||
this.buttonChangeAllWholeText.Name = "buttonChangeAllWholeText";
|
this.buttonChangeAllWholeText.Name = "buttonChangeAllWholeText";
|
||||||
this.buttonChangeAllWholeText.Size = new System.Drawing.Size(141, 21);
|
this.buttonChangeAllWholeText.Size = new System.Drawing.Size(141, 23);
|
||||||
this.buttonChangeAllWholeText.TabIndex = 36;
|
this.buttonChangeAllWholeText.TabIndex = 36;
|
||||||
this.buttonChangeAllWholeText.Text = "Change all";
|
this.buttonChangeAllWholeText.Text = "Change all";
|
||||||
this.buttonChangeAllWholeText.UseVisualStyleBackColor = true;
|
this.buttonChangeAllWholeText.UseVisualStyleBackColor = true;
|
||||||
@ -262,7 +263,7 @@
|
|||||||
//
|
//
|
||||||
this.buttonSkipText.Location = new System.Drawing.Point(156, 88);
|
this.buttonSkipText.Location = new System.Drawing.Point(156, 88);
|
||||||
this.buttonSkipText.Name = "buttonSkipText";
|
this.buttonSkipText.Name = "buttonSkipText";
|
||||||
this.buttonSkipText.Size = new System.Drawing.Size(139, 21);
|
this.buttonSkipText.Size = new System.Drawing.Size(139, 23);
|
||||||
this.buttonSkipText.TabIndex = 35;
|
this.buttonSkipText.TabIndex = 35;
|
||||||
this.buttonSkipText.Text = "Skip text";
|
this.buttonSkipText.Text = "Skip text";
|
||||||
this.buttonSkipText.UseVisualStyleBackColor = true;
|
this.buttonSkipText.UseVisualStyleBackColor = true;
|
||||||
@ -272,7 +273,7 @@
|
|||||||
//
|
//
|
||||||
this.buttonChangeWholeText.Location = new System.Drawing.Point(6, 88);
|
this.buttonChangeWholeText.Location = new System.Drawing.Point(6, 88);
|
||||||
this.buttonChangeWholeText.Name = "buttonChangeWholeText";
|
this.buttonChangeWholeText.Name = "buttonChangeWholeText";
|
||||||
this.buttonChangeWholeText.Size = new System.Drawing.Size(143, 21);
|
this.buttonChangeWholeText.Size = new System.Drawing.Size(143, 23);
|
||||||
this.buttonChangeWholeText.TabIndex = 34;
|
this.buttonChangeWholeText.TabIndex = 34;
|
||||||
this.buttonChangeWholeText.Text = "Change";
|
this.buttonChangeWholeText.Text = "Change";
|
||||||
this.buttonChangeWholeText.UseVisualStyleBackColor = true;
|
this.buttonChangeWholeText.UseVisualStyleBackColor = true;
|
||||||
@ -280,6 +281,7 @@
|
|||||||
//
|
//
|
||||||
// textBoxWholeText
|
// textBoxWholeText
|
||||||
//
|
//
|
||||||
|
this.textBoxWholeText.FocusedColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
this.textBoxWholeText.Font = new System.Drawing.Font("Tahoma", 9F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
this.textBoxWholeText.Font = new System.Drawing.Font("Tahoma", 9F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||||
this.textBoxWholeText.Location = new System.Drawing.Point(6, 19);
|
this.textBoxWholeText.Location = new System.Drawing.Point(6, 19);
|
||||||
this.textBoxWholeText.Multiline = true;
|
this.textBoxWholeText.Multiline = true;
|
||||||
@ -394,14 +396,14 @@
|
|||||||
this.buttonEditWord.UseVisualStyleBackColor = true;
|
this.buttonEditWord.UseVisualStyleBackColor = true;
|
||||||
this.buttonEditWord.Click += new System.EventHandler(this.ButtonEditWordClick);
|
this.buttonEditWord.Click += new System.EventHandler(this.ButtonEditWordClick);
|
||||||
//
|
//
|
||||||
// contextMenuStrip2
|
// contextMenuStripForm
|
||||||
//
|
//
|
||||||
this.contextMenuStripForm.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {
|
this.contextMenuStripForm.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {
|
||||||
this.useLargerFontForThisWindowToolStripMenuItem});
|
this.useLargerFontForThisWindowToolStripMenuItem});
|
||||||
this.contextMenuStripForm.Name = "contextMenuStripForm";
|
this.contextMenuStripForm.Name = "contextMenuStripForm";
|
||||||
this.contextMenuStripForm.Size = new System.Drawing.Size(237, 48);
|
this.contextMenuStripForm.Size = new System.Drawing.Size(237, 26);
|
||||||
//
|
//
|
||||||
// useLargerFontForThisWindowToolStripMenuItem1
|
// useLargerFontForThisWindowToolStripMenuItem
|
||||||
//
|
//
|
||||||
this.useLargerFontForThisWindowToolStripMenuItem.Name = "useLargerFontForThisWindowToolStripMenuItem";
|
this.useLargerFontForThisWindowToolStripMenuItem.Name = "useLargerFontForThisWindowToolStripMenuItem";
|
||||||
this.useLargerFontForThisWindowToolStripMenuItem.Size = new System.Drawing.Size(236, 22);
|
this.useLargerFontForThisWindowToolStripMenuItem.Size = new System.Drawing.Size(236, 22);
|
||||||
|
@ -94,6 +94,7 @@ namespace Nikse.SubtitleEdit.Forms.ShotChanges
|
|||||||
"|JSON shot changes file|*.json" +
|
"|JSON shot changes file|*.json" +
|
||||||
"|" + LanguageSettings.Current.General.AllFiles + "|*.*";
|
"|" + LanguageSettings.Current.General.AllFiles + "|*.*";
|
||||||
openFileDialog1.FileName = string.Empty;
|
openFileDialog1.FileName = string.Empty;
|
||||||
|
openFileDialog1.InitialDirectory = Path.GetDirectoryName(_videoFileName);
|
||||||
if (openFileDialog1.ShowDialog() == DialogResult.OK)
|
if (openFileDialog1.ShowDialog() == DialogResult.OK)
|
||||||
{
|
{
|
||||||
LoadTextFile(openFileDialog1.FileName);
|
LoadTextFile(openFileDialog1.FileName);
|
||||||
|
@ -133,6 +133,7 @@ namespace Nikse.SubtitleEdit.Forms.Translate
|
|||||||
new OpenRouterTranslate(),
|
new OpenRouterTranslate(),
|
||||||
new GeminiTranslate(),
|
new GeminiTranslate(),
|
||||||
new PapagoTranslate(),
|
new PapagoTranslate(),
|
||||||
|
new DeepLXTranslate(),
|
||||||
new NoLanguageLeftBehindServe(),
|
new NoLanguageLeftBehindServe(),
|
||||||
new NoLanguageLeftBehindApi(),
|
new NoLanguageLeftBehindApi(),
|
||||||
};
|
};
|
||||||
@ -227,6 +228,21 @@ namespace Nikse.SubtitleEdit.Forms.Translate
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (engineType == typeof(DeepLXTranslate))
|
||||||
|
{
|
||||||
|
if (string.IsNullOrEmpty(Configuration.Settings.Tools.AutoTranslateDeepLXUrl))
|
||||||
|
{
|
||||||
|
Configuration.Settings.Tools.AutoTranslateDeepLXUrl = "http://localhost:1188";
|
||||||
|
}
|
||||||
|
|
||||||
|
FillUrls(new List<string>
|
||||||
|
{
|
||||||
|
Configuration.Settings.Tools.AutoTranslateDeepLXUrl,
|
||||||
|
});
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (engineType == typeof(NoLanguageLeftBehindServe))
|
if (engineType == typeof(NoLanguageLeftBehindServe))
|
||||||
{
|
{
|
||||||
FillUrls(new List<string>
|
FillUrls(new List<string>
|
||||||
@ -1054,6 +1070,19 @@ namespace Nikse.SubtitleEdit.Forms.Translate
|
|||||||
UiUtil.ShowHelp("#translation");
|
UiUtil.ShowHelp("#translation");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (linesTranslate == 0 && engineType == typeof(DeepLXTranslate) && exception.Message.Contains("No connection could be made because the target machine actively refused it"))
|
||||||
|
{
|
||||||
|
MessageBox.Show(
|
||||||
|
this, "You need a local API to use DeepLX. Run ths docker command: "+ Environment.NewLine +
|
||||||
|
"docker run -itd -p 1188:1188 ghcr.io/owo-network/deeplx:latest" + Environment.NewLine +
|
||||||
|
Environment.NewLine +
|
||||||
|
exception.Message + Environment.NewLine +
|
||||||
|
Environment.NewLine +
|
||||||
|
"For more information visit: " + new DeepLXTranslate().Url,
|
||||||
|
Text,
|
||||||
|
MessageBoxButtons.OKCancel,
|
||||||
|
MessageBoxIcon.Error);
|
||||||
|
}
|
||||||
else if (linesTranslate == 0 &&
|
else if (linesTranslate == 0 &&
|
||||||
(nikseComboBoxUrl.Text.Contains("//192.", StringComparison.OrdinalIgnoreCase) ||
|
(nikseComboBoxUrl.Text.Contains("//192.", StringComparison.OrdinalIgnoreCase) ||
|
||||||
nikseComboBoxUrl.Text.Contains("//127.", StringComparison.OrdinalIgnoreCase) ||
|
nikseComboBoxUrl.Text.Contains("//127.", StringComparison.OrdinalIgnoreCase) ||
|
||||||
@ -1105,6 +1134,11 @@ namespace Nikse.SubtitleEdit.Forms.Translate
|
|||||||
Configuration.Settings.Tools.AutoTranslateDeepLApiKey = nikseTextBoxApiKey.Text.Trim();
|
Configuration.Settings.Tools.AutoTranslateDeepLApiKey = nikseTextBoxApiKey.Text.Trim();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (engineType == typeof(DeepLXTranslate) && !string.IsNullOrWhiteSpace(nikseTextBoxApiKey.Text))
|
||||||
|
{
|
||||||
|
Configuration.Settings.Tools.AutoTranslateDeepLXUrl = nikseComboBoxUrl.Text.Trim();
|
||||||
|
}
|
||||||
|
|
||||||
if (engineType == typeof(LibreTranslate) && nikseTextBoxApiKey.Visible && !string.IsNullOrWhiteSpace(nikseTextBoxApiKey.Text))
|
if (engineType == typeof(LibreTranslate) && nikseTextBoxApiKey.Visible && !string.IsNullOrWhiteSpace(nikseTextBoxApiKey.Text))
|
||||||
{
|
{
|
||||||
Configuration.Settings.Tools.AutoTranslateLibreApiKey = nikseTextBoxApiKey.Text.Trim();
|
Configuration.Settings.Tools.AutoTranslateLibreApiKey = nikseTextBoxApiKey.Text.Trim();
|
||||||
@ -1380,9 +1414,9 @@ namespace Nikse.SubtitleEdit.Forms.Translate
|
|||||||
|
|
||||||
private static void SyncListViews(ListView listViewSelected, SubtitleListView listViewOther)
|
private static void SyncListViews(ListView listViewSelected, SubtitleListView listViewOther)
|
||||||
{
|
{
|
||||||
if (listViewSelected == null ||
|
if (listViewSelected == null ||
|
||||||
listViewOther == null ||
|
listViewOther == null ||
|
||||||
listViewSelected.SelectedItems.Count == 0 ||
|
listViewSelected.SelectedItems.Count == 0 ||
|
||||||
listViewSelected.TopItem == null)
|
listViewSelected.TopItem == null)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
386
src/ui/Forms/Tts/TextToSpeech.Designer.cs
generated
386
src/ui/Forms/Tts/TextToSpeech.Designer.cs
generated
@ -36,29 +36,33 @@
|
|||||||
this.labelEngine = new System.Windows.Forms.Label();
|
this.labelEngine = new System.Windows.Forms.Label();
|
||||||
this.groupBoxSettings = new System.Windows.Forms.GroupBox();
|
this.groupBoxSettings = new System.Windows.Forms.GroupBox();
|
||||||
this.labelLanguage = new System.Windows.Forms.Label();
|
this.labelLanguage = new System.Windows.Forms.Label();
|
||||||
this.nikseComboBoxLanguage = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
|
||||||
this.linkLabelCustomAudio = new System.Windows.Forms.LinkLabel();
|
this.linkLabelCustomAudio = new System.Windows.Forms.LinkLabel();
|
||||||
this.checkBoxAudioEncoding = new System.Windows.Forms.CheckBox();
|
this.checkBoxAudioEncoding = new System.Windows.Forms.CheckBox();
|
||||||
this.labelRegion = new System.Windows.Forms.Label();
|
this.labelRegion = new System.Windows.Forms.Label();
|
||||||
this.nikseComboBoxRegion = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
|
||||||
this.labelVoiceCount = new System.Windows.Forms.Label();
|
this.labelVoiceCount = new System.Windows.Forms.Label();
|
||||||
this.checkBoxShowPreview = new System.Windows.Forms.CheckBox();
|
this.checkBoxShowPreview = new System.Windows.Forms.CheckBox();
|
||||||
this.labelApiKey = new System.Windows.Forms.Label();
|
this.labelApiKey = new System.Windows.Forms.Label();
|
||||||
this.nikseTextBoxApiKey = new Nikse.SubtitleEdit.Controls.NikseTextBox();
|
|
||||||
this.TextBoxTest = new Nikse.SubtitleEdit.Controls.NikseTextBox();
|
|
||||||
this.buttonTestVoice = new System.Windows.Forms.Button();
|
this.buttonTestVoice = new System.Windows.Forms.Button();
|
||||||
this.checkBoxAddToVideoFile = new System.Windows.Forms.CheckBox();
|
this.checkBoxAddToVideoFile = new System.Windows.Forms.CheckBox();
|
||||||
this.labelVoice = new System.Windows.Forms.Label();
|
this.labelVoice = new System.Windows.Forms.Label();
|
||||||
this.nikseComboBoxVoice = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
|
||||||
this.contextMenuStripVoices = new System.Windows.Forms.ContextMenuStrip(this.components);
|
this.contextMenuStripVoices = new System.Windows.Forms.ContextMenuStrip(this.components);
|
||||||
this.refreshVoicesToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
this.refreshVoicesToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||||
this.nikseComboBoxEngine = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
|
||||||
this.listViewActors = new System.Windows.Forms.ListView();
|
this.listViewActors = new System.Windows.Forms.ListView();
|
||||||
this.columnHeaderActor = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
|
this.columnHeaderActor = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
|
||||||
this.columnHeaderVoice = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
|
this.columnHeaderVoice = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
|
||||||
this.contextMenuStripActors = new System.Windows.Forms.ContextMenuStrip(this.components);
|
this.contextMenuStripActors = new System.Windows.Forms.ContextMenuStrip(this.components);
|
||||||
this.labelActors = new System.Windows.Forms.Label();
|
this.labelActors = new System.Windows.Forms.Label();
|
||||||
this.buttonCancel = new System.Windows.Forms.Button();
|
this.buttonCancel = new System.Windows.Forms.Button();
|
||||||
|
this.nikseUpDownStability = new Nikse.SubtitleEdit.Controls.NikseUpDown();
|
||||||
|
this.nikseUpDownSimilarity = new Nikse.SubtitleEdit.Controls.NikseUpDown();
|
||||||
|
this.labelSimilarity = new Nikse.SubtitleEdit.Controls.NikseLabel();
|
||||||
|
this.labelStability = new Nikse.SubtitleEdit.Controls.NikseLabel();
|
||||||
|
this.nikseComboBoxLanguage = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
||||||
|
this.nikseComboBoxRegion = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
||||||
|
this.nikseTextBoxApiKey = new Nikse.SubtitleEdit.Controls.NikseTextBox();
|
||||||
|
this.TextBoxTest = new Nikse.SubtitleEdit.Controls.NikseTextBox();
|
||||||
|
this.nikseComboBoxVoice = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
||||||
|
this.nikseComboBoxEngine = new Nikse.SubtitleEdit.Controls.NikseComboBox();
|
||||||
this.groupBoxSettings.SuspendLayout();
|
this.groupBoxSettings.SuspendLayout();
|
||||||
this.contextMenuStripVoices.SuspendLayout();
|
this.contextMenuStripVoices.SuspendLayout();
|
||||||
this.SuspendLayout();
|
this.SuspendLayout();
|
||||||
@ -121,6 +125,10 @@
|
|||||||
//
|
//
|
||||||
this.groupBoxSettings.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
|
this.groupBoxSettings.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
|
||||||
| System.Windows.Forms.AnchorStyles.Left)));
|
| System.Windows.Forms.AnchorStyles.Left)));
|
||||||
|
this.groupBoxSettings.Controls.Add(this.nikseUpDownStability);
|
||||||
|
this.groupBoxSettings.Controls.Add(this.nikseUpDownSimilarity);
|
||||||
|
this.groupBoxSettings.Controls.Add(this.labelSimilarity);
|
||||||
|
this.groupBoxSettings.Controls.Add(this.labelStability);
|
||||||
this.groupBoxSettings.Controls.Add(this.labelLanguage);
|
this.groupBoxSettings.Controls.Add(this.labelLanguage);
|
||||||
this.groupBoxSettings.Controls.Add(this.nikseComboBoxLanguage);
|
this.groupBoxSettings.Controls.Add(this.nikseComboBoxLanguage);
|
||||||
this.groupBoxSettings.Controls.Add(this.linkLabelCustomAudio);
|
this.groupBoxSettings.Controls.Add(this.linkLabelCustomAudio);
|
||||||
@ -155,39 +163,14 @@
|
|||||||
this.labelLanguage.TabIndex = 36;
|
this.labelLanguage.TabIndex = 36;
|
||||||
this.labelLanguage.Text = "Language";
|
this.labelLanguage.Text = "Language";
|
||||||
//
|
//
|
||||||
// nikseComboBoxLanguage
|
|
||||||
//
|
|
||||||
this.nikseComboBoxLanguage.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
|
||||||
this.nikseComboBoxLanguage.BackColor = System.Drawing.SystemColors.Window;
|
|
||||||
this.nikseComboBoxLanguage.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
|
||||||
this.nikseComboBoxLanguage.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
|
||||||
this.nikseComboBoxLanguage.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
|
||||||
this.nikseComboBoxLanguage.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
|
||||||
this.nikseComboBoxLanguage.ButtonForeColorDown = System.Drawing.Color.Orange;
|
|
||||||
this.nikseComboBoxLanguage.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
|
||||||
this.nikseComboBoxLanguage.DropDownHeight = 400;
|
|
||||||
this.nikseComboBoxLanguage.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
|
|
||||||
this.nikseComboBoxLanguage.DropDownWidth = 0;
|
|
||||||
this.nikseComboBoxLanguage.FormattingEnabled = false;
|
|
||||||
this.nikseComboBoxLanguage.Location = new System.Drawing.Point(102, 269);
|
|
||||||
this.nikseComboBoxLanguage.MaxLength = 32767;
|
|
||||||
this.nikseComboBoxLanguage.Name = "nikseComboBoxLanguage";
|
|
||||||
this.nikseComboBoxLanguage.SelectedIndex = -1;
|
|
||||||
this.nikseComboBoxLanguage.SelectedItem = null;
|
|
||||||
this.nikseComboBoxLanguage.SelectedText = "";
|
|
||||||
this.nikseComboBoxLanguage.Size = new System.Drawing.Size(266, 23);
|
|
||||||
this.nikseComboBoxLanguage.TabIndex = 35;
|
|
||||||
this.nikseComboBoxLanguage.UsePopupWindow = false;
|
|
||||||
//
|
|
||||||
// linkLabelCustomAudio
|
// linkLabelCustomAudio
|
||||||
//
|
//
|
||||||
this.linkLabelCustomAudio.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left)));
|
this.linkLabelCustomAudio.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left)));
|
||||||
this.linkLabelCustomAudio.AutoSize = true;
|
this.linkLabelCustomAudio.AutoSize = true;
|
||||||
this.linkLabelCustomAudio.Location = new System.Drawing.Point(169, 400);
|
this.linkLabelCustomAudio.Location = new System.Drawing.Point(168, 400);
|
||||||
this.linkLabelCustomAudio.Name = "linkLabelCustomAudio";
|
this.linkLabelCustomAudio.Name = "linkLabelCustomAudio";
|
||||||
this.linkLabelCustomAudio.Size = new System.Drawing.Size(45, 13);
|
this.linkLabelCustomAudio.Size = new System.Drawing.Size(45, 13);
|
||||||
this.linkLabelCustomAudio.TabIndex = 34;
|
this.linkLabelCustomAudio.TabIndex = 43;
|
||||||
this.linkLabelCustomAudio.TabStop = true;
|
this.linkLabelCustomAudio.TabStop = true;
|
||||||
this.linkLabelCustomAudio.Text = "Settings";
|
this.linkLabelCustomAudio.Text = "Settings";
|
||||||
this.linkLabelCustomAudio.LinkClicked += new System.Windows.Forms.LinkLabelLinkClickedEventHandler(this.linkLabelCustomAudio_LinkClicked);
|
this.linkLabelCustomAudio.LinkClicked += new System.Windows.Forms.LinkLabelLinkClickedEventHandler(this.linkLabelCustomAudio_LinkClicked);
|
||||||
@ -199,7 +182,7 @@
|
|||||||
this.checkBoxAudioEncoding.Location = new System.Drawing.Point(32, 401);
|
this.checkBoxAudioEncoding.Location = new System.Drawing.Point(32, 401);
|
||||||
this.checkBoxAudioEncoding.Name = "checkBoxAudioEncoding";
|
this.checkBoxAudioEncoding.Name = "checkBoxAudioEncoding";
|
||||||
this.checkBoxAudioEncoding.Size = new System.Drawing.Size(137, 17);
|
this.checkBoxAudioEncoding.Size = new System.Drawing.Size(137, 17);
|
||||||
this.checkBoxAudioEncoding.TabIndex = 33;
|
this.checkBoxAudioEncoding.TabIndex = 42;
|
||||||
this.checkBoxAudioEncoding.Text = "Custom audio encoding";
|
this.checkBoxAudioEncoding.Text = "Custom audio encoding";
|
||||||
this.checkBoxAudioEncoding.UseVisualStyleBackColor = true;
|
this.checkBoxAudioEncoding.UseVisualStyleBackColor = true;
|
||||||
//
|
//
|
||||||
@ -213,38 +196,12 @@
|
|||||||
this.labelRegion.TabIndex = 32;
|
this.labelRegion.TabIndex = 32;
|
||||||
this.labelRegion.Text = "Region";
|
this.labelRegion.Text = "Region";
|
||||||
//
|
//
|
||||||
// nikseComboBoxRegion
|
|
||||||
//
|
|
||||||
this.nikseComboBoxRegion.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
|
||||||
this.nikseComboBoxRegion.BackColor = System.Drawing.SystemColors.Window;
|
|
||||||
this.nikseComboBoxRegion.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
|
||||||
this.nikseComboBoxRegion.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
|
||||||
this.nikseComboBoxRegion.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
|
||||||
this.nikseComboBoxRegion.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
|
||||||
this.nikseComboBoxRegion.ButtonForeColorDown = System.Drawing.Color.Orange;
|
|
||||||
this.nikseComboBoxRegion.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
|
||||||
this.nikseComboBoxRegion.DropDownHeight = 400;
|
|
||||||
this.nikseComboBoxRegion.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
|
|
||||||
this.nikseComboBoxRegion.DropDownWidth = 0;
|
|
||||||
this.nikseComboBoxRegion.FormattingEnabled = false;
|
|
||||||
this.nikseComboBoxRegion.Location = new System.Drawing.Point(102, 240);
|
|
||||||
this.nikseComboBoxRegion.MaxLength = 32767;
|
|
||||||
this.nikseComboBoxRegion.Name = "nikseComboBoxRegion";
|
|
||||||
this.nikseComboBoxRegion.SelectedIndex = -1;
|
|
||||||
this.nikseComboBoxRegion.SelectedItem = null;
|
|
||||||
this.nikseComboBoxRegion.SelectedText = "";
|
|
||||||
this.nikseComboBoxRegion.Size = new System.Drawing.Size(266, 23);
|
|
||||||
this.nikseComboBoxRegion.TabIndex = 31;
|
|
||||||
this.nikseComboBoxRegion.UsePopupWindow = false;
|
|
||||||
this.nikseComboBoxRegion.SelectedIndexChanged += new System.EventHandler(this.nikseComboBoxRegion_SelectedIndexChanged);
|
|
||||||
//
|
|
||||||
// labelVoiceCount
|
// labelVoiceCount
|
||||||
//
|
//
|
||||||
this.labelVoiceCount.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
|
this.labelVoiceCount.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
|
||||||
this.labelVoiceCount.Location = new System.Drawing.Point(268, 83);
|
this.labelVoiceCount.Location = new System.Drawing.Point(172, 83);
|
||||||
this.labelVoiceCount.Name = "labelVoiceCount";
|
this.labelVoiceCount.Name = "labelVoiceCount";
|
||||||
this.labelVoiceCount.Size = new System.Drawing.Size(100, 23);
|
this.labelVoiceCount.Size = new System.Drawing.Size(196, 23);
|
||||||
this.labelVoiceCount.TabIndex = 29;
|
this.labelVoiceCount.TabIndex = 29;
|
||||||
this.labelVoiceCount.Text = "255";
|
this.labelVoiceCount.Text = "255";
|
||||||
this.labelVoiceCount.TextAlign = System.Drawing.ContentAlignment.BottomRight;
|
this.labelVoiceCount.TextAlign = System.Drawing.ContentAlignment.BottomRight;
|
||||||
@ -258,7 +215,7 @@
|
|||||||
this.checkBoxShowPreview.Location = new System.Drawing.Point(17, 352);
|
this.checkBoxShowPreview.Location = new System.Drawing.Point(17, 352);
|
||||||
this.checkBoxShowPreview.Name = "checkBoxShowPreview";
|
this.checkBoxShowPreview.Name = "checkBoxShowPreview";
|
||||||
this.checkBoxShowPreview.Size = new System.Drawing.Size(115, 17);
|
this.checkBoxShowPreview.Size = new System.Drawing.Size(115, 17);
|
||||||
this.checkBoxShowPreview.TabIndex = 25;
|
this.checkBoxShowPreview.TabIndex = 40;
|
||||||
this.checkBoxShowPreview.Text = "Review audio clips";
|
this.checkBoxShowPreview.Text = "Review audio clips";
|
||||||
this.checkBoxShowPreview.UseVisualStyleBackColor = true;
|
this.checkBoxShowPreview.UseVisualStyleBackColor = true;
|
||||||
//
|
//
|
||||||
@ -266,34 +223,12 @@
|
|||||||
//
|
//
|
||||||
this.labelApiKey.AutoSize = true;
|
this.labelApiKey.AutoSize = true;
|
||||||
this.labelApiKey.ImeMode = System.Windows.Forms.ImeMode.NoControl;
|
this.labelApiKey.ImeMode = System.Windows.Forms.ImeMode.NoControl;
|
||||||
this.labelApiKey.Location = new System.Drawing.Point(14, 217);
|
this.labelApiKey.Location = new System.Drawing.Point(14, 216);
|
||||||
this.labelApiKey.Name = "labelApiKey";
|
this.labelApiKey.Name = "labelApiKey";
|
||||||
this.labelApiKey.Size = new System.Drawing.Size(44, 13);
|
this.labelApiKey.Size = new System.Drawing.Size(44, 13);
|
||||||
this.labelApiKey.TabIndex = 28;
|
this.labelApiKey.TabIndex = 28;
|
||||||
this.labelApiKey.Text = "API key";
|
this.labelApiKey.Text = "API key";
|
||||||
//
|
//
|
||||||
// nikseTextBoxApiKey
|
|
||||||
//
|
|
||||||
this.nikseTextBoxApiKey.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
|
||||||
this.nikseTextBoxApiKey.FocusedColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
|
||||||
this.nikseTextBoxApiKey.Location = new System.Drawing.Point(102, 214);
|
|
||||||
this.nikseTextBoxApiKey.Name = "nikseTextBoxApiKey";
|
|
||||||
this.nikseTextBoxApiKey.Size = new System.Drawing.Size(266, 20);
|
|
||||||
this.nikseTextBoxApiKey.TabIndex = 27;
|
|
||||||
//
|
|
||||||
// TextBoxTest
|
|
||||||
//
|
|
||||||
this.TextBoxTest.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
|
||||||
this.TextBoxTest.FocusedColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
|
||||||
this.TextBoxTest.Location = new System.Drawing.Point(17, 172);
|
|
||||||
this.TextBoxTest.Name = "TextBoxTest";
|
|
||||||
this.TextBoxTest.Size = new System.Drawing.Size(351, 20);
|
|
||||||
this.TextBoxTest.TabIndex = 20;
|
|
||||||
this.TextBoxTest.Text = "Hello, how are you?";
|
|
||||||
this.TextBoxTest.KeyDown += new System.Windows.Forms.KeyEventHandler(this.TextBoxTest_KeyDown);
|
|
||||||
//
|
|
||||||
// buttonTestVoice
|
// buttonTestVoice
|
||||||
//
|
//
|
||||||
this.buttonTestVoice.Location = new System.Drawing.Point(17, 141);
|
this.buttonTestVoice.Location = new System.Drawing.Point(17, 141);
|
||||||
@ -313,7 +248,7 @@
|
|||||||
this.checkBoxAddToVideoFile.Location = new System.Drawing.Point(17, 376);
|
this.checkBoxAddToVideoFile.Location = new System.Drawing.Point(17, 376);
|
||||||
this.checkBoxAddToVideoFile.Name = "checkBoxAddToVideoFile";
|
this.checkBoxAddToVideoFile.Name = "checkBoxAddToVideoFile";
|
||||||
this.checkBoxAddToVideoFile.Size = new System.Drawing.Size(176, 17);
|
this.checkBoxAddToVideoFile.Size = new System.Drawing.Size(176, 17);
|
||||||
this.checkBoxAddToVideoFile.TabIndex = 26;
|
this.checkBoxAddToVideoFile.TabIndex = 41;
|
||||||
this.checkBoxAddToVideoFile.Text = "Add audio to video file (new file)";
|
this.checkBoxAddToVideoFile.Text = "Add audio to video file (new file)";
|
||||||
this.checkBoxAddToVideoFile.UseVisualStyleBackColor = true;
|
this.checkBoxAddToVideoFile.UseVisualStyleBackColor = true;
|
||||||
//
|
//
|
||||||
@ -327,32 +262,6 @@
|
|||||||
this.labelVoice.TabIndex = 16;
|
this.labelVoice.TabIndex = 16;
|
||||||
this.labelVoice.Text = "Voice";
|
this.labelVoice.Text = "Voice";
|
||||||
//
|
//
|
||||||
// nikseComboBoxVoice
|
|
||||||
//
|
|
||||||
this.nikseComboBoxVoice.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
|
||||||
this.nikseComboBoxVoice.BackColor = System.Drawing.SystemColors.Window;
|
|
||||||
this.nikseComboBoxVoice.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
|
||||||
this.nikseComboBoxVoice.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
|
||||||
this.nikseComboBoxVoice.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
|
||||||
this.nikseComboBoxVoice.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
|
||||||
this.nikseComboBoxVoice.ButtonForeColorDown = System.Drawing.Color.Orange;
|
|
||||||
this.nikseComboBoxVoice.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
|
||||||
this.nikseComboBoxVoice.ContextMenuStrip = this.contextMenuStripVoices;
|
|
||||||
this.nikseComboBoxVoice.DropDownHeight = 400;
|
|
||||||
this.nikseComboBoxVoice.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
|
|
||||||
this.nikseComboBoxVoice.DropDownWidth = 0;
|
|
||||||
this.nikseComboBoxVoice.FormattingEnabled = false;
|
|
||||||
this.nikseComboBoxVoice.Location = new System.Drawing.Point(17, 110);
|
|
||||||
this.nikseComboBoxVoice.MaxLength = 32767;
|
|
||||||
this.nikseComboBoxVoice.Name = "nikseComboBoxVoice";
|
|
||||||
this.nikseComboBoxVoice.SelectedIndex = -1;
|
|
||||||
this.nikseComboBoxVoice.SelectedItem = null;
|
|
||||||
this.nikseComboBoxVoice.SelectedText = "";
|
|
||||||
this.nikseComboBoxVoice.Size = new System.Drawing.Size(351, 23);
|
|
||||||
this.nikseComboBoxVoice.TabIndex = 10;
|
|
||||||
this.nikseComboBoxVoice.UsePopupWindow = false;
|
|
||||||
//
|
|
||||||
// contextMenuStripVoices
|
// contextMenuStripVoices
|
||||||
//
|
//
|
||||||
this.contextMenuStripVoices.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {
|
this.contextMenuStripVoices.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {
|
||||||
@ -368,33 +277,6 @@
|
|||||||
this.refreshVoicesToolStripMenuItem.Text = "Refresh voices";
|
this.refreshVoicesToolStripMenuItem.Text = "Refresh voices";
|
||||||
this.refreshVoicesToolStripMenuItem.Click += new System.EventHandler(this.refreshVoicesToolStripMenuItem_Click);
|
this.refreshVoicesToolStripMenuItem.Click += new System.EventHandler(this.refreshVoicesToolStripMenuItem_Click);
|
||||||
//
|
//
|
||||||
// nikseComboBoxEngine
|
|
||||||
//
|
|
||||||
this.nikseComboBoxEngine.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
|
||||||
this.nikseComboBoxEngine.BackColor = System.Drawing.SystemColors.Window;
|
|
||||||
this.nikseComboBoxEngine.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
|
||||||
this.nikseComboBoxEngine.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
|
||||||
this.nikseComboBoxEngine.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
|
||||||
this.nikseComboBoxEngine.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
|
||||||
this.nikseComboBoxEngine.ButtonForeColorDown = System.Drawing.Color.Orange;
|
|
||||||
this.nikseComboBoxEngine.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
|
||||||
this.nikseComboBoxEngine.DropDownHeight = 400;
|
|
||||||
this.nikseComboBoxEngine.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDown;
|
|
||||||
this.nikseComboBoxEngine.DropDownWidth = 391;
|
|
||||||
this.nikseComboBoxEngine.FormattingEnabled = false;
|
|
||||||
this.nikseComboBoxEngine.Location = new System.Drawing.Point(17, 40);
|
|
||||||
this.nikseComboBoxEngine.MaxLength = 32767;
|
|
||||||
this.nikseComboBoxEngine.Name = "nikseComboBoxEngine";
|
|
||||||
this.nikseComboBoxEngine.SelectedIndex = -1;
|
|
||||||
this.nikseComboBoxEngine.SelectedItem = null;
|
|
||||||
this.nikseComboBoxEngine.SelectedText = "";
|
|
||||||
this.nikseComboBoxEngine.Size = new System.Drawing.Size(351, 23);
|
|
||||||
this.nikseComboBoxEngine.TabIndex = 5;
|
|
||||||
this.nikseComboBoxEngine.TabStop = false;
|
|
||||||
this.nikseComboBoxEngine.Text = "nikseComboBox1";
|
|
||||||
this.nikseComboBoxEngine.UsePopupWindow = false;
|
|
||||||
//
|
|
||||||
// listViewActors
|
// listViewActors
|
||||||
//
|
//
|
||||||
this.listViewActors.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
|
this.listViewActors.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
|
||||||
@ -452,6 +334,226 @@
|
|||||||
this.buttonCancel.UseVisualStyleBackColor = true;
|
this.buttonCancel.UseVisualStyleBackColor = true;
|
||||||
this.buttonCancel.Click += new System.EventHandler(this.buttonCancel_Click);
|
this.buttonCancel.Click += new System.EventHandler(this.buttonCancel_Click);
|
||||||
//
|
//
|
||||||
|
// nikseUpDownStability
|
||||||
|
//
|
||||||
|
this.nikseUpDownStability.BackColor = System.Drawing.SystemColors.Window;
|
||||||
|
this.nikseUpDownStability.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
||||||
|
this.nikseUpDownStability.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
||||||
|
this.nikseUpDownStability.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
||||||
|
this.nikseUpDownStability.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
||||||
|
this.nikseUpDownStability.ButtonForeColorDown = System.Drawing.Color.Orange;
|
||||||
|
this.nikseUpDownStability.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.nikseUpDownStability.DecimalPlaces = 0;
|
||||||
|
this.nikseUpDownStability.Increment = new decimal(new int[] {
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.nikseUpDownStability.Location = new System.Drawing.Point(102, 270);
|
||||||
|
this.nikseUpDownStability.Maximum = new decimal(new int[] {
|
||||||
|
100,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.nikseUpDownStability.Minimum = new decimal(new int[] {
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.nikseUpDownStability.Name = "nikseUpDownStability";
|
||||||
|
this.nikseUpDownStability.Size = new System.Drawing.Size(75, 23);
|
||||||
|
this.nikseUpDownStability.TabIndex = 34;
|
||||||
|
this.nikseUpDownStability.TabStop = false;
|
||||||
|
this.nikseUpDownStability.Text = "nikseUpDownStability";
|
||||||
|
this.nikseUpDownStability.ThousandsSeparator = false;
|
||||||
|
this.nikseUpDownStability.Value = new decimal(new int[] {
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
//
|
||||||
|
// nikseUpDownSimilarity
|
||||||
|
//
|
||||||
|
this.nikseUpDownSimilarity.BackColor = System.Drawing.SystemColors.Window;
|
||||||
|
this.nikseUpDownSimilarity.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
||||||
|
this.nikseUpDownSimilarity.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
||||||
|
this.nikseUpDownSimilarity.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
||||||
|
this.nikseUpDownSimilarity.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
||||||
|
this.nikseUpDownSimilarity.ButtonForeColorDown = System.Drawing.Color.Orange;
|
||||||
|
this.nikseUpDownSimilarity.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.nikseUpDownSimilarity.DecimalPlaces = 0;
|
||||||
|
this.nikseUpDownSimilarity.Increment = new decimal(new int[] {
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.nikseUpDownSimilarity.Location = new System.Drawing.Point(102, 299);
|
||||||
|
this.nikseUpDownSimilarity.Maximum = new decimal(new int[] {
|
||||||
|
100,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.nikseUpDownSimilarity.Minimum = new decimal(new int[] {
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.nikseUpDownSimilarity.Name = "nikseUpDownSimilarity";
|
||||||
|
this.nikseUpDownSimilarity.Size = new System.Drawing.Size(75, 23);
|
||||||
|
this.nikseUpDownSimilarity.TabIndex = 35;
|
||||||
|
this.nikseUpDownSimilarity.TabStop = false;
|
||||||
|
this.nikseUpDownSimilarity.Text = "nikseUpDownSimilarity";
|
||||||
|
this.nikseUpDownSimilarity.ThousandsSeparator = false;
|
||||||
|
this.nikseUpDownSimilarity.Value = new decimal(new int[] {
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
//
|
||||||
|
// labelSimilarity
|
||||||
|
//
|
||||||
|
this.labelSimilarity.AutoSize = true;
|
||||||
|
this.labelSimilarity.Location = new System.Drawing.Point(14, 305);
|
||||||
|
this.labelSimilarity.Name = "labelSimilarity";
|
||||||
|
this.labelSimilarity.Size = new System.Drawing.Size(47, 13);
|
||||||
|
this.labelSimilarity.TabIndex = 99;
|
||||||
|
this.labelSimilarity.Text = "Similarity";
|
||||||
|
//
|
||||||
|
// labelStability
|
||||||
|
//
|
||||||
|
this.labelStability.AutoSize = true;
|
||||||
|
this.labelStability.Location = new System.Drawing.Point(15, 274);
|
||||||
|
this.labelStability.Name = "labelStability";
|
||||||
|
this.labelStability.Size = new System.Drawing.Size(43, 13);
|
||||||
|
this.labelStability.TabIndex = 97;
|
||||||
|
this.labelStability.Text = "Stability";
|
||||||
|
//
|
||||||
|
// nikseComboBoxLanguage
|
||||||
|
//
|
||||||
|
this.nikseComboBoxLanguage.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
||||||
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.nikseComboBoxLanguage.BackColor = System.Drawing.SystemColors.Window;
|
||||||
|
this.nikseComboBoxLanguage.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
||||||
|
this.nikseComboBoxLanguage.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
||||||
|
this.nikseComboBoxLanguage.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
||||||
|
this.nikseComboBoxLanguage.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
||||||
|
this.nikseComboBoxLanguage.ButtonForeColorDown = System.Drawing.Color.Orange;
|
||||||
|
this.nikseComboBoxLanguage.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.nikseComboBoxLanguage.DropDownHeight = 400;
|
||||||
|
this.nikseComboBoxLanguage.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
|
||||||
|
this.nikseComboBoxLanguage.DropDownWidth = 0;
|
||||||
|
this.nikseComboBoxLanguage.FormattingEnabled = false;
|
||||||
|
this.nikseComboBoxLanguage.Location = new System.Drawing.Point(102, 269);
|
||||||
|
this.nikseComboBoxLanguage.MaxLength = 32767;
|
||||||
|
this.nikseComboBoxLanguage.Name = "nikseComboBoxLanguage";
|
||||||
|
this.nikseComboBoxLanguage.SelectedIndex = -1;
|
||||||
|
this.nikseComboBoxLanguage.SelectedItem = null;
|
||||||
|
this.nikseComboBoxLanguage.SelectedText = "";
|
||||||
|
this.nikseComboBoxLanguage.Size = new System.Drawing.Size(266, 23);
|
||||||
|
this.nikseComboBoxLanguage.TabIndex = 35;
|
||||||
|
this.nikseComboBoxLanguage.UsePopupWindow = false;
|
||||||
|
//
|
||||||
|
// nikseComboBoxRegion
|
||||||
|
//
|
||||||
|
this.nikseComboBoxRegion.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
||||||
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.nikseComboBoxRegion.BackColor = System.Drawing.SystemColors.Window;
|
||||||
|
this.nikseComboBoxRegion.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
||||||
|
this.nikseComboBoxRegion.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
||||||
|
this.nikseComboBoxRegion.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
||||||
|
this.nikseComboBoxRegion.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
||||||
|
this.nikseComboBoxRegion.ButtonForeColorDown = System.Drawing.Color.Orange;
|
||||||
|
this.nikseComboBoxRegion.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.nikseComboBoxRegion.DropDownHeight = 400;
|
||||||
|
this.nikseComboBoxRegion.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
|
||||||
|
this.nikseComboBoxRegion.DropDownWidth = 0;
|
||||||
|
this.nikseComboBoxRegion.FormattingEnabled = false;
|
||||||
|
this.nikseComboBoxRegion.Location = new System.Drawing.Point(102, 240);
|
||||||
|
this.nikseComboBoxRegion.MaxLength = 32767;
|
||||||
|
this.nikseComboBoxRegion.Name = "nikseComboBoxRegion";
|
||||||
|
this.nikseComboBoxRegion.SelectedIndex = -1;
|
||||||
|
this.nikseComboBoxRegion.SelectedItem = null;
|
||||||
|
this.nikseComboBoxRegion.SelectedText = "";
|
||||||
|
this.nikseComboBoxRegion.Size = new System.Drawing.Size(266, 23);
|
||||||
|
this.nikseComboBoxRegion.TabIndex = 31;
|
||||||
|
this.nikseComboBoxRegion.UsePopupWindow = false;
|
||||||
|
this.nikseComboBoxRegion.SelectedIndexChanged += new System.EventHandler(this.nikseComboBoxRegion_SelectedIndexChanged);
|
||||||
|
//
|
||||||
|
// nikseTextBoxApiKey
|
||||||
|
//
|
||||||
|
this.nikseTextBoxApiKey.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
||||||
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.nikseTextBoxApiKey.FocusedColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.nikseTextBoxApiKey.Location = new System.Drawing.Point(102, 213);
|
||||||
|
this.nikseTextBoxApiKey.Name = "nikseTextBoxApiKey";
|
||||||
|
this.nikseTextBoxApiKey.Size = new System.Drawing.Size(266, 20);
|
||||||
|
this.nikseTextBoxApiKey.TabIndex = 27;
|
||||||
|
//
|
||||||
|
// TextBoxTest
|
||||||
|
//
|
||||||
|
this.TextBoxTest.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
||||||
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.TextBoxTest.FocusedColor = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.TextBoxTest.Location = new System.Drawing.Point(17, 172);
|
||||||
|
this.TextBoxTest.Name = "TextBoxTest";
|
||||||
|
this.TextBoxTest.Size = new System.Drawing.Size(351, 20);
|
||||||
|
this.TextBoxTest.TabIndex = 20;
|
||||||
|
this.TextBoxTest.Text = "Hello, how are you?";
|
||||||
|
this.TextBoxTest.KeyDown += new System.Windows.Forms.KeyEventHandler(this.TextBoxTest_KeyDown);
|
||||||
|
//
|
||||||
|
// nikseComboBoxVoice
|
||||||
|
//
|
||||||
|
this.nikseComboBoxVoice.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
||||||
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.nikseComboBoxVoice.BackColor = System.Drawing.SystemColors.Window;
|
||||||
|
this.nikseComboBoxVoice.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
||||||
|
this.nikseComboBoxVoice.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
||||||
|
this.nikseComboBoxVoice.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
||||||
|
this.nikseComboBoxVoice.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
||||||
|
this.nikseComboBoxVoice.ButtonForeColorDown = System.Drawing.Color.Orange;
|
||||||
|
this.nikseComboBoxVoice.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.nikseComboBoxVoice.ContextMenuStrip = this.contextMenuStripVoices;
|
||||||
|
this.nikseComboBoxVoice.DropDownHeight = 400;
|
||||||
|
this.nikseComboBoxVoice.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
|
||||||
|
this.nikseComboBoxVoice.DropDownWidth = 0;
|
||||||
|
this.nikseComboBoxVoice.FormattingEnabled = false;
|
||||||
|
this.nikseComboBoxVoice.Location = new System.Drawing.Point(17, 110);
|
||||||
|
this.nikseComboBoxVoice.MaxLength = 32767;
|
||||||
|
this.nikseComboBoxVoice.Name = "nikseComboBoxVoice";
|
||||||
|
this.nikseComboBoxVoice.SelectedIndex = -1;
|
||||||
|
this.nikseComboBoxVoice.SelectedItem = null;
|
||||||
|
this.nikseComboBoxVoice.SelectedText = "";
|
||||||
|
this.nikseComboBoxVoice.Size = new System.Drawing.Size(351, 23);
|
||||||
|
this.nikseComboBoxVoice.TabIndex = 10;
|
||||||
|
this.nikseComboBoxVoice.UsePopupWindow = false;
|
||||||
|
//
|
||||||
|
// nikseComboBoxEngine
|
||||||
|
//
|
||||||
|
this.nikseComboBoxEngine.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left)
|
||||||
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.nikseComboBoxEngine.BackColor = System.Drawing.SystemColors.Window;
|
||||||
|
this.nikseComboBoxEngine.BackColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(240)))), ((int)(((byte)(240)))), ((int)(((byte)(240)))));
|
||||||
|
this.nikseComboBoxEngine.BorderColor = System.Drawing.Color.FromArgb(((int)(((byte)(171)))), ((int)(((byte)(173)))), ((int)(((byte)(179)))));
|
||||||
|
this.nikseComboBoxEngine.BorderColorDisabled = System.Drawing.Color.FromArgb(((int)(((byte)(120)))), ((int)(((byte)(120)))), ((int)(((byte)(120)))));
|
||||||
|
this.nikseComboBoxEngine.ButtonForeColor = System.Drawing.SystemColors.ControlText;
|
||||||
|
this.nikseComboBoxEngine.ButtonForeColorDown = System.Drawing.Color.Orange;
|
||||||
|
this.nikseComboBoxEngine.ButtonForeColorOver = System.Drawing.Color.FromArgb(((int)(((byte)(0)))), ((int)(((byte)(120)))), ((int)(((byte)(215)))));
|
||||||
|
this.nikseComboBoxEngine.DropDownHeight = 400;
|
||||||
|
this.nikseComboBoxEngine.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDown;
|
||||||
|
this.nikseComboBoxEngine.DropDownWidth = 391;
|
||||||
|
this.nikseComboBoxEngine.FormattingEnabled = false;
|
||||||
|
this.nikseComboBoxEngine.Location = new System.Drawing.Point(17, 40);
|
||||||
|
this.nikseComboBoxEngine.MaxLength = 32767;
|
||||||
|
this.nikseComboBoxEngine.Name = "nikseComboBoxEngine";
|
||||||
|
this.nikseComboBoxEngine.SelectedIndex = -1;
|
||||||
|
this.nikseComboBoxEngine.SelectedItem = null;
|
||||||
|
this.nikseComboBoxEngine.SelectedText = "";
|
||||||
|
this.nikseComboBoxEngine.Size = new System.Drawing.Size(351, 23);
|
||||||
|
this.nikseComboBoxEngine.TabIndex = 5;
|
||||||
|
this.nikseComboBoxEngine.TabStop = false;
|
||||||
|
this.nikseComboBoxEngine.Text = "nikseComboBox1";
|
||||||
|
this.nikseComboBoxEngine.UsePopupWindow = false;
|
||||||
|
//
|
||||||
// TextToSpeech
|
// TextToSpeech
|
||||||
//
|
//
|
||||||
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
||||||
@ -517,5 +619,9 @@
|
|||||||
private System.Windows.Forms.LinkLabel linkLabelCustomAudio;
|
private System.Windows.Forms.LinkLabel linkLabelCustomAudio;
|
||||||
private System.Windows.Forms.Label labelLanguage;
|
private System.Windows.Forms.Label labelLanguage;
|
||||||
private Controls.NikseComboBox nikseComboBoxLanguage;
|
private Controls.NikseComboBox nikseComboBoxLanguage;
|
||||||
|
private Controls.NikseUpDown nikseUpDownStability;
|
||||||
|
private Controls.NikseUpDown nikseUpDownSimilarity;
|
||||||
|
private Controls.NikseLabel labelSimilarity;
|
||||||
|
private Controls.NikseLabel labelStability;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -125,7 +125,9 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
checkBoxShowPreview.Text = LanguageSettings.Current.TextToSpeech.ReviewAudioClips;
|
checkBoxShowPreview.Text = LanguageSettings.Current.TextToSpeech.ReviewAudioClips;
|
||||||
checkBoxAudioEncoding.Text = LanguageSettings.Current.TextToSpeech.CustomAudioEncoding;
|
checkBoxAudioEncoding.Text = LanguageSettings.Current.TextToSpeech.CustomAudioEncoding;
|
||||||
linkLabelCustomAudio.Text = LanguageSettings.Current.Settings.Title;
|
linkLabelCustomAudio.Text = LanguageSettings.Current.Settings.Title;
|
||||||
linkLabelCustomAudio.Left = checkBoxAudioEncoding.Right + 3;
|
linkLabelCustomAudio.Left = checkBoxAudioEncoding.Right;
|
||||||
|
labelStability.Text = LanguageSettings.Current.TextToSpeech.Stability;
|
||||||
|
labelSimilarity.Text = LanguageSettings.Current.TextToSpeech.Similarity;
|
||||||
buttonOK.Text = LanguageSettings.Current.General.Ok;
|
buttonOK.Text = LanguageSettings.Current.General.Ok;
|
||||||
buttonCancel.Text = LanguageSettings.Current.General.Cancel;
|
buttonCancel.Text = LanguageSettings.Current.General.Cancel;
|
||||||
UiUtil.FixLargeFonts(this, buttonOK);
|
UiUtil.FixLargeFonts(this, buttonOK);
|
||||||
@ -186,6 +188,8 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
checkBoxShowPreview.Checked = Configuration.Settings.Tools.TextToSpeechPreview;
|
checkBoxShowPreview.Checked = Configuration.Settings.Tools.TextToSpeechPreview;
|
||||||
checkBoxAudioEncoding.Checked = Configuration.Settings.Tools.TextToSpeechCustomAudio;
|
checkBoxAudioEncoding.Checked = Configuration.Settings.Tools.TextToSpeechCustomAudio;
|
||||||
checkBoxAddToVideoFile.Enabled = _videoFileName != null;
|
checkBoxAddToVideoFile.Enabled = _videoFileName != null;
|
||||||
|
nikseUpDownStability.Value = (int)Math.Round(Configuration.Settings.Tools.TextToSpeechElevenLabsStability * 100.0);
|
||||||
|
nikseUpDownSimilarity.Value = (int)Math.Round(Configuration.Settings.Tools.TextToSpeechElevenLabsSimilarity * 100.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetActor(ActorAndVoice actor)
|
private void SetActor(ActorAndVoice actor)
|
||||||
@ -220,6 +224,8 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
|
|
||||||
private void ButtonGenerateTtsClick(object sender, EventArgs e)
|
private void ButtonGenerateTtsClick(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
|
SaveConfiguration();
|
||||||
|
|
||||||
if (buttonGenerateTTS.Text == LanguageSettings.Current.General.Cancel)
|
if (buttonGenerateTTS.Text == LanguageSettings.Current.General.Cancel)
|
||||||
{
|
{
|
||||||
buttonGenerateTTS.Enabled = false;
|
buttonGenerateTTS.Enabled = false;
|
||||||
@ -319,7 +325,7 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
}
|
}
|
||||||
catch (Exception exception)
|
catch (Exception exception)
|
||||||
{
|
{
|
||||||
MessageBox.Show("Ups: " + exception.Message + Environment.NewLine + exception.Message);
|
MessageBox.Show("Oops: " + exception.Message + Environment.NewLine + exception.Message);
|
||||||
SeLogger.Error(exception, $"{Text}: Error running engine {nikseComboBoxEngine.Text} with video {_videoFileName}");
|
SeLogger.Error(exception, $"{Text}: Error running engine {nikseComboBoxEngine.Text} with video {_videoFileName}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1131,7 +1137,9 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var data = "{ \"text\": \"" + Json.EncodeJsonText(text) + $"\", \"model_id\": \"{model}\"{language}, \"voice_settings\": {{ \"stability\": 0.8, \"similarity_boost\": 1.0 }} }}";
|
var stability = Math.Round(Configuration.Settings.Tools.TextToSpeechElevenLabsStability, 1).ToString(CultureInfo.InvariantCulture);
|
||||||
|
var similarity = Math.Round(Configuration.Settings.Tools.TextToSpeechElevenLabsSimilarity, 1).ToString(CultureInfo.InvariantCulture);
|
||||||
|
var data = "{ \"text\": \"" + Json.EncodeJsonText(text) + $"\", \"model_id\": \"{model}\"{language}, \"voice_settings\": {{ \"stability\": {stability}, \"similarity_boost\": {similarity} }} }}";
|
||||||
var content = new StringContent(data, Encoding.UTF8);
|
var content = new StringContent(data, Encoding.UTF8);
|
||||||
content.Headers.ContentType = MediaTypeHeaderValue.Parse("application/json");
|
content.Headers.ContentType = MediaTypeHeaderValue.Parse("application/json");
|
||||||
var result = httpClient.PostAsync(url, content, CancellationToken.None).Result;
|
var result = httpClient.PostAsync(url, content, CancellationToken.None).Result;
|
||||||
@ -1360,6 +1368,11 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
labelLanguage.Visible = false;
|
labelLanguage.Visible = false;
|
||||||
nikseComboBoxLanguage.Visible = false;
|
nikseComboBoxLanguage.Visible = false;
|
||||||
|
|
||||||
|
labelStability.Visible = false;
|
||||||
|
labelSimilarity.Visible = false;
|
||||||
|
nikseUpDownStability.Visible = false;
|
||||||
|
nikseUpDownSimilarity.Visible = false;
|
||||||
|
|
||||||
labelRegion.Text = LanguageSettings.Current.General.Region;
|
labelRegion.Text = LanguageSettings.Current.General.Region;
|
||||||
labelVoice.Text = LanguageSettings.Current.TextToSpeech.Voice;
|
labelVoice.Text = LanguageSettings.Current.TextToSpeech.Voice;
|
||||||
if (SubtitleFormatHasActors() && _actors.Any())
|
if (SubtitleFormatHasActors() && _actors.Any())
|
||||||
@ -1485,6 +1498,11 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
}
|
}
|
||||||
|
|
||||||
nikseComboBoxRegion.Visible = true;
|
nikseComboBoxRegion.Visible = true;
|
||||||
|
|
||||||
|
labelStability.Visible = true;
|
||||||
|
labelSimilarity.Visible = true;
|
||||||
|
nikseUpDownStability.Visible = true;
|
||||||
|
nikseUpDownSimilarity.Visible = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (engine.Id == TextToSpeechEngineId.AzureTextToSpeech)
|
if (engine.Id == TextToSpeechEngineId.AzureTextToSpeech)
|
||||||
@ -1890,15 +1908,15 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
Directory.CreateDirectory(ttsPath);
|
Directory.CreateDirectory(ttsPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
var elevenLabsPath = Path.Combine(ttsPath, "Piper");
|
var piperPath = Path.Combine(ttsPath, "Piper");
|
||||||
if (!Directory.Exists(elevenLabsPath))
|
if (!Directory.Exists(piperPath))
|
||||||
{
|
{
|
||||||
Directory.CreateDirectory(elevenLabsPath);
|
Directory.CreateDirectory(piperPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
var result = new List<PiperModel>();
|
var result = new List<PiperModel>();
|
||||||
|
|
||||||
var jsonFileName = Path.Combine(elevenLabsPath, "voices.json");
|
var jsonFileName = Path.Combine(piperPath, "voices.json");
|
||||||
|
|
||||||
if (!File.Exists(jsonFileName))
|
if (!File.Exists(jsonFileName))
|
||||||
{
|
{
|
||||||
@ -1915,7 +1933,7 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
if (!string.IsNullOrEmpty(fileName))
|
if (!string.IsNullOrEmpty(fileName))
|
||||||
{
|
{
|
||||||
var name = entry.FilenameInZip;
|
var name = entry.FilenameInZip;
|
||||||
var path = Path.Combine(elevenLabsPath, name.Replace('/', Path.DirectorySeparatorChar));
|
var path = Path.Combine(piperPath, name.Replace('/', Path.DirectorySeparatorChar));
|
||||||
zip.ExtractFile(entry, path);
|
zip.ExtractFile(entry, path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2214,6 +2232,8 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
|
|
||||||
private void buttonTestVoice_Click(object sender, EventArgs e)
|
private void buttonTestVoice_Click(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
|
SaveConfiguration();
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (string.IsNullOrWhiteSpace(TextBoxTest.Text))
|
if (string.IsNullOrWhiteSpace(TextBoxTest.Text))
|
||||||
@ -2230,7 +2250,7 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
var ok = GenerateParagraphAudio(sub, false, waveFileNameOnly);
|
var ok = GenerateParagraphAudio(sub, false, waveFileNameOnly);
|
||||||
if (!ok)
|
if (!ok)
|
||||||
{
|
{
|
||||||
MessageBox.Show(this, "Ups, voice generation failed!");
|
MessageBox.Show(this, "Oops, voice generation failed!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2266,6 +2286,12 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void SaveConfiguration()
|
||||||
|
{
|
||||||
|
Configuration.Settings.Tools.TextToSpeechElevenLabsStability = (double)nikseUpDownStability.Value / 100.0;
|
||||||
|
Configuration.Settings.Tools.TextToSpeechElevenLabsSimilarity = (double)nikseUpDownSimilarity.Value / 100.0;
|
||||||
|
}
|
||||||
|
|
||||||
private void HandleError(Exception ex)
|
private void HandleError(Exception ex)
|
||||||
{
|
{
|
||||||
var engine = _engines.First(p => p.Index == nikseComboBoxEngine.SelectedIndex);
|
var engine = _engines.First(p => p.Index == nikseComboBoxEngine.SelectedIndex);
|
||||||
@ -2282,6 +2308,8 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
{
|
{
|
||||||
var engine = _engines.First(p => p.Index == nikseComboBoxEngine.SelectedIndex);
|
var engine = _engines.First(p => p.Index == nikseComboBoxEngine.SelectedIndex);
|
||||||
|
|
||||||
|
SaveConfiguration();
|
||||||
|
|
||||||
if (engine.Id == TextToSpeechEngineId.ElevenLabs)
|
if (engine.Id == TextToSpeechEngineId.ElevenLabs)
|
||||||
{
|
{
|
||||||
Configuration.Settings.Tools.TextToSpeechElevenLabsApiKey = nikseTextBoxApiKey.Text;
|
Configuration.Settings.Tools.TextToSpeechElevenLabsApiKey = nikseTextBoxApiKey.Text;
|
||||||
@ -2403,6 +2431,7 @@ namespace Nikse.SubtitleEdit.Forms.Tts
|
|||||||
}
|
}
|
||||||
else if (engine.Id == TextToSpeechEngineId.ElevenLabs)
|
else if (engine.Id == TextToSpeechEngineId.ElevenLabs)
|
||||||
{
|
{
|
||||||
|
_elevenLabVoices.Clear();
|
||||||
GetElevenLabVoices(false);
|
GetElevenLabVoices(false);
|
||||||
nikseComboBoxEngine_SelectedIndexChanged(null, null);
|
nikseComboBoxEngine_SelectedIndexChanged(null, null);
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<General>
|
<General>
|
||||||
<Title>Subtitle Edit</Title>
|
<Title>Subtitle Edit</Title>
|
||||||
<Version>4.0.8</Version>
|
<Version>4.0.8</Version>
|
||||||
<TranslatedBy>Tradotto da NAMP e bovirus - Data traduzione: 09.09.2024</TranslatedBy>
|
<TranslatedBy>Tradotto da NAMP e bovirus - Data traduzione: 23.10.2024</TranslatedBy>
|
||||||
<CultureName>it-IT</CultureName>
|
<CultureName>it-IT</CultureName>
|
||||||
<HelpFile />
|
<HelpFile />
|
||||||
<Ok>OK</Ok>
|
<Ok>OK</Ok>
|
||||||
@ -3188,6 +3188,8 @@ Vuoi continuare?</RestoreDefaultSettingsMsg>
|
|||||||
<AutoContinue>Continua automaticamente</AutoContinue>
|
<AutoContinue>Continua automaticamente</AutoContinue>
|
||||||
<Regenerate>Rigenera</Regenerate>
|
<Regenerate>Rigenera</Regenerate>
|
||||||
<Speed>Velocità</Speed>
|
<Speed>Velocità</Speed>
|
||||||
|
<Stability>Stabilità</Stability>
|
||||||
|
<Similarity>Somiglianza</Similarity>
|
||||||
</TextToSpeech>
|
</TextToSpeech>
|
||||||
<TimedTextSmpteTiming>
|
<TimedTextSmpteTiming>
|
||||||
<Title>Tempistica SMPTE</Title>
|
<Title>Tempistica SMPTE</Title>
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
<Preview>Voorbeeld</Preview>
|
<Preview>Voorbeeld</Preview>
|
||||||
<ShowPreview>Voorbeeld weergeven</ShowPreview>
|
<ShowPreview>Voorbeeld weergeven</ShowPreview>
|
||||||
<HidePreview>Voorbeeld verbergen</HidePreview>
|
<HidePreview>Voorbeeld verbergen</HidePreview>
|
||||||
|
<SubtitleFile>Ondertitelbestand</SubtitleFile>
|
||||||
<SubtitleFiles>Ondertitelbestanden</SubtitleFiles>
|
<SubtitleFiles>Ondertitelbestanden</SubtitleFiles>
|
||||||
<AllFiles>Alle bestanden</AllFiles>
|
<AllFiles>Alle bestanden</AllFiles>
|
||||||
<VideoFiles>Videobestanden</VideoFiles>
|
<VideoFiles>Videobestanden</VideoFiles>
|
||||||
@ -197,9 +198,6 @@ Is er voldoende beschikbare ruimte op de harde schijf?</WaveFileMalformed>
|
|||||||
<Engine>Engine</Engine>
|
<Engine>Engine</Engine>
|
||||||
<VoskWebsite>Website van Vosk</VoskWebsite>
|
<VoskWebsite>Website van Vosk</VoskWebsite>
|
||||||
<WhisperWebsite>Website van Whisper</WhisperWebsite>
|
<WhisperWebsite>Website van Whisper</WhisperWebsite>
|
||||||
<WhisperNotFound>Whisper niet gevonden.
|
|
||||||
|
|
||||||
Meer informatie online weergeven?</WhisperNotFound>
|
|
||||||
<Model>Model</Model>
|
<Model>Model</Model>
|
||||||
<Models>Modellen</Models>
|
<Models>Modellen</Models>
|
||||||
<LanguagesAndModels>Talen en modellen</LanguagesAndModels>
|
<LanguagesAndModels>Talen en modellen</LanguagesAndModels>
|
||||||
@ -216,12 +214,14 @@ Meer informatie online weergeven?</WhisperNotFound>
|
|||||||
<BatchMode>Batchmodus</BatchMode>
|
<BatchMode>Batchmodus</BatchMode>
|
||||||
<KeepPartialTranscription>Gedeeltelijke transcriptie behouden</KeepPartialTranscription>
|
<KeepPartialTranscription>Gedeeltelijke transcriptie behouden</KeepPartialTranscription>
|
||||||
<TranslateToEnglish>Vertaal naar Engels</TranslateToEnglish>
|
<TranslateToEnglish>Vertaal naar Engels</TranslateToEnglish>
|
||||||
<MaxCharsPerSubtitle>Max. tekens per ondertitelregel</MaxCharsPerSubtitle>
|
|
||||||
<RemoveTemporaryFiles>Tijdelijke bestanden verwijderen</RemoveTemporaryFiles>
|
<RemoveTemporaryFiles>Tijdelijke bestanden verwijderen</RemoveTemporaryFiles>
|
||||||
<SetCppConstMeFolder>Map CPP/Const-me-modellen instellen...</SetCppConstMeFolder>
|
<SetCppConstMeFolder>Map CPP/Const-me-modellen instellen...</SetCppConstMeFolder>
|
||||||
<OnlyRunPostProcessing>Alleen nabewerking uitvoeren/tijden aanpassen</OnlyRunPostProcessing>
|
<OnlyRunPostProcessing>Alleen nabewerking uitvoeren/tijden aanpassen</OnlyRunPostProcessing>
|
||||||
<DownloadFasterWhisperCuda>cuBLAS en cuDNN voor Faster-Whisper downloaden</DownloadFasterWhisperCuda>
|
<DownloadFasterWhisperCuda>cuBLAS en cuDNN voor Faster-Whisper downloaden</DownloadFasterWhisperCuda>
|
||||||
<NoTextFound>Geen tekst gevonden!</NoTextFound>
|
<NoTextFound>Geen tekst gevonden!</NoTextFound>
|
||||||
|
<FixCasing>Hoofdlettergebruik corrigeren</FixCasing>
|
||||||
|
<AddPeriods>Punten toevoegen</AddPeriods>
|
||||||
|
<FixShortDuration>Korte duurtijden corrigeren</FixShortDuration>
|
||||||
</AudioToText>
|
</AudioToText>
|
||||||
<AssaAttachments>
|
<AssaAttachments>
|
||||||
<Title>Advanced Sub Station Alpha-bijlagen</Title>
|
<Title>Advanced Sub Station Alpha-bijlagen</Title>
|
||||||
@ -731,6 +731,8 @@ We maken dan handig gebruik van het ritme van het beeld zelf.</CreateSimpleChain
|
|||||||
<ChooseColor>Kleur kiezen:</ChooseColor>
|
<ChooseColor>Kleur kiezen:</ChooseColor>
|
||||||
<TotalSeconds>Totaalaantal seconden:</TotalSeconds>
|
<TotalSeconds>Totaalaantal seconden:</TotalSeconds>
|
||||||
<EndDelayInSeconds>Eindvertraging in seconden:</EndDelayInSeconds>
|
<EndDelayInSeconds>Eindvertraging in seconden:</EndDelayInSeconds>
|
||||||
|
<WordEffect>Woordeffect</WordEffect>
|
||||||
|
<CharacterEffect>Tekeneffect</CharacterEffect>
|
||||||
</EffectKaraoke>
|
</EffectKaraoke>
|
||||||
<EffectTypewriter>
|
<EffectTypewriter>
|
||||||
<Title>Typemachine-effect</Title>
|
<Title>Typemachine-effect</Title>
|
||||||
@ -1011,21 +1013,28 @@ We maken dan handig gebruik van het ritme van het beeld zelf.</CreateSimpleChain
|
|||||||
<Audio>Audio</Audio>
|
<Audio>Audio</Audio>
|
||||||
<Stereo>Stereo</Stereo>
|
<Stereo>Stereo</Stereo>
|
||||||
<Preset>Preset</Preset>
|
<Preset>Preset</Preset>
|
||||||
|
<PixelFormat>Pixelindeling</PixelFormat>
|
||||||
<Crf>CRF</Crf>
|
<Crf>CRF</Crf>
|
||||||
<TuneFor>Optimaliseren voor</TuneFor>
|
<TuneFor>Optimaliseren voor</TuneFor>
|
||||||
<AlignRight>Rechts uitlijnen</AlignRight>
|
<AlignRight>Rechts uitlijnen</AlignRight>
|
||||||
<GetStartPosition>Beginpositie gebruiken</GetStartPosition>
|
<GetStartPosition>Beginpositie gebruiken</GetStartPosition>
|
||||||
<GetEndPosition>Eindpositie gebruiken</GetEndPosition>
|
<GetEndPosition>Eindpositie gebruiken</GetEndPosition>
|
||||||
|
<UseSource>Bron gebruiken</UseSource>
|
||||||
|
<UseSourceResolution>Bronresolutie gebruiken</UseSourceResolution>
|
||||||
|
<OutputSettings>Uitvoerbestand/-map...</OutputSettings>
|
||||||
</GenerateVideoWithBurnedInSubs>
|
</GenerateVideoWithBurnedInSubs>
|
||||||
<GenerateVideoWithEmbeddedSubs>
|
<GenerateVideoWithEmbeddedSubs>
|
||||||
<Title>Ondertitels toevoegen aan/verwijderen uit videobestand</Title>
|
<Title>Ondertitels toevoegen aan/verwijderen uit videobestand</Title>
|
||||||
<InputVideoFile>Invoer-videobestand</InputVideoFile>
|
<InputVideoFile>Invoer-videobestand</InputVideoFile>
|
||||||
<SubtitlesX>Ondertitels ({0})</SubtitlesX>
|
<SubtitlesX>Ondertitels ({0})</SubtitlesX>
|
||||||
<SetLanguage>Taal instellen...</SetLanguage>
|
<SetLanguage>Taal instellen...</SetLanguage>
|
||||||
|
<LanguageAndTitle>Taal/titel</LanguageAndTitle>
|
||||||
<ToggleForced>Geforceerd aan/uit</ToggleForced>
|
<ToggleForced>Geforceerd aan/uit</ToggleForced>
|
||||||
<ToggleDefault>Standaard aan/uit</ToggleDefault>
|
<ToggleDefault>Standaard aan/uit</ToggleDefault>
|
||||||
<Default>Standaard</Default>
|
<Default>Standaard</Default>
|
||||||
<XGeneratedWithEmbeddedSubs>'{0}' gegenereerd met ingesloten ondertitels</XGeneratedWithEmbeddedSubs>
|
<XGeneratedWithEmbeddedSubs>'{0}' gegenereerd met ingesloten ondertitels</XGeneratedWithEmbeddedSubs>
|
||||||
|
<DeleteInputVideo>Invoervideobestand na genereren verwijderen</DeleteInputVideo>
|
||||||
|
<OutputFileNameSettings>Instellingen voor uitvoerbestandsnaam...</OutputFileNameSettings>
|
||||||
</GenerateVideoWithEmbeddedSubs>
|
</GenerateVideoWithEmbeddedSubs>
|
||||||
<GetDictionaries>
|
<GetDictionaries>
|
||||||
<Title>Woordenboek nodig?</Title>
|
<Title>Woordenboek nodig?</Title>
|
||||||
@ -1052,14 +1061,7 @@ We maken dan handig gebruik van het ritme van het beeld zelf.</CreateSimpleChain
|
|||||||
<To>Naar:</To>
|
<To>Naar:</To>
|
||||||
<Translate>Vertalen</Translate>
|
<Translate>Vertalen</Translate>
|
||||||
<PleaseWait>Dit kan enige tijd duren. Een ogenblik geduld.</PleaseWait>
|
<PleaseWait>Dit kan enige tijd duren. Een ogenblik geduld.</PleaseWait>
|
||||||
<PoweredByGoogleTranslate>Mogelijk gemaakt door Google Vertalen</PoweredByGoogleTranslate>
|
|
||||||
<PoweredByMicrosoftTranslate>Mogelijk gemaakt door Microsoft Translator</PoweredByMicrosoftTranslate>
|
|
||||||
<PoweredByX>Mogelijk gemaakt door {0}</PoweredByX>
|
<PoweredByX>Mogelijk gemaakt door {0}</PoweredByX>
|
||||||
<MsClientSecretNeeded>Voor toegang tot Microsoft Translator is een Cognitive Services ‘Translator Text’-sleutel van Microsoft vereist.
|
|
||||||
|
|
||||||
Open ‘Instellingen -> Voorkeuren -> Extra’ voor meer informatie.</MsClientSecretNeeded>
|
|
||||||
<GoogleNoApiKeyWarning>Google Vertalen zonder API-sleutel... (traag en beperkt)</GoogleNoApiKeyWarning>
|
|
||||||
<Service>Dienst:</Service>
|
|
||||||
<LineMergeHandling>Regels samenvoegen:</LineMergeHandling>
|
<LineMergeHandling>Regels samenvoegen:</LineMergeHandling>
|
||||||
<ProcessorMergeNext>Maximaal twee regels samenvoegen</ProcessorMergeNext>
|
<ProcessorMergeNext>Maximaal twee regels samenvoegen</ProcessorMergeNext>
|
||||||
<ProcessorSentence>Zinnen samenvoegen</ProcessorSentence>
|
<ProcessorSentence>Zinnen samenvoegen</ProcessorSentence>
|
||||||
@ -1079,6 +1081,13 @@ Open ‘Instellingen -> Voorkeuren -> Extra’ voor meer informatie.</MsCl
|
|||||||
<XRequiresAnApiKey>Voor {0} is een API-sleutel vereist.</XRequiresAnApiKey>
|
<XRequiresAnApiKey>Voor {0} is een API-sleutel vereist.</XRequiresAnApiKey>
|
||||||
<ReadMore>Meer informatie weergeven?</ReadMore>
|
<ReadMore>Meer informatie weergeven?</ReadMore>
|
||||||
<Formality>Aanspreekvorm</Formality>
|
<Formality>Aanspreekvorm</Formality>
|
||||||
|
<TranslateCurrentLine>Alleen huidige titel vertalen</TranslateCurrentLine>
|
||||||
|
<ReTranslateCurrentLine>Huidige titel opnieuw vertalen</ReTranslateCurrentLine>
|
||||||
|
<MergeSplitStrategy>Splitsen/samenvoegen</MergeSplitStrategy>
|
||||||
|
<Delay>Vertraging tussen serververzoeken</Delay>
|
||||||
|
<MaxBytes>Maximumaantal bytes per serververzoek</MaxBytes>
|
||||||
|
<PromptX>Vragen om {0}</PromptX>
|
||||||
|
<TranslateLinesSeparately>Elke regel afzonderlijk vertalen</TranslateLinesSeparately>
|
||||||
</GoogleTranslate>
|
</GoogleTranslate>
|
||||||
<GoogleOrMicrosoftTranslate>
|
<GoogleOrMicrosoftTranslate>
|
||||||
<Title>Vertalen met Google of Microsoft</Title>
|
<Title>Vertalen met Google of Microsoft</Title>
|
||||||
@ -1437,12 +1446,14 @@ Open ‘Instellingen -> Voorkeuren -> Extra’ voor meer informatie.</MsCl
|
|||||||
<GenerateBlankVideo>Lege video genereren...</GenerateBlankVideo>
|
<GenerateBlankVideo>Lege video genereren...</GenerateBlankVideo>
|
||||||
<GenerateVideoWithBurnedInSub>Video met ingebrande ondertiteling genereren...</GenerateVideoWithBurnedInSub>
|
<GenerateVideoWithBurnedInSub>Video met ingebrande ondertiteling genereren...</GenerateVideoWithBurnedInSub>
|
||||||
<GenerateVideoWithEmbeddedSubs>Ondertitels toevoegen aan/verwijderen uit videobestand...</GenerateVideoWithEmbeddedSubs>
|
<GenerateVideoWithEmbeddedSubs>Ondertitels toevoegen aan/verwijderen uit videobestand...</GenerateVideoWithEmbeddedSubs>
|
||||||
|
<GenerateTransparentVideoWithSubs>Transparante video met ondertitels genereren...</GenerateTransparentVideoWithSubs>
|
||||||
<VideoAudioToTextX>Audio naar tekst ({0})...</VideoAudioToTextX>
|
<VideoAudioToTextX>Audio naar tekst ({0})...</VideoAudioToTextX>
|
||||||
<ImportChaptersFromVideo>Hoofdstukken uit video importeren</ImportChaptersFromVideo>
|
<ImportChaptersFromVideo>Hoofdstukken uit video importeren</ImportChaptersFromVideo>
|
||||||
<GenerateImportShotChanges>Beeldwissels detecteren/importeren...</GenerateImportShotChanges>
|
<GenerateImportShotChanges>Beeldwissels detecteren/importeren...</GenerateImportShotChanges>
|
||||||
<RemoveOrExportShotChanges>Beeldwissels verwijderen/exporteren...</RemoveOrExportShotChanges>
|
<RemoveOrExportShotChanges>Beeldwissels verwijderen/exporteren...</RemoveOrExportShotChanges>
|
||||||
<WaveformBatchGenerate>Golfvormen genereren</WaveformBatchGenerate>
|
<WaveformBatchGenerate>Golfvormen genereren</WaveformBatchGenerate>
|
||||||
<ShowHideWaveformAndSpectrogram>Golfvorm en spectrogram weergeven/verbergen</ShowHideWaveformAndSpectrogram>
|
<ShowHideWaveformAndSpectrogram>Golfvorm en spectrogram weergeven/verbergen</ShowHideWaveformAndSpectrogram>
|
||||||
|
<TextToSpeechAndAddToVideo>Tekst naar spraak en aan video toevoegen...</TextToSpeechAndAddToVideo>
|
||||||
<UnDockVideoControls>Videovenster ontkoppelen</UnDockVideoControls>
|
<UnDockVideoControls>Videovenster ontkoppelen</UnDockVideoControls>
|
||||||
<ReDockVideoControls>Videovenster koppelen</ReDockVideoControls>
|
<ReDockVideoControls>Videovenster koppelen</ReDockVideoControls>
|
||||||
</Video>
|
</Video>
|
||||||
@ -1600,6 +1611,7 @@ Open ‘Instellingen -> Voorkeuren -> Extra’ voor meer informatie.</MsCl
|
|||||||
<GoToSourceView>Naar bronweergave</GoToSourceView>
|
<GoToSourceView>Naar bronweergave</GoToSourceView>
|
||||||
<GoToListView>Naar lijstweergave</GoToListView>
|
<GoToListView>Naar lijstweergave</GoToListView>
|
||||||
<ExtractAudio>Audio extraheren...</ExtractAudio>
|
<ExtractAudio>Audio extraheren...</ExtractAudio>
|
||||||
|
<MediaInfo>Media-informatie</MediaInfo>
|
||||||
</ContextMenu>
|
</ContextMenu>
|
||||||
</Menu>
|
</Menu>
|
||||||
<Controls>
|
<Controls>
|
||||||
@ -1636,6 +1648,7 @@ Open ‘Instellingen -> Voorkeuren -> Extra’ voor meer informatie.</MsCl
|
|||||||
<StillTypingAutoContinueStopped>Er wordt nog getypt... automatisch doorgaan gestopt</StillTypingAutoContinueStopped>
|
<StillTypingAutoContinueStopped>Er wordt nog getypt... automatisch doorgaan gestopt</StillTypingAutoContinueStopped>
|
||||||
<InsertNewSubtitleAtVideoPosition>&Nieuwe ondertitel invoegen</InsertNewSubtitleAtVideoPosition>
|
<InsertNewSubtitleAtVideoPosition>&Nieuwe ondertitel invoegen</InsertNewSubtitleAtVideoPosition>
|
||||||
<InsertNewSubtitleAtVideoPositionNoTextBoxFocus>Nieuwe ondertitel invoegen (tekstvak niet activeren)</InsertNewSubtitleAtVideoPositionNoTextBoxFocus>
|
<InsertNewSubtitleAtVideoPositionNoTextBoxFocus>Nieuwe ondertitel invoegen (tekstvak niet activeren)</InsertNewSubtitleAtVideoPositionNoTextBoxFocus>
|
||||||
|
<InsertNewSubtitleAtVideoPositionMax>Nieuwe ondertitel invoegen (indien mogelijk)</InsertNewSubtitleAtVideoPositionMax>
|
||||||
<Auto>Automatisch</Auto>
|
<Auto>Automatisch</Auto>
|
||||||
<PlayFromJustBeforeText>Vanaf vlak voor deze &titel afspelen</PlayFromJustBeforeText>
|
<PlayFromJustBeforeText>Vanaf vlak voor deze &titel afspelen</PlayFromJustBeforeText>
|
||||||
<PlayFromBeginning>Vanaf begin van video afspelen</PlayFromBeginning>
|
<PlayFromBeginning>Vanaf begin van video afspelen</PlayFromBeginning>
|
||||||
@ -2122,6 +2135,10 @@ Indien u dit bestand met Subtitle Edit hebt bewerkt, kunt u een vorige versie vi
|
|||||||
<EvenLines>Even regelnummers</EvenLines>
|
<EvenLines>Even regelnummers</EvenLines>
|
||||||
<DurationLessThan>Tijdsduur korter dan</DurationLessThan>
|
<DurationLessThan>Tijdsduur korter dan</DurationLessThan>
|
||||||
<DurationGreaterThan>Tijdsduur langer dan</DurationGreaterThan>
|
<DurationGreaterThan>Tijdsduur langer dan</DurationGreaterThan>
|
||||||
|
<CpsLessThan>CPS lager dan</CpsLessThan>
|
||||||
|
<CpsGreaterThan>CPS hoger dan</CpsGreaterThan>
|
||||||
|
<LengthLessThan>Lengte korter dan</LengthLessThan>
|
||||||
|
<LengthGreaterThan>Lengte langer dan</LengthGreaterThan>
|
||||||
<ExactlyOneLine>Precies één regel</ExactlyOneLine>
|
<ExactlyOneLine>Precies één regel</ExactlyOneLine>
|
||||||
<ExactlyTwoLines>Precies twee regels</ExactlyTwoLines>
|
<ExactlyTwoLines>Precies twee regels</ExactlyTwoLines>
|
||||||
<MoreThanTwoLines>Meer dan twee regels</MoreThanTwoLines>
|
<MoreThanTwoLines>Meer dan twee regels</MoreThanTwoLines>
|
||||||
@ -2527,6 +2544,8 @@ hetzelfde ondertitelbestand bewerken (samenwerken)</Information>
|
|||||||
<CpsLineLengthStyleCalcNoSpace>Alle tekens behalve spaties meetellen</CpsLineLengthStyleCalcNoSpace>
|
<CpsLineLengthStyleCalcNoSpace>Alle tekens behalve spaties meetellen</CpsLineLengthStyleCalcNoSpace>
|
||||||
<CpsLineLengthStyleCalcCjk>CJK 1, Latin 0,5</CpsLineLengthStyleCalcCjk>
|
<CpsLineLengthStyleCalcCjk>CJK 1, Latin 0,5</CpsLineLengthStyleCalcCjk>
|
||||||
<CpsLineLengthStyleCalcCjkNoSpace>CJK 1, Latin 0,5, spatie 0</CpsLineLengthStyleCalcCjkNoSpace>
|
<CpsLineLengthStyleCalcCjkNoSpace>CJK 1, Latin 0,5, spatie 0</CpsLineLengthStyleCalcCjkNoSpace>
|
||||||
|
<CpsLineLengthStyleCalcIncludeCompositionCharacters>Inclusief compositietekens</CpsLineLengthStyleCalcIncludeCompositionCharacters>
|
||||||
|
<CpsLineLengthStyleCalcIncludeCompositionCharactersNotSpace>Inclusief compositietekens, zonder spaties</CpsLineLengthStyleCalcIncludeCompositionCharactersNotSpace>
|
||||||
<CpsLineLengthStyleCalcNoSpaceOrPunctuation>Geen spaties of interpunctie ()[]-:;,.!?</CpsLineLengthStyleCalcNoSpaceOrPunctuation>
|
<CpsLineLengthStyleCalcNoSpaceOrPunctuation>Geen spaties of interpunctie ()[]-:;,.!?</CpsLineLengthStyleCalcNoSpaceOrPunctuation>
|
||||||
<CpsLineLengthStyleCalcNoSpaceOrPunctuationCpsOnly>Geen spaties of interpunctie, alleen voor CPS</CpsLineLengthStyleCalcNoSpaceOrPunctuationCpsOnly>
|
<CpsLineLengthStyleCalcNoSpaceOrPunctuationCpsOnly>Geen spaties of interpunctie, alleen voor CPS</CpsLineLengthStyleCalcNoSpaceOrPunctuationCpsOnly>
|
||||||
<MusicSymbol>Vervangend muzieksymbool</MusicSymbol>
|
<MusicSymbol>Vervangend muzieksymbool</MusicSymbol>
|
||||||
@ -2673,6 +2692,8 @@ hetzelfde ondertitelbestand bewerken (samenwerken)</Information>
|
|||||||
<WaveformGoToPreviousShotChange>Naar vorige beeldwissel</WaveformGoToPreviousShotChange>
|
<WaveformGoToPreviousShotChange>Naar vorige beeldwissel</WaveformGoToPreviousShotChange>
|
||||||
<WaveformGoToNextShotChange>Naar volgende beeldwissel</WaveformGoToNextShotChange>
|
<WaveformGoToNextShotChange>Naar volgende beeldwissel</WaveformGoToNextShotChange>
|
||||||
<WaveformToggleShotChange>Beeldwissel toevoegen/verwijderen</WaveformToggleShotChange>
|
<WaveformToggleShotChange>Beeldwissel toevoegen/verwijderen</WaveformToggleShotChange>
|
||||||
|
<WaveformAllShotChangesOneFrameForward>Alle beeldwissels één frame vooruit verplaatsen</WaveformAllShotChangesOneFrameForward>
|
||||||
|
<WaveformAllShotChangesOneFrameBack>Alle beeldwissels één frame achteruit verplaatsen</WaveformAllShotChangesOneFrameBack>
|
||||||
<WaveformRemoveOrExportShotChanges>Beeldwissels verwijderen/exporteren</WaveformRemoveOrExportShotChanges>
|
<WaveformRemoveOrExportShotChanges>Beeldwissels verwijderen/exporteren</WaveformRemoveOrExportShotChanges>
|
||||||
<WaveformGuessStart>Begin automatisch aanpassen aan de hand van volumewijziging/beeldwissel</WaveformGuessStart>
|
<WaveformGuessStart>Begin automatisch aanpassen aan de hand van volumewijziging/beeldwissel</WaveformGuessStart>
|
||||||
<GoBack1Frame>Eén frame terug</GoBack1Frame>
|
<GoBack1Frame>Eén frame terug</GoBack1Frame>
|
||||||
@ -3122,6 +3143,9 @@ Probeer het later opnieuw.</XDownloadFailed>
|
|||||||
<Angle>Hoek</Angle>
|
<Angle>Hoek</Angle>
|
||||||
<BoxPerLine>Vak voor elke regel (gebruik omtrekkleur)</BoxPerLine>
|
<BoxPerLine>Vak voor elke regel (gebruik omtrekkleur)</BoxPerLine>
|
||||||
<BoxMultiLine>Eén vak (gebruik schaduwkleur)</BoxMultiLine>
|
<BoxMultiLine>Eén vak (gebruik schaduwkleur)</BoxMultiLine>
|
||||||
|
<BoxPerLineShort>Vak voor elke regel</BoxPerLineShort>
|
||||||
|
<BoxMultiLineShort>Eén vak</BoxMultiLineShort>
|
||||||
|
<BoxType>Vaktype</BoxType>
|
||||||
<DuplicateStyleNames>Dubbele stijlnamen: {0}</DuplicateStyleNames>
|
<DuplicateStyleNames>Dubbele stijlnamen: {0}</DuplicateStyleNames>
|
||||||
</SubStationAlphaStyles>
|
</SubStationAlphaStyles>
|
||||||
<SubStationAlphaStylesCategoriesManager>
|
<SubStationAlphaStylesCategoriesManager>
|
||||||
@ -3148,6 +3172,25 @@ Probeer het later opnieuw.</XDownloadFailed>
|
|||||||
<Info>Eén sync-punt past positie aan, twee of meer sync-punten passen positie én snelheid aan</Info>
|
<Info>Eén sync-punt past positie aan, twee of meer sync-punten passen positie én snelheid aan</Info>
|
||||||
<ApplySync>Toepassen</ApplySync>
|
<ApplySync>Toepassen</ApplySync>
|
||||||
</PointSync>
|
</PointSync>
|
||||||
|
<TextToSpeech>
|
||||||
|
<Title>Tekst naar spraak</Title>
|
||||||
|
<Voice>Stem</Voice>
|
||||||
|
<TestVoice>Stem testen</TestVoice>
|
||||||
|
<DefaultVoice>Standaardstem</DefaultVoice>
|
||||||
|
<AddAudioToVideo>Audio aan video toevoegen (nieuw bestand)</AddAudioToVideo>
|
||||||
|
<GenerateSpeech>Spraak genereren</GenerateSpeech>
|
||||||
|
<ActorInfo>Rechtsklik om acteur aan stem toe te wijzen</ActorInfo>
|
||||||
|
<AdjustingSpeedXOfY>Snelheid aanpassen: {0} / {1}...</AdjustingSpeedXOfY>
|
||||||
|
<MergingAudioTrackXOfY>Audiospoor samenvoegen: {0} / {1}...</MergingAudioTrackXOfY>
|
||||||
|
<GeneratingSpeechFromTextXOfY>Spraak genereren: {0} / {1}...</GeneratingSpeechFromTextXOfY>
|
||||||
|
<ReviewAudioClips>Audiofragmenten controleren</ReviewAudioClips>
|
||||||
|
<CustomAudioEncoding>Aangepaste audiocodering</CustomAudioEncoding>
|
||||||
|
<ReviewInfo>Audiofragmenten controleren en bewerken/verwijderen</ReviewInfo>
|
||||||
|
<Play>Afspelen</Play>
|
||||||
|
<AutoContinue>Automatisch doorgaan</AutoContinue>
|
||||||
|
<Regenerate>Opnieuw genereren</Regenerate>
|
||||||
|
<Speed>Snelheid</Speed>
|
||||||
|
</TextToSpeech>
|
||||||
<TimedTextSmpteTiming>
|
<TimedTextSmpteTiming>
|
||||||
<Title>SMPTE-timing</Title>
|
<Title>SMPTE-timing</Title>
|
||||||
<UseSmpteTiming>SMPTE-timing voor huidige ondertitel gebruiken?</UseSmpteTiming>
|
<UseSmpteTiming>SMPTE-timing voor huidige ondertitel gebruiken?</UseSmpteTiming>
|
||||||
@ -3317,6 +3360,13 @@ Wilt u deze wijzigingen behouden?</KeepChangesMessage>
|
|||||||
<InspectItems>Items inspecteren</InspectItems>
|
<InspectItems>Items inspecteren</InspectItems>
|
||||||
<AddBetterMatch>Betere overeenkomst toevoegen</AddBetterMatch>
|
<AddBetterMatch>Betere overeenkomst toevoegen</AddBetterMatch>
|
||||||
<Add>Toevoegen</Add>
|
<Add>Toevoegen</Add>
|
||||||
|
<AddBetterMultiMatch>Betere multi-overeenkomst toevoegen</AddBetterMultiMatch>
|
||||||
|
<AddOrUpdateMatch>Overeenkomst toevoegen of wijzigen</AddOrUpdateMatch>
|
||||||
|
<SelectPrevousMatch>Vorige overeenkomst selecteren</SelectPrevousMatch>
|
||||||
|
<SelectNextMatch>Volgende overeenkomst selecteren</SelectNextMatch>
|
||||||
|
<JumpPreviousMissingMatch>Naar vorige ontbrekende overeenkomst</JumpPreviousMissingMatch>
|
||||||
|
<JumpNextMissingMatch>Naar volgende ontbrekende overeenkomst</JumpNextMissingMatch>
|
||||||
|
<FocusTextbox>Tekstvak activeren</FocusTextbox>
|
||||||
</VobSubOcrCharacterInspect>
|
</VobSubOcrCharacterInspect>
|
||||||
<VobSubOcrNewFolder>
|
<VobSubOcrNewFolder>
|
||||||
<Title>Nieuwe map</Title>
|
<Title>Nieuwe map</Title>
|
||||||
@ -3369,6 +3419,7 @@ Wilt u deze wijzigingen behouden?</KeepChangesMessage>
|
|||||||
<SplitAtCursor>Splitsen op cursor</SplitAtCursor>
|
<SplitAtCursor>Splitsen op cursor</SplitAtCursor>
|
||||||
<MergeWithPrevious>Met vorige samenvoegen</MergeWithPrevious>
|
<MergeWithPrevious>Met vorige samenvoegen</MergeWithPrevious>
|
||||||
<MergeWithNext>Met volgende samenvoegen</MergeWithNext>
|
<MergeWithNext>Met volgende samenvoegen</MergeWithNext>
|
||||||
|
<RunWhisperSelectedParagraph>Whisper uitvoeren op geselecteerde titel...</RunWhisperSelectedParagraph>
|
||||||
<ExtendToPrevious>Tot vorige verlengen</ExtendToPrevious>
|
<ExtendToPrevious>Tot vorige verlengen</ExtendToPrevious>
|
||||||
<ExtendToNext>Tot volgende verlengen</ExtendToNext>
|
<ExtendToNext>Tot volgende verlengen</ExtendToNext>
|
||||||
<PlaySelection>Selectie afspelen</PlaySelection>
|
<PlaySelection>Selectie afspelen</PlaySelection>
|
||||||
@ -3381,6 +3432,7 @@ Wilt u deze wijzigingen behouden?</KeepChangesMessage>
|
|||||||
<GuessTimeCodes>Tijdcodes schatten...</GuessTimeCodes>
|
<GuessTimeCodes>Tijdcodes schatten...</GuessTimeCodes>
|
||||||
<SeekSilence>Stilte zoeken...</SeekSilence>
|
<SeekSilence>Stilte zoeken...</SeekSilence>
|
||||||
<InsertSubtitleHere>Ondertitel hier invoegen</InsertSubtitleHere>
|
<InsertSubtitleHere>Ondertitel hier invoegen</InsertSubtitleHere>
|
||||||
|
<InsertSubtitleFileHere>Ondertitelbestand hier invoegen...</InsertSubtitleFileHere>
|
||||||
<CharsSecX>CPS: {0:0.00}</CharsSecX>
|
<CharsSecX>CPS: {0:0.00}</CharsSecX>
|
||||||
<WordsMinX>WPM: {0:0.00}</WordsMinX>
|
<WordsMinX>WPM: {0:0.00}</WordsMinX>
|
||||||
</Waveform>
|
</Waveform>
|
||||||
@ -3408,6 +3460,7 @@ Wilt u deze wijzigingen behouden?</KeepChangesMessage>
|
|||||||
<WebVttProperties>
|
<WebVttProperties>
|
||||||
<UseXTimeStamp>Waarde van X-TIMESTAMP-MAP-header gebruiken</UseXTimeStamp>
|
<UseXTimeStamp>Waarde van X-TIMESTAMP-MAP-header gebruiken</UseXTimeStamp>
|
||||||
<MergeLines>Titels met dezelfde tekst samenvoegen bij inladen</MergeLines>
|
<MergeLines>Titels met dezelfde tekst samenvoegen bij inladen</MergeLines>
|
||||||
|
<MergeStyleTags>Stijltags samenvoegen</MergeStyleTags>
|
||||||
</WebVttProperties>
|
</WebVttProperties>
|
||||||
<WebVttStyleManager>
|
<WebVttStyleManager>
|
||||||
<Title>WebVTT-stijlen</Title>
|
<Title>WebVTT-stijlen</Title>
|
||||||
@ -3416,5 +3469,10 @@ Wilt u deze wijzigingen behouden?</KeepChangesMessage>
|
|||||||
<Title>Whisper (geavanceerd) – extra opdrachtregelargumenten</Title>
|
<Title>Whisper (geavanceerd) – extra opdrachtregelargumenten</Title>
|
||||||
<CommandLineArguments>Extra opdrachtregelargumenten voor Whisper:</CommandLineArguments>
|
<CommandLineArguments>Extra opdrachtregelargumenten voor Whisper:</CommandLineArguments>
|
||||||
<Info>Let op: de opdrachtregelargumenten kunnen per Whisper-implementatie verschillen!</Info>
|
<Info>Let op: de opdrachtregelargumenten kunnen per Whisper-implementatie verschillen!</Info>
|
||||||
|
<Standard>Standaard</Standard>
|
||||||
|
<StandardAsia>Standaard (Azië)</StandardAsia>
|
||||||
|
<HighlightCurrentWord>Huidig woord markeren</HighlightCurrentWord>
|
||||||
|
<SingleWords>Afzonderlijke woorden</SingleWords>
|
||||||
|
<Sentence>Zinnen</Sentence>
|
||||||
</WhisperAdvanced>
|
</WhisperAdvanced>
|
||||||
</Language>
|
</Language>
|
@ -3586,6 +3586,8 @@ can edit in same subtitle file (collaboration)",
|
|||||||
Play = "Play",
|
Play = "Play",
|
||||||
Regenerate = "Regenerate",
|
Regenerate = "Regenerate",
|
||||||
Speed = "Speed",
|
Speed = "Speed",
|
||||||
|
Stability = "Stability",
|
||||||
|
Similarity = "Similarity",
|
||||||
};
|
};
|
||||||
|
|
||||||
TimedTextSmpteTiming = new LanguageStructure.TimedTextSmpteTiming
|
TimedTextSmpteTiming = new LanguageStructure.TimedTextSmpteTiming
|
||||||
|
@ -8746,6 +8746,12 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
case "TextToSpeech/Speed":
|
case "TextToSpeech/Speed":
|
||||||
language.TextToSpeech.Speed = reader.Value;
|
language.TextToSpeech.Speed = reader.Value;
|
||||||
break;
|
break;
|
||||||
|
case "TextToSpeech/Stability":
|
||||||
|
language.TextToSpeech.Stability = reader.Value;
|
||||||
|
break;
|
||||||
|
case "TextToSpeech/Similarity":
|
||||||
|
language.TextToSpeech.Similarity = reader.Value;
|
||||||
|
break;
|
||||||
case "TimedTextSmpteTiming/Title":
|
case "TimedTextSmpteTiming/Title":
|
||||||
language.TimedTextSmpteTiming.Title = reader.Value;
|
language.TimedTextSmpteTiming.Title = reader.Value;
|
||||||
break;
|
break;
|
||||||
|
@ -3397,6 +3397,8 @@
|
|||||||
public string AutoContinue { get; set; }
|
public string AutoContinue { get; set; }
|
||||||
public string Regenerate { get; set; }
|
public string Regenerate { get; set; }
|
||||||
public string Speed { get; set; }
|
public string Speed { get; set; }
|
||||||
|
public string Stability { get; set; }
|
||||||
|
public string Similarity { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class TimedTextSmpteTiming
|
public class TimedTextSmpteTiming
|
||||||
|
@ -41,7 +41,7 @@ namespace Nikse.SubtitleEdit.Logic.Ocr.Binary
|
|||||||
{
|
{
|
||||||
if (bob.ExpandCount > 0)
|
if (bob.ExpandCount > 0)
|
||||||
{
|
{
|
||||||
System.Windows.Forms.MessageBox.Show("Ups, expand image in CompareImages!");
|
System.Windows.Forms.MessageBox.Show("Oops, expand image in CompareImages!");
|
||||||
}
|
}
|
||||||
|
|
||||||
bob.Save(gz);
|
bob.Save(gz);
|
||||||
@ -50,7 +50,7 @@ namespace Nikse.SubtitleEdit.Logic.Ocr.Binary
|
|||||||
{
|
{
|
||||||
if (bob.ExpandCount == 0)
|
if (bob.ExpandCount == 0)
|
||||||
{
|
{
|
||||||
System.Windows.Forms.MessageBox.Show("Ups, not expanded image in CompareImagesExpanded!");
|
System.Windows.Forms.MessageBox.Show("Oops, not expanded image in CompareImagesExpanded!");
|
||||||
}
|
}
|
||||||
|
|
||||||
bob.Save(gz);
|
bob.Save(gz);
|
||||||
|
@ -50,7 +50,7 @@ namespace Nikse.SubtitleEdit.Logic.Ocr
|
|||||||
text = text.Replace(" ", " ");
|
text = text.Replace(" ", " ");
|
||||||
text = text.Replace("<i> ", " <i>");
|
text = text.Replace("<i> ", " <i>");
|
||||||
text = text.Replace(" </i>", "</i> ");
|
text = text.Replace(" </i>", "</i> ");
|
||||||
text = text.Replace("</i> <i>", " ");
|
text = text.Replace("</i> <i>", " ");
|
||||||
text = text.Replace(" ", " ");
|
text = text.Replace(" ", " ");
|
||||||
|
|
||||||
return text.Trim();
|
return text.Trim();
|
||||||
@ -67,7 +67,7 @@ namespace Nikse.SubtitleEdit.Logic.Ocr
|
|||||||
}
|
}
|
||||||
|
|
||||||
var beforeHasLetter = i > 0 && !Separators.Contains(matches[i - 1].Text);
|
var beforeHasLetter = i > 0 && !Separators.Contains(matches[i - 1].Text);
|
||||||
var afterHasLetter = i < matches.Count -1 && !Separators.Contains(matches[i + 1].Text);
|
var afterHasLetter = i < matches.Count - 1 && !Separators.Contains(matches[i + 1].Text);
|
||||||
if (beforeHasLetter || afterHasLetter)
|
if (beforeHasLetter || afterHasLetter)
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
|
Loading…
Reference in New Issue
Block a user