mirror of
https://github.com/SubtitleEdit/subtitleedit.git
synced 2024-11-21 18:52:36 +01:00
Added new subtitle format + ZPosition for Dcinema interop
This commit is contained in:
parent
ed3c1af017
commit
dac14dfb90
1
.gitignore
vendored
1
.gitignore
vendored
@ -11,3 +11,4 @@
|
|||||||
/SE*.zip
|
/SE*.zip
|
||||||
/SubtitleEdit-*-setup.exe
|
/SubtitleEdit-*-setup.exe
|
||||||
/src/SubtitleEdit.csproj.user
|
/src/SubtitleEdit.csproj.user
|
||||||
|
/src/Languages/Language.xml
|
||||||
|
@ -3,9 +3,10 @@
|
|||||||
|
|
||||||
3.3.15 (x March 2014)
|
3.3.15 (x March 2014)
|
||||||
* NEW:
|
* NEW:
|
||||||
* Added new subtitle format
|
* Added new subtitle formats
|
||||||
* IMPROVED:
|
* IMPROVED:
|
||||||
* Updated French language file - thx JM GBT
|
* Updated French language file - thx JM GBT
|
||||||
|
* Added ZPosition setting for Dcinema interop - thx Joseph
|
||||||
* FIXED:
|
* FIXED:
|
||||||
* Minor fix for ass import in Matroska (mkv) files
|
* Minor fix for ass import in Matroska (mkv) files
|
||||||
|
|
||||||
|
134
src/Forms/DCinemaPropertiesInterop.Designer.cs
generated
134
src/Forms/DCinemaPropertiesInterop.Designer.cs
generated
@ -35,6 +35,10 @@
|
|||||||
this.numericUpDownReelNumber = new System.Windows.Forms.NumericUpDown();
|
this.numericUpDownReelNumber = new System.Windows.Forms.NumericUpDown();
|
||||||
this.buttonGenerateID = new System.Windows.Forms.Button();
|
this.buttonGenerateID = new System.Windows.Forms.Button();
|
||||||
this.groupBoxFont = new System.Windows.Forms.GroupBox();
|
this.groupBoxFont = new System.Windows.Forms.GroupBox();
|
||||||
|
this.numericUpDownZPosition = new System.Windows.Forms.NumericUpDown();
|
||||||
|
this.labelZPosition = new System.Windows.Forms.Label();
|
||||||
|
this.numericUpDownTopBottomMargin = new System.Windows.Forms.NumericUpDown();
|
||||||
|
this.labelTopBottomMargin = new System.Windows.Forms.Label();
|
||||||
this.buttonFontEffectColor = new System.Windows.Forms.Button();
|
this.buttonFontEffectColor = new System.Windows.Forms.Button();
|
||||||
this.panelFontColor = new System.Windows.Forms.Panel();
|
this.panelFontColor = new System.Windows.Forms.Panel();
|
||||||
this.buttonFontColor = new System.Windows.Forms.Button();
|
this.buttonFontColor = new System.Windows.Forms.Button();
|
||||||
@ -56,13 +60,13 @@
|
|||||||
this.buttonCancel = new System.Windows.Forms.Button();
|
this.buttonCancel = new System.Windows.Forms.Button();
|
||||||
this.buttonOK = new System.Windows.Forms.Button();
|
this.buttonOK = new System.Windows.Forms.Button();
|
||||||
this.colorDialog1 = new System.Windows.Forms.ColorDialog();
|
this.colorDialog1 = new System.Windows.Forms.ColorDialog();
|
||||||
this.numericUpDownTopBottomMargin = new System.Windows.Forms.NumericUpDown();
|
this.labelZPositionHelp = new System.Windows.Forms.Label();
|
||||||
this.label2 = new System.Windows.Forms.Label();
|
|
||||||
this.groupBox1.SuspendLayout();
|
this.groupBox1.SuspendLayout();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.numericUpDownReelNumber)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownReelNumber)).BeginInit();
|
||||||
this.groupBoxFont.SuspendLayout();
|
this.groupBoxFont.SuspendLayout();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.numericUpDownFontSize)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownZPosition)).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.numericUpDownTopBottomMargin)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownTopBottomMargin)).BeginInit();
|
||||||
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownFontSize)).BeginInit();
|
||||||
this.SuspendLayout();
|
this.SuspendLayout();
|
||||||
//
|
//
|
||||||
// panelFontEffectColor
|
// panelFontEffectColor
|
||||||
@ -91,7 +95,7 @@
|
|||||||
this.groupBox1.Controls.Add(this.labelSubtitleID);
|
this.groupBox1.Controls.Add(this.labelSubtitleID);
|
||||||
this.groupBox1.Location = new System.Drawing.Point(12, 12);
|
this.groupBox1.Location = new System.Drawing.Point(12, 12);
|
||||||
this.groupBox1.Name = "groupBox1";
|
this.groupBox1.Name = "groupBox1";
|
||||||
this.groupBox1.Size = new System.Drawing.Size(537, 364);
|
this.groupBox1.Size = new System.Drawing.Size(597, 419);
|
||||||
this.groupBox1.TabIndex = 0;
|
this.groupBox1.TabIndex = 0;
|
||||||
this.groupBox1.TabStop = false;
|
this.groupBox1.TabStop = false;
|
||||||
//
|
//
|
||||||
@ -150,8 +154,11 @@
|
|||||||
this.groupBoxFont.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
|
this.groupBoxFont.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)
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.groupBoxFont.Controls.Add(this.labelZPositionHelp);
|
||||||
|
this.groupBoxFont.Controls.Add(this.numericUpDownZPosition);
|
||||||
|
this.groupBoxFont.Controls.Add(this.labelZPosition);
|
||||||
this.groupBoxFont.Controls.Add(this.numericUpDownTopBottomMargin);
|
this.groupBoxFont.Controls.Add(this.numericUpDownTopBottomMargin);
|
||||||
this.groupBoxFont.Controls.Add(this.label2);
|
this.groupBoxFont.Controls.Add(this.labelTopBottomMargin);
|
||||||
this.groupBoxFont.Controls.Add(this.panelFontEffectColor);
|
this.groupBoxFont.Controls.Add(this.panelFontEffectColor);
|
||||||
this.groupBoxFont.Controls.Add(this.buttonFontEffectColor);
|
this.groupBoxFont.Controls.Add(this.buttonFontEffectColor);
|
||||||
this.groupBoxFont.Controls.Add(this.panelFontColor);
|
this.groupBoxFont.Controls.Add(this.panelFontColor);
|
||||||
@ -168,11 +175,74 @@
|
|||||||
this.groupBoxFont.Controls.Add(this.labelFontUri);
|
this.groupBoxFont.Controls.Add(this.labelFontUri);
|
||||||
this.groupBoxFont.Location = new System.Drawing.Point(6, 141);
|
this.groupBoxFont.Location = new System.Drawing.Point(6, 141);
|
||||||
this.groupBoxFont.Name = "groupBoxFont";
|
this.groupBoxFont.Name = "groupBoxFont";
|
||||||
this.groupBoxFont.Size = new System.Drawing.Size(525, 217);
|
this.groupBoxFont.Size = new System.Drawing.Size(585, 272);
|
||||||
this.groupBoxFont.TabIndex = 5;
|
this.groupBoxFont.TabIndex = 5;
|
||||||
this.groupBoxFont.TabStop = false;
|
this.groupBoxFont.TabStop = false;
|
||||||
this.groupBoxFont.Text = "Font";
|
this.groupBoxFont.Text = "Font";
|
||||||
//
|
//
|
||||||
|
// numericUpDownZPosition
|
||||||
|
//
|
||||||
|
this.numericUpDownZPosition.DecimalPlaces = 2;
|
||||||
|
this.numericUpDownZPosition.Increment = new decimal(new int[] {
|
||||||
|
5,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
131072});
|
||||||
|
this.numericUpDownZPosition.Location = new System.Drawing.Point(133, 207);
|
||||||
|
this.numericUpDownZPosition.Maximum = new decimal(new int[] {
|
||||||
|
10,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.numericUpDownZPosition.Minimum = new decimal(new int[] {
|
||||||
|
10,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
-2147483648});
|
||||||
|
this.numericUpDownZPosition.Name = "numericUpDownZPosition";
|
||||||
|
this.numericUpDownZPosition.Size = new System.Drawing.Size(112, 20);
|
||||||
|
this.numericUpDownZPosition.TabIndex = 33;
|
||||||
|
//
|
||||||
|
// labelZPosition
|
||||||
|
//
|
||||||
|
this.labelZPosition.AutoSize = true;
|
||||||
|
this.labelZPosition.Location = new System.Drawing.Point(9, 210);
|
||||||
|
this.labelZPosition.Name = "labelZPosition";
|
||||||
|
this.labelZPosition.Size = new System.Drawing.Size(53, 13);
|
||||||
|
this.labelZPosition.TabIndex = 32;
|
||||||
|
this.labelZPosition.Text = "Z-position";
|
||||||
|
//
|
||||||
|
// numericUpDownTopBottomMargin
|
||||||
|
//
|
||||||
|
this.numericUpDownTopBottomMargin.Location = new System.Drawing.Point(133, 181);
|
||||||
|
this.numericUpDownTopBottomMargin.Maximum = new decimal(new int[] {
|
||||||
|
50,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.numericUpDownTopBottomMargin.Minimum = new decimal(new int[] {
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
this.numericUpDownTopBottomMargin.Name = "numericUpDownTopBottomMargin";
|
||||||
|
this.numericUpDownTopBottomMargin.Size = new System.Drawing.Size(112, 20);
|
||||||
|
this.numericUpDownTopBottomMargin.TabIndex = 31;
|
||||||
|
this.numericUpDownTopBottomMargin.Value = new decimal(new int[] {
|
||||||
|
1,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0});
|
||||||
|
//
|
||||||
|
// labelTopBottomMargin
|
||||||
|
//
|
||||||
|
this.labelTopBottomMargin.AutoSize = true;
|
||||||
|
this.labelTopBottomMargin.Location = new System.Drawing.Point(9, 184);
|
||||||
|
this.labelTopBottomMargin.Name = "labelTopBottomMargin";
|
||||||
|
this.labelTopBottomMargin.Size = new System.Drawing.Size(97, 13);
|
||||||
|
this.labelTopBottomMargin.TabIndex = 30;
|
||||||
|
this.labelTopBottomMargin.Text = "Top/bottom margin";
|
||||||
|
//
|
||||||
// buttonFontEffectColor
|
// buttonFontEffectColor
|
||||||
//
|
//
|
||||||
this.buttonFontEffectColor.Location = new System.Drawing.Point(133, 128);
|
this.buttonFontEffectColor.Location = new System.Drawing.Point(133, 128);
|
||||||
@ -344,7 +414,7 @@
|
|||||||
//
|
//
|
||||||
this.buttonCancel.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
this.buttonCancel.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
||||||
this.buttonCancel.ImeMode = System.Windows.Forms.ImeMode.NoControl;
|
this.buttonCancel.ImeMode = System.Windows.Forms.ImeMode.NoControl;
|
||||||
this.buttonCancel.Location = new System.Drawing.Point(474, 382);
|
this.buttonCancel.Location = new System.Drawing.Point(534, 437);
|
||||||
this.buttonCancel.Name = "buttonCancel";
|
this.buttonCancel.Name = "buttonCancel";
|
||||||
this.buttonCancel.Size = new System.Drawing.Size(75, 21);
|
this.buttonCancel.Size = new System.Drawing.Size(75, 21);
|
||||||
this.buttonCancel.TabIndex = 2;
|
this.buttonCancel.TabIndex = 2;
|
||||||
@ -356,7 +426,7 @@
|
|||||||
//
|
//
|
||||||
this.buttonOK.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
this.buttonOK.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
||||||
this.buttonOK.ImeMode = System.Windows.Forms.ImeMode.NoControl;
|
this.buttonOK.ImeMode = System.Windows.Forms.ImeMode.NoControl;
|
||||||
this.buttonOK.Location = new System.Drawing.Point(393, 382);
|
this.buttonOK.Location = new System.Drawing.Point(453, 437);
|
||||||
this.buttonOK.Name = "buttonOK";
|
this.buttonOK.Name = "buttonOK";
|
||||||
this.buttonOK.Size = new System.Drawing.Size(75, 21);
|
this.buttonOK.Size = new System.Drawing.Size(75, 21);
|
||||||
this.buttonOK.TabIndex = 1;
|
this.buttonOK.TabIndex = 1;
|
||||||
@ -364,42 +434,22 @@
|
|||||||
this.buttonOK.UseVisualStyleBackColor = true;
|
this.buttonOK.UseVisualStyleBackColor = true;
|
||||||
this.buttonOK.Click += new System.EventHandler(this.buttonOK_Click);
|
this.buttonOK.Click += new System.EventHandler(this.buttonOK_Click);
|
||||||
//
|
//
|
||||||
// numericUpDownTopBottomMargin
|
// labelZPositionHelp
|
||||||
//
|
//
|
||||||
this.numericUpDownTopBottomMargin.Location = new System.Drawing.Point(133, 181);
|
this.labelZPositionHelp.Font = new System.Drawing.Font("Microsoft Sans Serif", 8F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||||
this.numericUpDownTopBottomMargin.Maximum = new decimal(new int[] {
|
this.labelZPositionHelp.ForeColor = System.Drawing.Color.Gray;
|
||||||
50,
|
this.labelZPositionHelp.Location = new System.Drawing.Point(252, 213);
|
||||||
0,
|
this.labelZPositionHelp.Name = "labelZPositionHelp";
|
||||||
0,
|
this.labelZPositionHelp.Size = new System.Drawing.Size(327, 47);
|
||||||
0});
|
this.labelZPositionHelp.TabIndex = 34;
|
||||||
this.numericUpDownTopBottomMargin.Minimum = new decimal(new int[] {
|
this.labelZPositionHelp.Text = "Positive numbers moves text away, negative numbers moves text closer, if z-positi" +
|
||||||
1,
|
"on zeo then it\'s normal \r\n2D";
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0});
|
|
||||||
this.numericUpDownTopBottomMargin.Name = "numericUpDownTopBottomMargin";
|
|
||||||
this.numericUpDownTopBottomMargin.Size = new System.Drawing.Size(112, 20);
|
|
||||||
this.numericUpDownTopBottomMargin.TabIndex = 31;
|
|
||||||
this.numericUpDownTopBottomMargin.Value = new decimal(new int[] {
|
|
||||||
1,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0});
|
|
||||||
//
|
|
||||||
// label2
|
|
||||||
//
|
|
||||||
this.label2.AutoSize = true;
|
|
||||||
this.label2.Location = new System.Drawing.Point(9, 184);
|
|
||||||
this.label2.Name = "label2";
|
|
||||||
this.label2.Size = new System.Drawing.Size(97, 13);
|
|
||||||
this.label2.TabIndex = 30;
|
|
||||||
this.label2.Text = "Top/bottom margin";
|
|
||||||
//
|
//
|
||||||
// DCinemaPropertiesInterop
|
// DCinemaPropertiesInterop
|
||||||
//
|
//
|
||||||
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
||||||
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
||||||
this.ClientSize = new System.Drawing.Size(561, 415);
|
this.ClientSize = new System.Drawing.Size(621, 470);
|
||||||
this.Controls.Add(this.groupBox1);
|
this.Controls.Add(this.groupBox1);
|
||||||
this.Controls.Add(this.buttonCancel);
|
this.Controls.Add(this.buttonCancel);
|
||||||
this.Controls.Add(this.buttonOK);
|
this.Controls.Add(this.buttonOK);
|
||||||
@ -417,8 +467,9 @@
|
|||||||
((System.ComponentModel.ISupportInitialize)(this.numericUpDownReelNumber)).EndInit();
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownReelNumber)).EndInit();
|
||||||
this.groupBoxFont.ResumeLayout(false);
|
this.groupBoxFont.ResumeLayout(false);
|
||||||
this.groupBoxFont.PerformLayout();
|
this.groupBoxFont.PerformLayout();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.numericUpDownFontSize)).EndInit();
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownZPosition)).EndInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.numericUpDownTopBottomMargin)).EndInit();
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownTopBottomMargin)).EndInit();
|
||||||
|
((System.ComponentModel.ISupportInitialize)(this.numericUpDownFontSize)).EndInit();
|
||||||
this.ResumeLayout(false);
|
this.ResumeLayout(false);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -454,6 +505,9 @@
|
|||||||
private System.Windows.Forms.ComboBox comboBoxLanguage;
|
private System.Windows.Forms.ComboBox comboBoxLanguage;
|
||||||
private System.Windows.Forms.Label labelLanguage;
|
private System.Windows.Forms.Label labelLanguage;
|
||||||
private System.Windows.Forms.NumericUpDown numericUpDownTopBottomMargin;
|
private System.Windows.Forms.NumericUpDown numericUpDownTopBottomMargin;
|
||||||
private System.Windows.Forms.Label label2;
|
private System.Windows.Forms.Label labelTopBottomMargin;
|
||||||
|
private System.Windows.Forms.NumericUpDown numericUpDownZPosition;
|
||||||
|
private System.Windows.Forms.Label labelZPosition;
|
||||||
|
private System.Windows.Forms.Label labelZPositionHelp;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -32,6 +32,13 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
buttonFontEffectColor.Text = l.ChooseColor;
|
buttonFontEffectColor.Text = l.ChooseColor;
|
||||||
labelFontSize.Text = l.FontSize;
|
labelFontSize.Text = l.FontSize;
|
||||||
|
|
||||||
|
if (!string.IsNullOrEmpty(l.TopBottomMargin)) //TODO: Remove in SE 3.4
|
||||||
|
{
|
||||||
|
labelTopBottomMargin.Text = l.TopBottomMargin;
|
||||||
|
labelZPosition.Text = l.ZPosition;
|
||||||
|
labelZPositionHelp.Text = l.ZPositionHelp;
|
||||||
|
}
|
||||||
|
|
||||||
this._subtitle = _subtitle;
|
this._subtitle = _subtitle;
|
||||||
this._videoFileName = _videoFileName;
|
this._videoFileName = _videoFileName;
|
||||||
|
|
||||||
@ -69,6 +76,15 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
numericUpDownTopBottomMargin.Value = Configuration.Settings.SubtitleSettings.DCinemaBottomMargin;
|
numericUpDownTopBottomMargin.Value = Configuration.Settings.SubtitleSettings.DCinemaBottomMargin;
|
||||||
else
|
else
|
||||||
numericUpDownTopBottomMargin.Value = 8;
|
numericUpDownTopBottomMargin.Value = 8;
|
||||||
|
|
||||||
|
decimal zPosition = (decimal)Configuration.Settings.SubtitleSettings.DCinemaZPosition;
|
||||||
|
if (numericUpDownZPosition.Minimum <= zPosition &&
|
||||||
|
numericUpDownZPosition.Maximum >= zPosition)
|
||||||
|
numericUpDownZPosition.Value = zPosition;
|
||||||
|
else
|
||||||
|
numericUpDownZPosition.Value = 0;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
FixLargeFonts();
|
FixLargeFonts();
|
||||||
}
|
}
|
||||||
@ -130,6 +146,7 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
ss.CurrentDCinemaFontEffectColor = panelFontEffectColor.BackColor;
|
ss.CurrentDCinemaFontEffectColor = panelFontEffectColor.BackColor;
|
||||||
ss.CurrentDCinemaFontSize = (int)numericUpDownFontSize.Value;
|
ss.CurrentDCinemaFontSize = (int)numericUpDownFontSize.Value;
|
||||||
Configuration.Settings.SubtitleSettings.DCinemaBottomMargin = (int)numericUpDownTopBottomMargin.Value;
|
Configuration.Settings.SubtitleSettings.DCinemaBottomMargin = (int)numericUpDownTopBottomMargin.Value;
|
||||||
|
Configuration.Settings.SubtitleSettings.DCinemaZPosition = (double)numericUpDownZPosition.Value;
|
||||||
|
|
||||||
DialogResult = DialogResult.OK;
|
DialogResult = DialogResult.OK;
|
||||||
}
|
}
|
||||||
|
@ -879,7 +879,8 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (prev == null || prev.EndTime.TotalMilliseconds < p.EndTime.TotalMilliseconds - Configuration.Settings.General.SubtitleMinimumDisplayMilliseconds)
|
else if (Configuration.Settings.Tools.FixShortDisplayTimesAllowMoveStartTime &&
|
||||||
|
prev == null || prev.EndTime.TotalMilliseconds < p.EndTime.TotalMilliseconds - Configuration.Settings.General.SubtitleMinimumDisplayMilliseconds)
|
||||||
{
|
{
|
||||||
if (AllowFix(p, fixAction))
|
if (AllowFix(p, fixAction))
|
||||||
{
|
{
|
||||||
@ -922,7 +923,8 @@ namespace Nikse.SubtitleEdit.Forms
|
|||||||
AddFixToListView(p, fixAction, oldCurrent, p.ToString());
|
AddFixToListView(p, fixAction, oldCurrent, p.ToString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (temp.Duration.TotalMilliseconds - p.Duration.TotalMilliseconds < 1500 && (prev == null || prev.EndTime.TotalMilliseconds < p.EndTime.TotalMilliseconds - temp.Duration.TotalMilliseconds ))
|
else if (Configuration.Settings.Tools.FixShortDisplayTimesAllowMoveStartTime &&
|
||||||
|
temp.Duration.TotalMilliseconds - p.Duration.TotalMilliseconds < 1500 && (prev == null || prev.EndTime.TotalMilliseconds < p.EndTime.TotalMilliseconds - temp.Duration.TotalMilliseconds ))
|
||||||
{
|
{
|
||||||
if (AllowFix(p, fixAction))
|
if (AllowFix(p, fixAction))
|
||||||
{
|
{
|
||||||
|
@ -393,6 +393,9 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
FontEffect = "Effect",
|
FontEffect = "Effect",
|
||||||
FontEffectColor = "Effect color",
|
FontEffectColor = "Effect color",
|
||||||
FontSize = "Size",
|
FontSize = "Size",
|
||||||
|
TopBottomMargin = "Top/bottom margin",
|
||||||
|
ZPosition = "Z-position",
|
||||||
|
ZPositionHelp = "Positive numbers moves text away, negative numbers moves text closer, if z-position is zero then it's 2D",
|
||||||
ChooseColor = "Choose color...",
|
ChooseColor = "Choose color...",
|
||||||
Generate = "Generate",
|
Generate = "Generate",
|
||||||
};
|
};
|
||||||
|
@ -283,6 +283,9 @@
|
|||||||
public string FontEffect { get; set; }
|
public string FontEffect { get; set; }
|
||||||
public string FontEffectColor { get; set; }
|
public string FontEffectColor { get; set; }
|
||||||
public string FontSize { get; set; }
|
public string FontSize { get; set; }
|
||||||
|
public string TopBottomMargin { get; set; }
|
||||||
|
public string ZPosition { get; set; }
|
||||||
|
public string ZPositionHelp { get; set; }
|
||||||
public string ChooseColor { get; set; }
|
public string ChooseColor { get; set; }
|
||||||
public string Generate { get; set; }
|
public string Generate { get; set; }
|
||||||
}
|
}
|
||||||
|
@ -75,6 +75,7 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
public int EndSceneIndex { get; set; }
|
public int EndSceneIndex { get; set; }
|
||||||
public int VerifyPlaySeconds { get; set; }
|
public int VerifyPlaySeconds { get; set; }
|
||||||
public int MergeLinesShorterThan { get; set; }
|
public int MergeLinesShorterThan { get; set; }
|
||||||
|
public bool FixShortDisplayTimesAllowMoveStartTime { get; set; }
|
||||||
public string MusicSymbol { get; set; }
|
public string MusicSymbol { get; set; }
|
||||||
public string MusicSymbolToReplace { get; set; }
|
public string MusicSymbolToReplace { get; set; }
|
||||||
public string UnicodeSymbolsToInsert { get; set; }
|
public string UnicodeSymbolsToInsert { get; set; }
|
||||||
@ -150,6 +151,7 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
EndSceneIndex = 1;
|
EndSceneIndex = 1;
|
||||||
VerifyPlaySeconds = 2;
|
VerifyPlaySeconds = 2;
|
||||||
MergeLinesShorterThan = 33;
|
MergeLinesShorterThan = 33;
|
||||||
|
FixShortDisplayTimesAllowMoveStartTime = true;
|
||||||
MusicSymbol = "♪";
|
MusicSymbol = "♪";
|
||||||
MusicSymbolToReplace = "⪠ⶠ♪ âTª ã¢â™âª ?t×3 ?t¤3 #";
|
MusicSymbolToReplace = "⪠ⶠ♪ âTª ã¢â™âª ?t×3 ?t¤3 #";
|
||||||
UnicodeSymbolsToInsert = "♪;♫;☺;☹;♥;©;☮;☯;Σ;∞;≡;⇒;π";
|
UnicodeSymbolsToInsert = "♪;♫;☺;☹;♥;©;☮;☯;Σ;∞;≡;⇒;π";
|
||||||
@ -218,6 +220,7 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
public string DCinemaLoadFontResource { get; set; }
|
public string DCinemaLoadFontResource { get; set; }
|
||||||
public int DCinemaFontSize { get; set; }
|
public int DCinemaFontSize { get; set; }
|
||||||
public int DCinemaBottomMargin { get; set; }
|
public int DCinemaBottomMargin { get; set; }
|
||||||
|
public double DCinemaZPosition { get; set; }
|
||||||
public int DCinemaFadeUpDownTime { get; set; }
|
public int DCinemaFadeUpDownTime { get; set; }
|
||||||
|
|
||||||
public string CurrentDCinemaSubtitleId { get; set; }
|
public string CurrentDCinemaSubtitleId { get; set; }
|
||||||
@ -261,6 +264,7 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
DCinemaLoadFontResource = "urn:uuid:3dec6dc0-39d0-498d-97d0-928d2eb78391";
|
DCinemaLoadFontResource = "urn:uuid:3dec6dc0-39d0-498d-97d0-928d2eb78391";
|
||||||
DCinemaFontSize = 42;
|
DCinemaFontSize = 42;
|
||||||
DCinemaBottomMargin = 8;
|
DCinemaBottomMargin = 8;
|
||||||
|
DCinemaZPosition = 0;
|
||||||
DCinemaFadeUpDownTime = 5;
|
DCinemaFadeUpDownTime = 5;
|
||||||
|
|
||||||
SamiDisplayTwoClassesAsTwoSubtitles = true;
|
SamiDisplayTwoClassesAsTwoSubtitles = true;
|
||||||
@ -1415,6 +1419,9 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
subNode = node.SelectSingleNode("MergeLinesShorterThan");
|
subNode = node.SelectSingleNode("MergeLinesShorterThan");
|
||||||
if (subNode != null)
|
if (subNode != null)
|
||||||
settings.Tools.MergeLinesShorterThan = Convert.ToInt32(subNode.InnerText);
|
settings.Tools.MergeLinesShorterThan = Convert.ToInt32(subNode.InnerText);
|
||||||
|
subNode = node.SelectSingleNode("FixShortDisplayTimesAllowMoveStartTime");
|
||||||
|
if (subNode != null)
|
||||||
|
settings.Tools.FixShortDisplayTimesAllowMoveStartTime = Convert.ToBoolean(subNode.InnerText);
|
||||||
subNode = node.SelectSingleNode("MusicSymbol");
|
subNode = node.SelectSingleNode("MusicSymbol");
|
||||||
if (subNode != null)
|
if (subNode != null)
|
||||||
settings.Tools.MusicSymbol = subNode.InnerText;
|
settings.Tools.MusicSymbol = subNode.InnerText;
|
||||||
@ -1647,7 +1654,10 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
settings.SubtitleSettings.DCinemaFontSize = Convert.ToInt32(subNode.InnerText);
|
settings.SubtitleSettings.DCinemaFontSize = Convert.ToInt32(subNode.InnerText);
|
||||||
subNode = node.SelectSingleNode("DCinemaBottomMargin");
|
subNode = node.SelectSingleNode("DCinemaBottomMargin");
|
||||||
if (subNode != null)
|
if (subNode != null)
|
||||||
settings.SubtitleSettings.DCinemaBottomMargin = Convert.ToInt32(subNode.InnerText);
|
settings.SubtitleSettings.DCinemaBottomMargin = Convert.ToInt32(subNode.InnerText, CultureInfo.InvariantCulture);
|
||||||
|
subNode = node.SelectSingleNode("DCinemaZPosition");
|
||||||
|
if (subNode != null)
|
||||||
|
settings.SubtitleSettings.DCinemaZPosition = Convert.ToDouble(subNode.InnerText);
|
||||||
subNode = node.SelectSingleNode("DCinemaFadeUpDownTime");
|
subNode = node.SelectSingleNode("DCinemaFadeUpDownTime");
|
||||||
if (subNode != null)
|
if (subNode != null)
|
||||||
settings.SubtitleSettings.DCinemaFadeUpDownTime = Convert.ToInt32(subNode.InnerText);
|
settings.SubtitleSettings.DCinemaFadeUpDownTime = Convert.ToInt32(subNode.InnerText);
|
||||||
@ -2559,6 +2569,7 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
textWriter.WriteElementString("EndSceneIndex", settings.Tools.EndSceneIndex.ToString());
|
textWriter.WriteElementString("EndSceneIndex", settings.Tools.EndSceneIndex.ToString());
|
||||||
textWriter.WriteElementString("VerifyPlaySeconds", settings.Tools.VerifyPlaySeconds.ToString());
|
textWriter.WriteElementString("VerifyPlaySeconds", settings.Tools.VerifyPlaySeconds.ToString());
|
||||||
textWriter.WriteElementString("MergeLinesShorterThan", settings.Tools.MergeLinesShorterThan.ToString());
|
textWriter.WriteElementString("MergeLinesShorterThan", settings.Tools.MergeLinesShorterThan.ToString());
|
||||||
|
textWriter.WriteElementString("FixShortDisplayTimesAllowMoveStartTime", settings.Tools.FixShortDisplayTimesAllowMoveStartTime.ToString());
|
||||||
textWriter.WriteElementString("MusicSymbol", settings.Tools.MusicSymbol);
|
textWriter.WriteElementString("MusicSymbol", settings.Tools.MusicSymbol);
|
||||||
textWriter.WriteElementString("MusicSymbolToReplace", settings.Tools.MusicSymbolToReplace);
|
textWriter.WriteElementString("MusicSymbolToReplace", settings.Tools.MusicSymbolToReplace);
|
||||||
textWriter.WriteElementString("UnicodeSymbolsToInsert", settings.Tools.UnicodeSymbolsToInsert);
|
textWriter.WriteElementString("UnicodeSymbolsToInsert", settings.Tools.UnicodeSymbolsToInsert);
|
||||||
@ -2639,6 +2650,7 @@ namespace Nikse.SubtitleEdit.Logic
|
|||||||
textWriter.WriteElementString("DCinemaFontFile", settings.SubtitleSettings.DCinemaFontFile);
|
textWriter.WriteElementString("DCinemaFontFile", settings.SubtitleSettings.DCinemaFontFile);
|
||||||
textWriter.WriteElementString("DCinemaFontSize", settings.SubtitleSettings.DCinemaFontSize.ToString());
|
textWriter.WriteElementString("DCinemaFontSize", settings.SubtitleSettings.DCinemaFontSize.ToString());
|
||||||
textWriter.WriteElementString("DCinemaBottomMargin", settings.SubtitleSettings.DCinemaBottomMargin.ToString());
|
textWriter.WriteElementString("DCinemaBottomMargin", settings.SubtitleSettings.DCinemaBottomMargin.ToString());
|
||||||
|
textWriter.WriteElementString("DCinemaZPosition", settings.SubtitleSettings.DCinemaZPosition.ToString(CultureInfo.InvariantCulture));
|
||||||
textWriter.WriteElementString("DCinemaFadeUpDownTime", settings.SubtitleSettings.DCinemaFadeUpDownTime.ToString());
|
textWriter.WriteElementString("DCinemaFadeUpDownTime", settings.SubtitleSettings.DCinemaFadeUpDownTime.ToString());
|
||||||
textWriter.WriteElementString("SamiDisplayTwoClassesAsTwoSubtitles", settings.SubtitleSettings.SamiDisplayTwoClassesAsTwoSubtitles.ToString());
|
textWriter.WriteElementString("SamiDisplayTwoClassesAsTwoSubtitles", settings.SubtitleSettings.SamiDisplayTwoClassesAsTwoSubtitles.ToString());
|
||||||
textWriter.WriteElementString("SamiFullHtmlEncode", settings.SubtitleSettings.SamiFullHtmlEncode.ToString());
|
textWriter.WriteElementString("SamiFullHtmlEncode", settings.SubtitleSettings.SamiFullHtmlEncode.ToString());
|
||||||
|
@ -210,6 +210,13 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
|||||||
vPosition.InnerText = vPos.ToString();
|
vPosition.InnerText = vPos.ToString();
|
||||||
textNode.Attributes.Append(vPosition);
|
textNode.Attributes.Append(vPosition);
|
||||||
|
|
||||||
|
if (Configuration.Settings.SubtitleSettings.DCinemaZPosition != 0)
|
||||||
|
{
|
||||||
|
XmlAttribute zPosition = xml.CreateAttribute("ZPosition");
|
||||||
|
zPosition.InnerText = string.Format(CultureInfo.InvariantCulture, "{0:0.00}", Configuration.Settings.SubtitleSettings.DCinemaZPosition);
|
||||||
|
textNode.Attributes.Append(zPosition);
|
||||||
|
}
|
||||||
|
|
||||||
XmlAttribute vAlign = xml.CreateAttribute("VAlign");
|
XmlAttribute vAlign = xml.CreateAttribute("VAlign");
|
||||||
if (alignVTop)
|
if (alignVTop)
|
||||||
vAlign.InnerText = "top";
|
vAlign.InnerText = "top";
|
||||||
|
@ -111,6 +111,7 @@ namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
|||||||
new SwiftTextLineNumber(),
|
new SwiftTextLineNumber(),
|
||||||
new Tek(),
|
new Tek(),
|
||||||
new TimeXml(),
|
new TimeXml(),
|
||||||
|
new TimeXml2(),
|
||||||
new TimedText10(),
|
new TimedText10(),
|
||||||
new TimedText200604(),
|
new TimedText200604(),
|
||||||
new TimedText(),
|
new TimedText(),
|
||||||
|
128
src/Logic/SubtitleFormats/TimeXml2.cs
Normal file
128
src/Logic/SubtitleFormats/TimeXml2.cs
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
|
using System.Text;
|
||||||
|
using System.Xml;
|
||||||
|
|
||||||
|
namespace Nikse.SubtitleEdit.Logic.SubtitleFormats
|
||||||
|
{
|
||||||
|
public class TimeXml2 : SubtitleFormat
|
||||||
|
{
|
||||||
|
public override string Extension
|
||||||
|
{
|
||||||
|
get { return ".xml"; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string Name
|
||||||
|
{
|
||||||
|
get { return "Xml 2"; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public override bool IsTimeBased
|
||||||
|
{
|
||||||
|
get { return true; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public override bool IsMine(List<string> lines, string fileName)
|
||||||
|
{
|
||||||
|
Subtitle subtitle = new Subtitle();
|
||||||
|
this.LoadSubtitle(subtitle, lines, fileName);
|
||||||
|
return subtitle.Paragraphs.Count > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string ToText(Subtitle subtitle, string title)
|
||||||
|
{
|
||||||
|
string xmlStructure =
|
||||||
|
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>" + Environment.NewLine +
|
||||||
|
"<Subtitles/>";
|
||||||
|
|
||||||
|
XmlDocument xml = new XmlDocument();
|
||||||
|
xml.LoadXml(xmlStructure);
|
||||||
|
|
||||||
|
foreach (Paragraph p in subtitle.Paragraphs)
|
||||||
|
{
|
||||||
|
XmlNode paragraph = xml.CreateElement("Subtitle");
|
||||||
|
|
||||||
|
XmlNode number = xml.CreateElement("Number");
|
||||||
|
number.InnerText = p.Number.ToString();
|
||||||
|
paragraph.AppendChild(number);
|
||||||
|
|
||||||
|
XmlNode start = xml.CreateElement("Start");
|
||||||
|
start.InnerText = p.StartTime.ToString();
|
||||||
|
paragraph.AppendChild(start);
|
||||||
|
|
||||||
|
XmlNode end = xml.CreateElement("End");
|
||||||
|
end.InnerText = p.EndTime.ToString();
|
||||||
|
paragraph.AppendChild(end);
|
||||||
|
|
||||||
|
XmlNode duration = xml.CreateElement("Duration");
|
||||||
|
duration.InnerText = p.Duration.ToShortString();
|
||||||
|
paragraph.AppendChild(duration);
|
||||||
|
|
||||||
|
XmlNode text = xml.CreateElement("Text");
|
||||||
|
text.InnerText = Utilities.RemoveHtmlTags(p.Text);
|
||||||
|
paragraph.AppendChild(text);
|
||||||
|
|
||||||
|
xml.DocumentElement.AppendChild(paragraph);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ToUtf8XmlString(xml);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void LoadSubtitle(Subtitle subtitle, List<string> lines, string fileName)
|
||||||
|
{
|
||||||
|
_errorCount = 0;
|
||||||
|
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
lines.ForEach(line => sb.AppendLine(line));
|
||||||
|
|
||||||
|
string xmlString = sb.ToString();
|
||||||
|
if (!xmlString.Contains("<Subtitles>") || !xmlString.Contains("<Text>") || !xmlString.Contains("<Duration>"))
|
||||||
|
return;
|
||||||
|
|
||||||
|
XmlDocument xml = new XmlDocument();
|
||||||
|
try
|
||||||
|
{
|
||||||
|
xml.LoadXml(xmlString);
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
_errorCount = 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (XmlNode node in xml.DocumentElement.SelectNodes("Subtitle"))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
TimeCode startTimeCode = DecodeTimeCode(node.SelectSingleNode("Start").InnerText);
|
||||||
|
TimeCode endTimeCode = DecodeTimeCode(node.SelectSingleNode("End").InnerText);
|
||||||
|
string text = node.SelectSingleNode("Text").InnerText;
|
||||||
|
subtitle.Paragraphs.Add(new Paragraph(startTimeCode, endTimeCode, text));
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
System.Diagnostics.Debug.WriteLine(ex.Message);
|
||||||
|
_errorCount++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
subtitle.Renumber(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
private TimeCode DecodeTimeCode(string p)
|
||||||
|
{
|
||||||
|
var parts = p.Split(";.:,".ToCharArray());
|
||||||
|
|
||||||
|
string hour = parts[0];
|
||||||
|
string minutes = parts[1];
|
||||||
|
string seconds = parts[2];
|
||||||
|
string ms = parts[3];
|
||||||
|
|
||||||
|
TimeCode tc = new TimeCode(int.Parse(hour), int.Parse(minutes), int.Parse(seconds), (int.Parse(ms)));
|
||||||
|
return tc;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -876,6 +876,7 @@
|
|||||||
<Compile Include="Logic\SubtitleFormats\CaraokeXml.cs" />
|
<Compile Include="Logic\SubtitleFormats\CaraokeXml.cs" />
|
||||||
<Compile Include="Logic\SubtitleFormats\Cavena890.cs" />
|
<Compile Include="Logic\SubtitleFormats\Cavena890.cs" />
|
||||||
<Compile Include="Logic\SubtitleFormats\CheetahCaption.cs" />
|
<Compile Include="Logic\SubtitleFormats\CheetahCaption.cs" />
|
||||||
|
<Compile Include="Logic\SubtitleFormats\TimeXml2.cs" />
|
||||||
<Compile Include="Logic\SubtitleFormats\OresmeDocXDocument.cs" />
|
<Compile Include="Logic\SubtitleFormats\OresmeDocXDocument.cs" />
|
||||||
<Compile Include="Logic\SubtitleFormats\UnknownSubtitle68.cs" />
|
<Compile Include="Logic\SubtitleFormats\UnknownSubtitle68.cs" />
|
||||||
<Compile Include="Logic\SubtitleFormats\FinalCutProXml13.cs" />
|
<Compile Include="Logic\SubtitleFormats\FinalCutProXml13.cs" />
|
||||||
|
@ -41,7 +41,16 @@ namespace Test
|
|||||||
{
|
{
|
||||||
string s1 = "Gledaj prema kameri i rici <i>zdravo!";
|
string s1 = "Gledaj prema kameri i rici <i>zdravo!";
|
||||||
string s2 = Utilities.FixInvalidItalicTags(s1);
|
string s2 = Utilities.FixInvalidItalicTags(s1);
|
||||||
Assert.AreEqual(s1.Replace("<i>", string.Empty), s2);
|
Assert.AreEqual(s2, "Gledaj prema kameri i rici zdravo!");
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
[DeploymentItem("SubtitleEdit.exe")]
|
||||||
|
public void FixInvalidItalicTags3()
|
||||||
|
{
|
||||||
|
string s1 = "<i>Line 1.</i>" + Environment.NewLine + "<i>Line 2.";
|
||||||
|
string s2 = Utilities.FixInvalidItalicTags(s1);
|
||||||
|
Assert.AreEqual(s2, "<i>Line 1." + Environment.NewLine + "Line 2.</i>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user