[longomatch/gameunits] Add a base class for time lines
- From: Andoni Morales Alastruey <amorales src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [longomatch/gameunits] Add a base class for time lines
- Date: Mon, 5 Dec 2011 21:06:08 +0000 (UTC)
commit 76085216c593294b6adf8a62b8fb190e69013c99
Author: Andoni Morales Alastruey <ylatuya gmail com>
Date: Thu Nov 24 22:50:48 2011 +0100
Add a base class for time lines
LongoMatch.GUI/Gui/Base/TimelineWidgetBase.cs | 200 ++++++++++++
LongoMatch.GUI/Gui/Component/TimeLineWidget.cs | 147 +--------
LongoMatch.GUI/LongoMatch.GUI.mdp | 3 +-
LongoMatch.GUI/Makefile.am | 5 +-
...s => LongoMatch.Gui.Base.TimelineWidgetBase.cs} | 22 +-
.../gtk-gui/LongoMatch.Gui.MainWindow.cs | 2 +-
LongoMatch.GUI/gtk-gui/gui.stetic | 341 ++++++++++----------
LongoMatch.GUI/gtk-gui/objects.xml | 58 +++-
8 files changed, 442 insertions(+), 336 deletions(-)
---
diff --git a/LongoMatch.GUI/Gui/Base/TimelineWidgetBase.cs b/LongoMatch.GUI/Gui/Base/TimelineWidgetBase.cs
new file mode 100644
index 0000000..0c5a20b
--- /dev/null
+++ b/LongoMatch.GUI/Gui/Base/TimelineWidgetBase.cs
@@ -0,0 +1,200 @@
+//
+// Copyright (C) 2011 Andoni Morales Alastruey
+//
+// This program is free software; you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation; either version 2 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; if not, write to the Free Software
+// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+using System;
+using System.Collections.Generic;
+
+using LongoMatch.Interfaces;
+using LongoMatch.Gui.Base;
+using LongoMatch.Gui.Component;
+using Gtk;
+
+namespace LongoMatch.Gui.Base
+{
+ [System.ComponentModel.ToolboxItem(true)]
+ public partial class TimelineWidgetBase : Gtk.Bin
+ {
+ protected TimeReferenceWidget tr;
+ protected CategoriesScale cs;
+ protected uint currentFrame, pixelRatio, frames;
+ protected bool loaded;
+
+ public TimelineWidgetBase ()
+ {
+ this.Build ();
+
+ tr = new TimeReferenceWidget();
+ cs = new CategoriesScale();
+
+ cs.WidthRequest = 100;
+ toolsbox.HeightRequest = 50 - leftbox.Spacing;
+ tr.HeightRequest = 50 - leftbox.Spacing;
+
+ categoriesbox.PackStart(cs, false, false, 0);
+ timelinebox.PackStart(tr,false,false,0);
+
+ zoomscale.CanFocus = false;
+ loaded = false;
+ frames = 0;
+
+ ScrolledWindow.Vadjustment.ValueChanged += HandleScrollEvent;
+ ScrolledWindow.Hadjustment.ValueChanged += HandleScrollEvent;
+ ScrolledWindow.HScrollbar.SizeAllocated += OnSizeAllocated;
+ }
+
+ public ScrolledWindow ScrolledWindow {
+ get {
+ return GtkScrolledWindow;
+ }
+ }
+
+ public Box TimelineBox {
+ get{
+ return timelinebox;
+ }
+ }
+
+ public Scale ZoomScale {
+ get{
+ return zoomscale;
+ }
+ }
+
+ public Alignment Alignment {
+ get{
+ return categoriesalignment1;
+ }
+ }
+
+ public void AdjustPostion(uint currentframe) {
+ int visibleWidth;
+ int realWidth;
+ uint pos;
+ int scrollbarWidth;
+ if(Visible) {
+ scrollbarWidth= ScrolledWindow.VScrollbar.Allocation.Width;
+ visibleWidth = ScrolledWindow.Allocation.Width-scrollbarWidth;
+ realWidth = TimelineBox.Allocation.Width;
+ pos = currentframe/pixelRatio;
+ if(pos+visibleWidth < realWidth) {
+ ScrolledWindow.Hadjustment.Value = pos;
+ }
+ else {
+ ScrolledWindow.Hadjustment.Value = realWidth-visibleWidth-20;
+ }
+ }
+ }
+
+ protected virtual void HandleScrollEvent(object sender, System.EventArgs args)
+ {
+ if(sender == ScrolledWindow.Vadjustment)
+ cs.Scroll = ScrolledWindow.Vadjustment.Value;
+ else if(sender == ScrolledWindow.Hadjustment)
+ tr.Scroll = ScrolledWindow.Hadjustment.Value;
+ }
+
+ protected virtual void OnSizeAllocated(object sender, SizeAllocatedArgs e)
+ {
+ /* Align the categories list widget on top of the timeline's horizontal bar */
+ if(sender == ScrolledWindow.HScrollbar)
+ Alignment.BottomPadding = (uint) ScrolledWindow.HScrollbar.Allocation.Height;
+ }
+
+ }
+
+ [System.ComponentModel.ToolboxItem(true)]
+ public partial class TimelineBase <W, Z> : TimelineWidgetBase where Z:ITimelineNode where W: TimeScaleBase<Z>
+ {
+ protected Dictionary<object, W> tsList;
+ protected Z selected;
+
+ public TimelineBase (): base()
+ {
+ SetPixelRatio(10);
+ tsList = new Dictionary<object, W>();
+ }
+
+ public Z SelectedTimeNode {
+ get {
+ return selected;
+ }
+ set {
+ if(!loaded)
+ return;
+
+ selected = value;
+ foreach(W ts in tsList.Values)
+ ts.SelectedTimeNode = value;
+ if(selected != null) {
+ if(SelectedTimeNode.StartFrame/pixelRatio < ScrolledWindow.Hadjustment.Value ||
+ SelectedTimeNode.StartFrame/pixelRatio > ScrolledWindow.Hadjustment.Value +
+ ScrolledWindow.Allocation.Width - ScrolledWindow.VScrollbar.Allocation.Width)
+ AdjustPostion(SelectedTimeNode.StartFrame);
+ }
+ QueueDraw();
+ }
+ }
+
+ public uint CurrentFrame {
+ get {
+ return currentFrame;
+ }
+ set {
+ if(!loaded)
+ return;
+
+ currentFrame = value;
+ foreach(W ts in tsList.Values)
+ ts.CurrentFrame = value;
+ tr.CurrentFrame = value;
+ QueueDraw();
+ }
+ }
+
+ protected void SetPixelRatio(uint pixelRatio) {
+ if(!loaded)
+ return;
+
+ this.pixelRatio = pixelRatio;
+ tr.PixelRatio = pixelRatio;
+ foreach(W ts in tsList.Values)
+ ts.PixelRatio = pixelRatio;
+ ZoomScale.Value=pixelRatio;
+ }
+
+ protected void ResetGui() {
+ //Unrealize all children
+ foreach(Widget w in TimelineBox.AllChildren) {
+ TimelineBox.Remove(w);
+ w.Destroy();
+ }
+ }
+
+ protected virtual void OnFitbuttonClicked(object sender, System.EventArgs e)
+ {
+ AdjustPostion(currentFrame);
+ }
+
+ protected virtual void OnZoomscaleValueChanged(object sender, System.EventArgs e)
+ {
+ SetPixelRatio((uint)(ZoomScale.Value));
+ QueueDraw();
+ AdjustPostion(currentFrame);
+ }
+ }
+}
+
diff --git a/LongoMatch.GUI/Gui/Component/TimeLineWidget.cs b/LongoMatch.GUI/Gui/Component/TimeLineWidget.cs
index 5efd169..aec0c2a 100644
--- a/LongoMatch.GUI/Gui/Component/TimeLineWidget.cs
+++ b/LongoMatch.GUI/Gui/Component/TimeLineWidget.cs
@@ -20,6 +20,8 @@
using System;
using System.Collections.Generic;
using Gtk;
+
+using LongoMatch.Gui.Base;
using LongoMatch.Handlers;
using LongoMatch.Store;
using LongoMatch.Store.Templates;
@@ -28,113 +30,18 @@ namespace LongoMatch.Gui.Component {
[System.ComponentModel.Category("LongoMatch")]
[System.ComponentModel.ToolboxItem(true)]
- public partial class TimeLineWidget : Gtk.Bin
+ public class TimeLineWidget : TimelineBase<TimeScale, Play>
{
public event TimeNodeChangedHandler TimeNodeChanged;
public event PlaySelectedHandler TimeNodeSelected;
public event PlaysDeletedHandler TimeNodeDeleted;
public event NewTagAtFrameHandler NewMarkEvent;
- //public event PlayListNodeAddedHandler PlayListNodeAdded;
- private Dictionary<Category,TimeScale> tsList;
private Categories categories;
- private TimeReferenceWidget tr;
- CategoriesScale cs;
- private uint frames;
- private uint pixelRatio;
- private Play selected;
- private uint currentFrame;
- private bool hasProject;
-
- public TimeLineWidget()
+ public TimeLineWidget(): base()
{
- this.Build();
- SetPixelRatio(10);
- zoomscale.CanFocus = false;
-
- GtkScrolledWindow.Vadjustment.ValueChanged += HandleScrollEvent;
- GtkScrolledWindow.Hadjustment.ValueChanged += HandleScrollEvent;
-
- GtkScrolledWindow.HScrollbar.SizeAllocated += OnSizeAllocated;
-
- cs = new CategoriesScale();
- cs.WidthRequest = 100;
- categoriesbox.PackStart(cs, false, false, 0);
-
- tr = new TimeReferenceWidget();
- timescalebox.PackStart(tr,false,false,0);
-
- tr.HeightRequest = 50 - leftbox.Spacing;
- toolsbox.HeightRequest = 50 - leftbox.Spacing;
- }
-
- public Play SelectedTimeNode {
- get {
- return selected;
- }
- set {
- if(!hasProject)
- return;
-
- selected = value;
- foreach(TimeScale ts in tsList.Values)
- ts.SelectedTimeNode = value;
- if(selected != null) {
- if(SelectedTimeNode.StartFrame/pixelRatio < GtkScrolledWindow.Hadjustment.Value ||
- SelectedTimeNode.StartFrame/pixelRatio > GtkScrolledWindow.Hadjustment.Value +
- GtkScrolledWindow.Allocation.Width - GtkScrolledWindow.VScrollbar.Allocation.Width)
- AdjustPostion(SelectedTimeNode.StartFrame);
- }
- QueueDraw();
- }
- }
-
- public uint CurrentFrame {
- get {
- return currentFrame;
- }
- set {
- if(!hasProject)
- return;
-
- currentFrame = value;
- foreach(TimeScale ts in tsList.Values)
- ts.CurrentFrame = value;
- tr.CurrentFrame = value;
- QueueDraw();
- }
- }
-
- public void AdjustPostion(uint currentframe) {
- int visibleWidth;
- int realWidth;
- uint pos;
- int scrollbarWidth;
- if(Visible) {
- scrollbarWidth= GtkScrolledWindow.VScrollbar.Allocation.Width;
- visibleWidth = GtkScrolledWindow.Allocation.Width-scrollbarWidth;
- realWidth = vbox1.Allocation.Width;
- pos = currentframe/pixelRatio;
- if(pos+visibleWidth < realWidth) {
- GtkScrolledWindow.Hadjustment.Value = pos;
- }
- else {
- GtkScrolledWindow.Hadjustment.Value = realWidth-visibleWidth-20;
- }
- }
- }
-
- private void SetPixelRatio(uint pixelRatio) {
- if(!hasProject)
- return;
-
- this.pixelRatio = pixelRatio;
- tr.PixelRatio = pixelRatio;
- foreach(TimeScale ts in tsList.Values)
- ts.PixelRatio = pixelRatio;
- zoomscale.Value=pixelRatio;
}
public Project Project {
@@ -145,12 +52,12 @@ namespace LongoMatch.Gui.Component {
categories = null;
tsList.Clear();
tsList=null;
- hasProject = false;
+ loaded = false;
return;
}
- hasProject = true;
+ loaded = true;
categories = value.Categories;
- tsList = new Dictionary<Category, TimeScale>();
+ tsList.Clear();
frames = value.Description.File.GetFrames();
cs.Categories = categories;
@@ -168,7 +75,7 @@ namespace LongoMatch.Gui.Component {
ts.TimeNodeSelected += new PlaySelectedHandler(OnTimeNodeSelected);
ts.TimeNodeDeleted += new PlaysDeletedHandler(OnTimeNodeDeleted);
ts.NewMarkAtFrameEvent += new NewTagAtFrameHandler(OnNewMark);
- vbox1.PackStart(ts,true,true,0);
+ TimelineBox.PackStart(ts,true,true,0);
ts.Show();
}
SetPixelRatio(3);
@@ -187,16 +94,8 @@ namespace LongoMatch.Gui.Component {
if(tsList.TryGetValue(play.Category, out ts))
ts.RemovePlay(play);
}
-
- }
- private void ResetGui() {
- //Unrealize all children
- foreach(Widget w in vbox1.AllChildren) {
- vbox1.Remove(w);
- w.Destroy();
- }
}
-
+
protected virtual void OnNewMark(Category category, int frame) {
if(NewMarkEvent != null)
NewMarkEvent(category,frame);
@@ -211,36 +110,10 @@ namespace LongoMatch.Gui.Component {
if(TimeNodeSelected != null)
TimeNodeSelected(tn);
}
+
protected virtual void OnTimeNodeDeleted(List<Play> plays) {
if(TimeNodeDeleted != null)
TimeNodeDeleted(plays);
}
-
- protected virtual void OnFitbuttonClicked(object sender, System.EventArgs e)
- {
- AdjustPostion(currentFrame);
- }
-
- protected virtual void OnZoomscaleValueChanged(object sender, System.EventArgs e)
- {
- SetPixelRatio((uint)(zoomscale.Value));
- QueueDraw();
- AdjustPostion(currentFrame);
- }
-
- protected virtual void HandleScrollEvent(object sender, System.EventArgs args)
- {
- if(sender == GtkScrolledWindow.Vadjustment)
- cs.Scroll = GtkScrolledWindow.Vadjustment.Value;
- else if(sender == GtkScrolledWindow.Hadjustment)
- tr.Scroll = GtkScrolledWindow.Hadjustment.Value;
- }
-
- protected virtual void OnSizeAllocated(object sender, SizeAllocatedArgs e)
- {
- /* Align the categories list widget on top of the timeline's horizontal bar */
- if(sender == GtkScrolledWindow.HScrollbar)
- categoriesalignment1.BottomPadding = (uint) GtkScrolledWindow.HScrollbar.Allocation.Height;
- }
}
}
diff --git a/LongoMatch.GUI/LongoMatch.GUI.mdp b/LongoMatch.GUI/LongoMatch.GUI.mdp
index 91e3bad..31ad85c 100644
--- a/LongoMatch.GUI/LongoMatch.GUI.mdp
+++ b/LongoMatch.GUI/LongoMatch.GUI.mdp
@@ -80,7 +80,6 @@
<File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Component.CategoryProperties.cs" />
<File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Component.PlayListWidget.cs" />
<File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Dialog.EntryDialog.cs" />
- <File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Component.TimeLineWidget.cs" />
<File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Dialog.VideoEditionProperties.cs" />
<File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Dialog.SnapshotsDialog.cs" />
<File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Component.NotesWidget.cs" />
@@ -147,6 +146,8 @@
<File subtype="Directory" buildaction="Compile" name="Gui/Component" />
<File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Base.TemplatesEditorBase.cs" />
<File subtype="Code" buildaction="Compile" name="Gui/Component/GameUnitTimeScale.cs" />
+ <File subtype="Code" buildaction="Compile" name="Gui/Base/TimelineWidgetBase.cs" />
+ <File subtype="Code" buildaction="Compile" name="gtk-gui/LongoMatch.Gui.Base.TimelineWidgetBase.cs" />
</Contents>
<MonoDevelop.Autotools.MakefileInfo RelativeMakefileName="../CesarPlayer/Makefile.am" RelativeConfigureInPath="../">
<BuildFilesVar Name="FILES" />
diff --git a/LongoMatch.GUI/Makefile.am b/LongoMatch.GUI/Makefile.am
index e15620c..cc3a394 100644
--- a/LongoMatch.GUI/Makefile.am
+++ b/LongoMatch.GUI/Makefile.am
@@ -6,6 +6,7 @@ LINK = $(REF_DEP_LONGOMATCH_GUI)
SOURCES = \
gtk-gui/generated.cs \
gtk-gui/LongoMatch.Gui.Base.TemplatesEditorBase.cs \
+ gtk-gui/LongoMatch.Gui.Base.TimelineWidgetBase.cs \
gtk-gui/LongoMatch.Gui.Component.ButtonsWidget.cs \
gtk-gui/LongoMatch.Gui.Component.CategoryProperties.cs \
gtk-gui/LongoMatch.Gui.Component.DrawingToolBox.cs \
@@ -26,7 +27,6 @@ SOURCES = \
gtk-gui/LongoMatch.Gui.Component.TaggerWidget.cs \
gtk-gui/LongoMatch.Gui.Component.TagsTreeWidget.cs \
gtk-gui/LongoMatch.Gui.Component.TeamTaggerWidget.cs \
- gtk-gui/LongoMatch.Gui.Component.TimeLineWidget.cs \
gtk-gui/LongoMatch.Gui.Dialog.BusyDialog.cs \
gtk-gui/LongoMatch.Gui.Dialog.DrawingTool.cs \
gtk-gui/LongoMatch.Gui.Dialog.EditCategoryDialog.cs \
@@ -52,8 +52,9 @@ SOURCES = \
gtk-gui/LongoMatch.Gui.MainWindow.cs \
gtk-gui/LongoMatch.Gui.Popup.CalendarPopup.cs \
gtk-gui/LongoMatch.Gui.Popup.TransparentDrawingArea.cs \
- Gui/Base/TimeScaleBase.cs \
Gui/Base/TemplatesEditorBase.cs \
+ Gui/Base/TimelineWidgetBase.cs \
+ Gui/Base/TimeScaleBase.cs \
Gui/Component/ButtonsWidget.cs \
Gui/Component/CategoriesScale.cs \
Gui/Component/CategoriesTemplateEditor.cs \
diff --git a/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.Component.TimeLineWidget.cs b/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.Base.TimelineWidgetBase.cs
similarity index 91%
rename from LongoMatch.GUI/gtk-gui/LongoMatch.Gui.Component.TimeLineWidget.cs
rename to LongoMatch.GUI/gtk-gui/LongoMatch.Gui.Base.TimelineWidgetBase.cs
index 4c72a59..880813a 100644
--- a/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.Component.TimeLineWidget.cs
+++ b/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.Base.TimelineWidgetBase.cs
@@ -1,8 +1,8 @@
// This file has been generated by the GUI designer. Do not modify.
-namespace LongoMatch.Gui.Component
+namespace LongoMatch.Gui.Base
{
- public partial class TimeLineWidget
+ public partial class TimelineWidgetBase
{
private global::Gtk.VBox vbox3;
private global::Gtk.HSeparator hseparator1;
@@ -17,15 +17,15 @@ namespace LongoMatch.Gui.Component
private global::Gtk.VBox vbox2;
private global::Gtk.VBox timescalebox;
private global::Gtk.ScrolledWindow GtkScrolledWindow;
- private global::Gtk.VBox vbox1;
+ private global::Gtk.VBox timelinebox;
protected virtual void Build ()
{
global::Stetic.Gui.Initialize (this);
- // Widget LongoMatch.Gui.Component.TimeLineWidget
+ // Widget LongoMatch.Gui.Base.TimelineWidgetBase
global::Stetic.BinContainer.Attach (this);
- this.Name = "LongoMatch.Gui.Component.TimeLineWidget";
- // Container child LongoMatch.Gui.Component.TimeLineWidget.Gtk.Container+ContainerChild
+ this.Name = "LongoMatch.Gui.Base.TimelineWidgetBase";
+ // Container child LongoMatch.Gui.Base.TimelineWidgetBase.Gtk.Container+ContainerChild
this.vbox3 = new global::Gtk.VBox ();
this.vbox3.Name = "vbox3";
this.vbox3.Spacing = 6;
@@ -137,9 +137,9 @@ namespace LongoMatch.Gui.Component
global::Gtk.Viewport w18 = new global::Gtk.Viewport ();
w18.ShadowType = ((global::Gtk.ShadowType)(0));
// Container child GtkViewport.Gtk.Container+ContainerChild
- this.vbox1 = new global::Gtk.VBox ();
- this.vbox1.Name = "vbox1";
- w18.Add (this.vbox1);
+ this.timelinebox = new global::Gtk.VBox ();
+ this.timelinebox.Name = "timelinebox";
+ w18.Add (this.timelinebox);
this.GtkScrolledWindow.Add (w18);
this.vbox2.Add (this.GtkScrolledWindow);
global::Gtk.Box.BoxChild w21 = ((global::Gtk.Box.BoxChild)(this.vbox2 [this.GtkScrolledWindow]));
@@ -154,9 +154,7 @@ namespace LongoMatch.Gui.Component
if ((this.Child != null)) {
this.Child.ShowAll ();
}
- this.Show ();
- this.fitbutton.Clicked += new global::System.EventHandler (this.OnFitbuttonClicked);
- this.zoomscale.ValueChanged += new global::System.EventHandler (this.OnZoomscaleValueChanged);
+ this.Hide ();
}
}
}
diff --git a/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.MainWindow.cs b/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.MainWindow.cs
index 030c9c6..fd091c9 100644
--- a/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.MainWindow.cs
+++ b/LongoMatch.GUI/gtk-gui/LongoMatch.Gui.MainWindow.cs
@@ -139,7 +139,7 @@ namespace LongoMatch.Gui
this.ImportProjectAction.ShortLabel = global::Mono.Unix.Catalog.GetString ("_Import Project");
w1.Add (this.ImportProjectAction, "<Control>i");
this.ManualTaggingViewAction = new global::Gtk.RadioAction ("ManualTaggingViewAction", global::Mono.Unix.Catalog.GetString ("Manual tagging view"), null, null, 0);
- this.ManualTaggingViewAction.Group = this.TaggingViewAction.Group;
+ this.ManualTaggingViewAction.Group = this.TimelineViewAction.Group;
this.ManualTaggingViewAction.Sensitive = false;
this.ManualTaggingViewAction.ShortLabel = global::Mono.Unix.Catalog.GetString ("Free Capture Mode");
w1.Add (this.ManualTaggingViewAction, "<Control>f");
diff --git a/LongoMatch.GUI/gtk-gui/gui.stetic b/LongoMatch.GUI/gtk-gui/gui.stetic
index f217339..aca3d2c 100644
--- a/LongoMatch.GUI/gtk-gui/gui.stetic
+++ b/LongoMatch.GUI/gtk-gui/gui.stetic
@@ -3008,174 +3008,6 @@ new one.</property>
</widget>
</child>
</widget>
- <widget class="Gtk.Bin" id="LongoMatch.Gui.Component.TimeLineWidget" design-size="535 229">
- <property name="MemberName" />
- <child>
- <widget class="Gtk.VBox" id="vbox3">
- <property name="MemberName" />
- <property name="Spacing">6</property>
- <child>
- <widget class="Gtk.HSeparator" id="hseparator1">
- <property name="MemberName" />
- </widget>
- <packing>
- <property name="Position">0</property>
- <property name="AutoSize">True</property>
- <property name="Expand">False</property>
- <property name="Fill">False</property>
- </packing>
- </child>
- <child>
- <widget class="Gtk.HBox" id="hbox3">
- <property name="MemberName" />
- <child>
- <widget class="Gtk.VBox" id="leftbox">
- <property name="MemberName" />
- <property name="Spacing">6</property>
- <child>
- <widget class="Gtk.HBox" id="toolsbox">
- <property name="MemberName" />
- <property name="Spacing">6</property>
- <child>
- <widget class="Gtk.Button" id="fitbutton">
- <property name="MemberName" />
- <property name="Type">TextAndIcon</property>
- <property name="Icon">stock:gtk-zoom-fit Button</property>
- <property name="Label" translatable="yes" />
- <property name="UseUnderline">True</property>
- <signal name="Clicked" handler="OnFitbuttonClicked" />
- </widget>
- <packing>
- <property name="Position">0</property>
- <property name="AutoSize">True</property>
- <property name="Expand">False</property>
- <property name="Fill">False</property>
- </packing>
- </child>
- <child>
- <widget class="Gtk.HScale" id="zoomscale">
- <property name="MemberName" />
- <property name="CanFocus">True</property>
- <property name="UpdatePolicy">Discontinuous</property>
- <property name="Lower">1</property>
- <property name="Upper">100</property>
- <property name="PageIncrement">10</property>
- <property name="StepIncrement">1</property>
- <property name="Value">1</property>
- <property name="DrawValue">True</property>
- <property name="Digits">0</property>
- <property name="ValuePos">Top</property>
- <signal name="ValueChanged" handler="OnZoomscaleValueChanged" />
- </widget>
- <packing>
- <property name="Position">1</property>
- <property name="AutoSize">True</property>
- </packing>
- </child>
- </widget>
- <packing>
- <property name="Position">0</property>
- <property name="AutoSize">True</property>
- <property name="Expand">False</property>
- <property name="Fill">False</property>
- </packing>
- </child>
- <child>
- <widget class="Gtk.Alignment" id="categoriesalignment1">
- <property name="MemberName" />
- <child>
- <widget class="Gtk.HBox" id="categoriesbox">
- <property name="MemberName" />
- <property name="Spacing">6</property>
- <child>
- <placeholder />
- </child>
- </widget>
- </child>
- </widget>
- <packing>
- <property name="Position">1</property>
- <property name="AutoSize">True</property>
- </packing>
- </child>
- </widget>
- <packing>
- <property name="Position">0</property>
- <property name="AutoSize">False</property>
- <property name="Expand">False</property>
- <property name="Fill">False</property>
- </packing>
- </child>
- <child>
- <widget class="Gtk.VSeparator" id="vseparator1">
- <property name="MemberName" />
- </widget>
- <packing>
- <property name="Position">1</property>
- <property name="AutoSize">True</property>
- <property name="Expand">False</property>
- <property name="Fill">False</property>
- </packing>
- </child>
- <child>
- <widget class="Gtk.VBox" id="vbox2">
- <property name="MemberName" />
- <property name="Spacing">6</property>
- <child>
- <widget class="Gtk.VBox" id="timescalebox">
- <property name="MemberName" />
- <property name="Spacing">6</property>
- <child>
- <placeholder />
- </child>
- </widget>
- <packing>
- <property name="Position">0</property>
- <property name="AutoSize">False</property>
- <property name="Expand">False</property>
- <property name="Fill">False</property>
- </packing>
- </child>
- <child>
- <widget class="Gtk.ScrolledWindow" id="GtkScrolledWindow">
- <property name="MemberName" />
- <property name="ShadowType">In</property>
- <child>
- <widget class="Gtk.Viewport" id="GtkViewport">
- <property name="MemberName" />
- <property name="ShadowType">None</property>
- <child>
- <widget class="Gtk.VBox" id="vbox1">
- <property name="MemberName" />
- <property name="ShowScrollbars">True</property>
- <child>
- <placeholder />
- </child>
- </widget>
- </child>
- </widget>
- </child>
- </widget>
- <packing>
- <property name="Position">1</property>
- <property name="AutoSize">True</property>
- </packing>
- </child>
- </widget>
- <packing>
- <property name="Position">2</property>
- <property name="AutoSize">True</property>
- </packing>
- </child>
- </widget>
- <packing>
- <property name="Position">1</property>
- <property name="AutoSize">True</property>
- </packing>
- </child>
- </widget>
- </child>
- </widget>
<widget class="Gtk.Dialog" id="LongoMatch.Gui.Dialog.VideoEditionProperties" design-size="516 245">
<property name="MemberName" />
<property name="Title" translatable="yes">Video Properties</property>
@@ -6798,4 +6630,177 @@ Defining <b> Game Units </b> will help you during the analysis to in
</widget>
</child>
</widget>
+ <widget class="Gtk.Bin" id="LongoMatch.Gui.Base.TimelineWidgetBase" design-size="687 300">
+ <property name="MemberName" />
+ <property name="Visible">False</property>
+ <child>
+ <widget class="Gtk.VBox" id="vbox3">
+ <property name="MemberName" />
+ <property name="Spacing">6</property>
+ <child>
+ <widget class="Gtk.HSeparator" id="hseparator1">
+ <property name="MemberName" />
+ </widget>
+ <packing>
+ <property name="Position">0</property>
+ <property name="AutoSize">True</property>
+ <property name="Expand">False</property>
+ <property name="Fill">False</property>
+ </packing>
+ </child>
+ <child>
+ <widget class="Gtk.HBox" id="hbox3">
+ <property name="MemberName" />
+ <child>
+ <widget class="Gtk.VBox" id="leftbox">
+ <property name="MemberName" />
+ <property name="Spacing">6</property>
+ <child>
+ <widget class="Gtk.HBox" id="toolsbox">
+ <property name="MemberName" />
+ <property name="Spacing">6</property>
+ <child>
+ <widget class="Gtk.Button" id="fitbutton">
+ <property name="MemberName" />
+ <property name="Type">TextAndIcon</property>
+ <property name="Icon">stock:gtk-zoom-fit Button</property>
+ <property name="Label" translatable="yes" />
+ <property name="UseUnderline">True</property>
+ </widget>
+ <packing>
+ <property name="Position">0</property>
+ <property name="AutoSize">True</property>
+ <property name="Expand">False</property>
+ <property name="Fill">False</property>
+ </packing>
+ </child>
+ <child>
+ <widget class="Gtk.HScale" id="zoomscale">
+ <property name="MemberName" />
+ <property name="CanFocus">True</property>
+ <property name="UpdatePolicy">Discontinuous</property>
+ <property name="Lower">1</property>
+ <property name="Upper">100</property>
+ <property name="PageIncrement">10</property>
+ <property name="StepIncrement">1</property>
+ <property name="Value">1</property>
+ <property name="DrawValue">True</property>
+ <property name="Digits">0</property>
+ <property name="ValuePos">Top</property>
+ </widget>
+ <packing>
+ <property name="Position">1</property>
+ <property name="AutoSize">True</property>
+ </packing>
+ </child>
+ </widget>
+ <packing>
+ <property name="Position">0</property>
+ <property name="AutoSize">True</property>
+ <property name="Expand">False</property>
+ <property name="Fill">False</property>
+ </packing>
+ </child>
+ <child>
+ <widget class="Gtk.Alignment" id="categoriesalignment1">
+ <property name="MemberName" />
+ <child>
+ <widget class="Gtk.HBox" id="categoriesbox">
+ <property name="MemberName" />
+ <property name="Spacing">6</property>
+ <child>
+ <placeholder />
+ </child>
+ </widget>
+ </child>
+ </widget>
+ <packing>
+ <property name="Position">1</property>
+ <property name="AutoSize">True</property>
+ </packing>
+ </child>
+ </widget>
+ <packing>
+ <property name="Position">0</property>
+ <property name="AutoSize">False</property>
+ <property name="Expand">False</property>
+ <property name="Fill">False</property>
+ </packing>
+ </child>
+ <child>
+ <widget class="Gtk.VSeparator" id="vseparator1">
+ <property name="MemberName" />
+ </widget>
+ <packing>
+ <property name="Position">1</property>
+ <property name="AutoSize">True</property>
+ <property name="Expand">False</property>
+ <property name="Fill">False</property>
+ </packing>
+ </child>
+ <child>
+ <widget class="Gtk.VBox" id="vbox2">
+ <property name="MemberName" />
+ <property name="Spacing">6</property>
+ <child>
+ <widget class="Gtk.VBox" id="timescalebox">
+ <property name="MemberName" />
+ <property name="Spacing">6</property>
+ <child>
+ <placeholder />
+ </child>
+ </widget>
+ <packing>
+ <property name="Position">0</property>
+ <property name="AutoSize">False</property>
+ <property name="Expand">False</property>
+ <property name="Fill">False</property>
+ </packing>
+ </child>
+ <child>
+ <widget class="Gtk.ScrolledWindow" id="GtkScrolledWindow">
+ <property name="MemberName" />
+ <property name="ShadowType">In</property>
+ <child>
+ <widget class="Gtk.Viewport" id="GtkViewport">
+ <property name="MemberName" />
+ <property name="ShadowType">None</property>
+ <child>
+ <widget class="Gtk.VBox" id="timelinebox">
+ <property name="MemberName" />
+ <property name="ShowScrollbars">True</property>
+ <child>
+ <placeholder />
+ </child>
+ </widget>
+ </child>
+ </widget>
+ </child>
+ </widget>
+ <packing>
+ <property name="Position">1</property>
+ <property name="AutoSize">True</property>
+ </packing>
+ </child>
+ </widget>
+ <packing>
+ <property name="Position">2</property>
+ <property name="AutoSize">True</property>
+ </packing>
+ </child>
+ </widget>
+ <packing>
+ <property name="Position">1</property>
+ <property name="AutoSize">True</property>
+ </packing>
+ </child>
+ </widget>
+ </child>
+ </widget>
+ <widget class="Gtk.Bin" id="LongoMatch.Gui.Component.TimeLineWidget" design-size="535 229">
+ <property name="MemberName" />
+ <child>
+ <placeholder />
+ </child>
+ </widget>
</stetic-interface>
\ No newline at end of file
diff --git a/LongoMatch.GUI/gtk-gui/objects.xml b/LongoMatch.GUI/gtk-gui/objects.xml
index 22f1bc7..a3445d3 100644
--- a/LongoMatch.GUI/gtk-gui/objects.xml
+++ b/LongoMatch.GUI/gtk-gui/objects.xml
@@ -240,21 +240,6 @@
</itemgroup>
</signals>
</object>
- <object type="LongoMatch.Gui.Component.TimeLineWidget" palette-category="LongoMatch" allow-children="false" base-type="Gtk.Bin">
- <itemgroups>
- <itemgroup label="TimeLineWidget Properties">
- <property name="CurrentFrame" />
- </itemgroup>
- </itemgroups>
- <signals>
- <itemgroup label="TimeLineWidget Signals">
- <signal name="TimeNodeChanged" />
- <signal name="TimeNodeSelected" />
- <signal name="TimeNodeDeleted" />
- <signal name="NewMarkEvent" />
- </itemgroup>
- </signals>
- </object>
<object type="LongoMatch.Gui.Base.TimeScaleBase" palette-category="LongoMatch" allow-children="false" base-type="Gtk.DrawingArea">
<itemgroups>
<itemgroup label="TimeScaleBase Properties">
@@ -288,4 +273,47 @@
</itemgroups>
<signals />
</object>
+ <object type="LongoMatch.Gui.Component.GameUnitTimeScale" palette-category="LongoMatch" allow-children="false" base-type="Gtk.DrawingArea">
+ <itemgroups>
+ <itemgroup label="TimeScaleBase[LongoMatch.Store.TimelineNode] Properties">
+ <property name="PixelRatio" />
+ <property name="CurrentFrame" />
+ </itemgroup>
+ </itemgroups>
+ <signals>
+ <itemgroup label="GameUnitTimeScale Signals">
+ <signal name="UnitChanged" />
+ <signal name="UnitSelected" />
+ <signal name="UnitDeleted" />
+ <signal name="UnitAdded" />
+ </itemgroup>
+ </signals>
+ </object>
+ <object type="LongoMatch.Gui.Base.TimelineBase" palette-category="General" allow-children="false" base-type="Gtk.Bin">
+ <itemgroups>
+ <itemgroup label="TimelineBase Properties">
+ <property name="CurrentFrame" />
+ </itemgroup>
+ </itemgroups>
+ <signals />
+ </object>
+ <object type="LongoMatch.Gui.Component.TimeLineWidget" palette-category="LongoMatch" allow-children="false" base-type="LongoMatch.Gui.Base.TimelineWidgetBase">
+ <itemgroups>
+ <itemgroup label="TimelineBase[LongoMatch.Gui.Component.TimeScale,LongoMatch.Store.Play] Properties">
+ <property name="CurrentFrame" />
+ </itemgroup>
+ </itemgroups>
+ <signals>
+ <itemgroup label="TimeLineWidget Signals">
+ <signal name="TimeNodeChanged" />
+ <signal name="TimeNodeSelected" />
+ <signal name="TimeNodeDeleted" />
+ <signal name="NewMarkEvent" />
+ </itemgroup>
+ </signals>
+ </object>
+ <object type="LongoMatch.Gui.Base.TimelineWidgetBase" palette-category="General" allow-children="false" base-type="Gtk.Bin">
+ <itemgroups />
+ <signals />
+ </object>
</objects>
\ No newline at end of file
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]