[sysprof] libsysprof-ui: add simplified time label



commit bfe72c1d77d7638f8387f40611aeb7d2f6faf75d
Author: Christian Hergert <chergert redhat com>
Date:   Fri May 24 00:41:02 2019 -0700

    libsysprof-ui: add simplified time label
    
    This handles the resizing of the numbers better to avoid jitter of the
    positioning.

 src/libsysprof-ui/libsysprof-ui.gresource.xml      |   1 +
 src/libsysprof-ui/meson.build                      |   1 +
 src/libsysprof-ui/sysprof-recording-state-view.c   |  36 ++-----
 src/libsysprof-ui/sysprof-time-label.c             | 103 +++++++++++++++++++++
 src/libsysprof-ui/sysprof-time-label.h             |  34 +++++++
 .../ui/sysprof-recording-state-view.ui             |   8 +-
 src/libsysprof-ui/ui/sysprof-time-label.ui         |  50 ++++++++++
 7 files changed, 200 insertions(+), 33 deletions(-)
---
diff --git a/src/libsysprof-ui/libsysprof-ui.gresource.xml b/src/libsysprof-ui/libsysprof-ui.gresource.xml
index 46b0c6e..c3e80a0 100644
--- a/src/libsysprof-ui/libsysprof-ui.gresource.xml
+++ b/src/libsysprof-ui/libsysprof-ui.gresource.xml
@@ -25,6 +25,7 @@
     <file preprocess="xml-stripblanks">ui/sysprof-profiler-menu-button.ui</file>
     <file preprocess="xml-stripblanks">ui/sysprof-recording-state-view.ui</file>
     <file preprocess="xml-stripblanks">ui/sysprof-tab.ui</file>
+    <file preprocess="xml-stripblanks">ui/sysprof-time-label.ui</file>
     <file preprocess="xml-stripblanks">ui/sysprof-visualizer-view.ui</file>
   </gresource>
 </gresources>
diff --git a/src/libsysprof-ui/meson.build b/src/libsysprof-ui/meson.build
index f6ee097..9ee8c6c 100644
--- a/src/libsysprof-ui/meson.build
+++ b/src/libsysprof-ui/meson.build
@@ -42,6 +42,7 @@ libsysprof_ui_private_sources = [
   'sysprof-environ-variable.c',
   'sysprof-environ.c',
   'sysprof-tab.c',
+  'sysprof-time-label.c',
   'sysprof-theme-manager.c',
   '../stackstash.c',
 ]
diff --git a/src/libsysprof-ui/sysprof-recording-state-view.c 
b/src/libsysprof-ui/sysprof-recording-state-view.c
index 687f728..a5eb8c9 100644
--- a/src/libsysprof-ui/sysprof-recording-state-view.c
+++ b/src/libsysprof-ui/sysprof-recording-state-view.c
@@ -21,13 +21,14 @@
 #include "config.h"
 
 #include "sysprof-recording-state-view.h"
+#include "sysprof-time-label.h"
 
 typedef struct
 {
-  SysprofProfiler *profiler;
-  GtkLabel        *elapsed;
-  GtkLabel        *samples;
-  gulong           notify_elapsed_handler;
+  SysprofProfiler  *profiler;
+  SysprofTimeLabel *elapsed;
+  GtkLabel         *samples;
+  gulong            notify_elapsed_handler;
 } SysprofRecordingStateViewPrivate;
 
 G_DEFINE_TYPE_WITH_PRIVATE (SysprofRecordingStateView, sysprof_recording_state_view, GTK_TYPE_BIN)
@@ -55,9 +56,6 @@ sysprof_recording_state_view_notify_elapsed (SysprofRecordingStateView *self,
   g_autofree gchar *str = NULL;
   SysprofCaptureWriter *writer;
   gint64 elapsed;
-  guint hours;
-  guint minutes;
-  guint seconds;
 
   g_assert (SYSPROF_IS_RECORDING_STATE_VIEW (self));
   g_assert (SYSPROF_IS_PROFILER (profiler));
@@ -78,20 +76,7 @@ sysprof_recording_state_view_notify_elapsed (SysprofRecordingStateView *self,
     }
 
   elapsed = (gint64)sysprof_profiler_get_elapsed (profiler);
-
-  hours = elapsed / (60 * 60);
-  if (hours > 0)
-    minutes = (elapsed % (hours * 60 * 60)) / 60;
-  else
-    minutes = elapsed / 60;
-  seconds = elapsed % 60;
-
-  if (hours == 0)
-    str = g_strdup_printf ("%02u:%02u", minutes, seconds);
-  else
-    str = g_strdup_printf ("%02u:%02u:%02u", hours, minutes, seconds);
-
-  gtk_label_set_label (priv->elapsed, str);
+  sysprof_time_label_set_duration (priv->elapsed, elapsed);
 }
 
 static void
@@ -168,10 +153,11 @@ sysprof_recording_state_view_class_init (SysprofRecordingStateViewClass *klass)
 
   g_object_class_install_properties (object_class, N_PROPS, properties);
 
-  gtk_widget_class_set_template_from_resource (widget_class,
-                                               "/org/gnome/sysprof/ui/sysprof-recording-state-view.ui");
+  gtk_widget_class_set_template_from_resource (widget_class, 
"/org/gnome/sysprof/ui/sysprof-recording-state-view.ui");
   gtk_widget_class_bind_template_child_private (widget_class, SysprofRecordingStateView, elapsed);
   gtk_widget_class_bind_template_child_private (widget_class, SysprofRecordingStateView, samples);
+
+  g_type_ensure (SYSPROF_TYPE_TIME_LABEL);
 }
 
 static void
@@ -189,7 +175,7 @@ sysprof_recording_state_view_set_profiler (SysprofRecordingStateView *self,
   g_assert (SYSPROF_IS_RECORDING_STATE_VIEW (self));
   g_assert (!profiler || SYSPROF_IS_PROFILER (profiler));
 
-  gtk_label_set_label (priv->elapsed, "00:00");
+  sysprof_time_label_set_duration (priv->elapsed, 0);
 
   if (profiler != priv->profiler)
     {
@@ -199,8 +185,6 @@ sysprof_recording_state_view_set_profiler (SysprofRecordingStateView *self,
           g_clear_object (&priv->profiler);
         }
 
-      gtk_label_set_label (priv->elapsed, "00:00");
-
       if (profiler != NULL)
         {
           priv->profiler = g_object_ref (profiler);
diff --git a/src/libsysprof-ui/sysprof-time-label.c b/src/libsysprof-ui/sysprof-time-label.c
new file mode 100644
index 0000000..eac8898
--- /dev/null
+++ b/src/libsysprof-ui/sysprof-time-label.c
@@ -0,0 +1,103 @@
+/* sysprof-time-label.c
+ *
+ * Copyright 2019 Christian Hergert <chergert redhat com>
+ *
+ * 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 3 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, see <http://www.gnu.org/licenses/>.
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ */
+
+#define G_LOG_DOMAIN "sysprof-time-label"
+
+#include "config.h"
+
+#include "sysprof-time-label.h"
+
+#define NSEC_PER_SEC (G_USEC_PER_SEC * 1000L)
+
+struct _SysprofTimeLabel
+{
+  GtkBox parent;
+
+  GtkLabel *minutes;
+  GtkLabel *seconds;
+};
+
+G_DEFINE_TYPE (SysprofTimeLabel, sysprof_time_label, GTK_TYPE_BOX)
+
+static void
+sysprof_time_label_class_init (SysprofTimeLabelClass *klass)
+{
+}
+
+static void
+sysprof_time_label_init (SysprofTimeLabel *self)
+{
+  PangoAttrList *attrs = pango_attr_list_new ();
+  GtkWidget *sep;
+
+  pango_attr_list_insert (attrs, pango_attr_scale_new (4));
+  pango_attr_list_insert (attrs, pango_attr_weight_new (PANGO_WEIGHT_BOLD));
+
+  gtk_box_set_spacing (GTK_BOX (self), 3);
+
+  self->minutes = g_object_new (GTK_TYPE_LABEL,
+                                "attributes", attrs,
+                                "visible", TRUE,
+                                "xalign", 1.0f,
+                                NULL);
+  gtk_container_add_with_properties (GTK_CONTAINER (self), GTK_WIDGET (self->minutes),
+                                     "pack-type", GTK_PACK_START,
+                                     "expand", TRUE,
+                                     "fill", TRUE,
+                                     NULL);
+
+  sep = g_object_new (GTK_TYPE_LABEL,
+                      "attributes", attrs,
+                      "visible", TRUE,
+                      "label", ":",
+                      NULL);
+  gtk_box_set_center_widget (GTK_BOX (self), sep);
+
+  self->seconds = g_object_new (GTK_TYPE_LABEL,
+                                "attributes", attrs,
+                                "visible", TRUE,
+                                "xalign", 0.0f,
+                                NULL);
+  gtk_container_add_with_properties (GTK_CONTAINER (self), GTK_WIDGET (self->seconds),
+                                     "pack-type", GTK_PACK_END,
+                                     "expand", TRUE,
+                                     "fill", TRUE,
+                                     NULL);
+}
+
+void
+sysprof_time_label_set_duration (SysprofTimeLabel *self,
+                                 guint             duration)
+{
+  gchar minstr[12];
+  gchar secstr[12];
+  gint min, sec;
+
+  g_return_if_fail (SYSPROF_IS_TIME_LABEL (self));
+
+  min = duration / 60;
+  sec = duration % 60;
+
+  g_snprintf (minstr, sizeof minstr, "%02d", min);
+  g_snprintf (secstr, sizeof secstr, "%02d", sec);
+
+  gtk_label_set_label (self->minutes, minstr);
+  gtk_label_set_label (self->seconds, secstr);
+}
diff --git a/src/libsysprof-ui/sysprof-time-label.h b/src/libsysprof-ui/sysprof-time-label.h
new file mode 100644
index 0000000..7d4304c
--- /dev/null
+++ b/src/libsysprof-ui/sysprof-time-label.h
@@ -0,0 +1,34 @@
+/* sysprof-time-label.h
+ *
+ * Copyright 2019 Christian Hergert <chergert redhat com>
+ *
+ * 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 3 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, see <http://www.gnu.org/licenses/>.
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ */
+
+#pragma once
+
+#include <gtk/gtk.h>
+
+G_BEGIN_DECLS
+
+#define SYSPROF_TYPE_TIME_LABEL (sysprof_time_label_get_type())
+
+G_DECLARE_FINAL_TYPE (SysprofTimeLabel, sysprof_time_label, SYSPROF, TIME_LABEL, GtkBox)
+
+void sysprof_time_label_set_duration (SysprofTimeLabel *self,
+                                      guint             duration);
+
+G_END_DECLS
diff --git a/src/libsysprof-ui/ui/sysprof-recording-state-view.ui 
b/src/libsysprof-ui/ui/sysprof-recording-state-view.ui
index 4b42b7d..08f06ae 100644
--- a/src/libsysprof-ui/ui/sysprof-recording-state-view.ui
+++ b/src/libsysprof-ui/ui/sysprof-recording-state-view.ui
@@ -20,17 +20,11 @@
           </object>
         </child>
         <child>
-          <object class="GtkLabel" id="elapsed">
-            <property name="label" translatable="yes">00:00</property>
+          <object class="SysprofTimeLabel" id="elapsed">
             <property name="visible">true</property>
             <style>
               <class name="dim-label"/>
             </style>
-            <attributes>
-              <attribute name="scale" value="4"/>
-              <attribute name="weight" value="bold"/>
-              <attribute name="font-features" value="font-feature-settings: &apos;tnum&apos;"/>
-            </attributes>
           </object>
         </child>
         <child>
diff --git a/src/libsysprof-ui/ui/sysprof-time-label.ui b/src/libsysprof-ui/ui/sysprof-time-label.ui
new file mode 100644
index 0000000..d23376d
--- /dev/null
+++ b/src/libsysprof-ui/ui/sysprof-time-label.ui
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!-- Generated with glade 3.22.0 -->
+<interface>
+  <requires lib="gtk+" version="3.0"/>
+  <template class="SysprofTimeLabel" parent="GtkBox">
+    <property name="can_focus">False</property>
+    <property name="spacing">2</property>
+    <child type="center">
+      <object class="GtkLabel">
+        <property name="visible">True</property>
+        <property name="can_focus">False</property>
+        <property name="label">:</property>
+      </object>
+      <packing>
+        <property name="expand">False</property>
+        <property name="fill">True</property>
+        <property name="position">3</property>
+      </packing>
+    </child>
+    <child>
+      <object class="GtkLabel" id="minute">
+        <property name="visible">True</property>
+        <property name="can_focus">False</property>
+        <property name="label" translatable="yes">00</property>
+        <property name="width_chars">2</property>
+        <property name="xalign">1</property>
+      </object>
+      <packing>
+        <property name="expand">True</property>
+        <property name="fill">True</property>
+        <property name="position">2</property>
+      </packing>
+    </child>
+    <child>
+      <object class="GtkLabel" id="second">
+        <property name="visible">True</property>
+        <property name="can_focus">False</property>
+        <property name="label" translatable="yes">00</property>
+        <property name="width_chars">2</property>
+        <property name="xalign">0</property>
+      </object>
+      <packing>
+        <property name="expand">True</property>
+        <property name="fill">True</property>
+        <property name="pack_type">end</property>
+        <property name="position">4</property>
+      </packing>
+    </child>
+  </template>
+</interface>


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]