Refactor of picture retrieval and implementing the things needed to create the details view.

This commit is contained in:
sergiotarxz 2021-11-01 14:38:15 +01:00
parent b3e5558ed5
commit dbcd7afff0
8 changed files with 98 additions and 57 deletions

View File

@ -6,4 +6,4 @@ LDFLAGS := $(shell pkg-config --libs ${LIBS})
CC_COMMAND := ${CC} ${INCDIR} ${CFLAGS} CC_COMMAND := ${CC} ${INCDIR} ${CFLAGS}
all: build all: build
build: build:
${CC_COMMAND} src/util/regex.c src/util/string.c src/util/xml.c src/util/soup.c src/view/list_view_manga.c src/view/main_view.c src/manga.c src/backend/readmng.c src/main.c -o main ${LDFLAGS} -ggdb ${CC_COMMAND} src/view/picture.c src/util/gobject_utility_extensions.c src/view/detail_manga.c src/util/regex.c src/util/string.c src/util/xml.c src/util/soup.c src/view/list_view_manga.c src/view/main_view.c src/manga.c src/backend/readmng.c src/main.c -o main ${LDFLAGS} -ggdb

View File

@ -0,0 +1,5 @@
#pragma once
#include <glib-object.h>
void
g_object_set_property_int(GObject *object, char *property_key, int value);

View File

@ -0,0 +1,4 @@
#include <openmg/manga.h>
GtkBox *
create_detail_view (MgManga *manga);

View File

@ -0,0 +1,4 @@
#pragma once
#include <gtk/gtk.h>
GtkPicture *
create_picture_from_url (char *url, gint picture_height);

View File

@ -0,0 +1,11 @@
#include <glib-object.h>
void
g_object_set_property_int(GObject *object, char *property_key, int value) {
GValue property = G_VALUE_INIT;
g_value_init (&property, G_TYPE_INT);
g_value_set_int (&property, value);
g_object_set_property (object, property_key, &property);
}

17
src/view/detail_manga.c Normal file
View File

@ -0,0 +1,17 @@
#include <gtk/gtk.h>
#include <openmg/manga.h>
#include <openmg/view/picture.h>
#include <openmg/view/detail_manga.h>
GtkBox *
create_detail_view (MgManga *manga) {
GtkBox *detail_view = GTK_BOX (gtk_box_new (GTK_ORIENTATION_VERTICAL, 0));
GtkBox *descriptive_box = GTK_BOX (gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0));
GtkPicture *manga_image = create_picture_from_url (
mg_manga_get_image_url(manga), 200);
gtk_box_append (descriptive_box, GTK_WIDGET (manga_image));
gtk_box_append (detail_view, GTK_WIDGET (descriptive_box));
return detail_view;
}

View File

@ -4,28 +4,32 @@
#include <openmg/manga.h> #include <openmg/manga.h>
#include <openmg/util/soup.h> #include <openmg/util/soup.h>
#include <openmg/util/gobject_utility_extensions.h>
#include <openmg/view/detail_manga.h>
#include <openmg/view/list_view_manga.h> #include <openmg/view/list_view_manga.h>
#include <openmg/view/picture.h>
typedef struct {
GtkListView *list_view;
AdwLeaflet *views_leaflet;
} ActivationValues;
static void
g_object_set_property_int(GObject *object, char *property_key, int value);
static void static void
setup_list_view_mangas (GtkSignalListItemFactory *factory, setup_list_view_mangas (GtkSignalListItemFactory *factory,
GtkListItem *list_item, GtkListItem *list_item,
gpointer user_data); gpointer user_data);
typedef struct {
GListStore *mangas;
AdwLeaflet *views_leaflet;
} MangaPressedValues;
static void static void
manga_selected (GtkListView *list_view, manga_selected (GtkListView *list_view,
guint position, guint position,
gpointer user_data) { gpointer user_data) {
MangaPressedValues *manga_pressed_values = (MangaPressedValues *) user_data; AdwLeaflet *views_leaflet = ADW_LEAFLET (user_data);
AdwLeaflet *views_leaflet = manga_pressed_values->views_leaflet; GtkSingleSelection *selection = GTK_SINGLE_SELECTION
GtkBox *box = GTK_BOX (gtk_box_new (GTK_ORIENTATION_VERTICAL, 0)); (gtk_list_view_get_model (list_view));
GListModel *mangas = gtk_single_selection_get_model (selection);
MgManga *manga = MG_MANGA (g_list_model_get_item (mangas, position));
GtkWidget *widget = adw_leaflet_get_adjacent_child (views_leaflet, GtkWidget *widget = adw_leaflet_get_adjacent_child (views_leaflet,
ADW_NAVIGATION_DIRECTION_FORWARD); ADW_NAVIGATION_DIRECTION_FORWARD);
@ -35,7 +39,8 @@ manga_selected (GtkListView *list_view,
ADW_NAVIGATION_DIRECTION_FORWARD); ADW_NAVIGATION_DIRECTION_FORWARD);
} }
adw_leaflet_append (views_leaflet, GTK_WIDGET (box)); GtkBox *detail_view = create_detail_view (manga);
adw_leaflet_append (views_leaflet, GTK_WIDGET (detail_view));
adw_leaflet_navigate (views_leaflet, ADW_NAVIGATION_DIRECTION_FORWARD); adw_leaflet_navigate (views_leaflet, ADW_NAVIGATION_DIRECTION_FORWARD);
} }
@ -47,35 +52,9 @@ setup_list_view_mangas (GtkSignalListItemFactory *factory,
GtkBox *box = GTK_BOX (gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0)); GtkBox *box = GTK_BOX (gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0));
GtkWidget *label = gtk_label_new (mg_manga_get_title (manga)); GtkWidget *label = gtk_label_new (mg_manga_get_title (manga));
GtkWidget *picture; GtkWidget *picture = GTK_WIDGET (
create_picture_from_url (mg_manga_get_image_url(manga), 200));
GFileIOStream *iostream;
GFile *tmp_image;
GError *error = NULL;
size_t size_downloaded_image = 0;
char *downloaded_image;
MgUtilSoup *util_soup = mg_util_soup_new ();
downloaded_image = mg_util_soup_get_request (util_soup, mg_manga_get_image_url(manga),
&size_downloaded_image);
tmp_image = g_file_new_tmp ("mangareadertmpfileXXXXXX",
&iostream,
&error
);
if (error) {
fprintf (stderr, "Unable to read file: %s\n", error->message);
return;
}
error = NULL;
g_output_stream_write (g_io_stream_get_output_stream (G_IO_STREAM (iostream)),
downloaded_image, size_downloaded_image, NULL, &error);
if (error) {
fprintf (stderr, "Unable to write file: %s\n", error->message);
return;
}
picture = gtk_picture_new_for_file (tmp_image);
g_object_set_property_int (G_OBJECT(picture), "height-request", 200);
gtk_box_append (box, picture); gtk_box_append (box, picture);
gtk_box_append (box, label); gtk_box_append (box, label);
gtk_list_item_set_child (list_item, GTK_WIDGET (box)); gtk_list_item_set_child (list_item, GTK_WIDGET (box));
@ -85,13 +64,8 @@ GtkListView *
create_list_view_mangas (GListStore *mangas, AdwLeaflet *views_leaflet) { create_list_view_mangas (GListStore *mangas, AdwLeaflet *views_leaflet) {
GtkSingleSelection *selection = gtk_single_selection_new (G_LIST_MODEL (mangas)); GtkSingleSelection *selection = gtk_single_selection_new (G_LIST_MODEL (mangas));
GtkListItemFactory *factory = gtk_signal_list_item_factory_new (); GtkListItemFactory *factory = gtk_signal_list_item_factory_new ();
MangaPressedValues *manga_pressed_values = NULL;
GtkListView *list_view_manga = NULL; GtkListView *list_view_manga = NULL;
manga_pressed_values = g_malloc (sizeof *manga_pressed_values);
manga_pressed_values->mangas = mangas;
manga_pressed_values->views_leaflet = views_leaflet;
g_signal_connect (G_OBJECT (factory), "bind", g_signal_connect (G_OBJECT (factory), "bind",
G_CALLBACK (setup_list_view_mangas), G_CALLBACK (setup_list_view_mangas),
views_leaflet); views_leaflet);
@ -102,16 +76,6 @@ create_list_view_mangas (GListStore *mangas, AdwLeaflet *views_leaflet) {
"single-click-activate", 1); "single-click-activate", 1);
g_signal_connect (G_OBJECT (list_view_manga), "activate", g_signal_connect (G_OBJECT (list_view_manga), "activate",
G_CALLBACK (manga_selected), manga_pressed_values); G_CALLBACK (manga_selected), views_leaflet);
return list_view_manga; return list_view_manga;
} }
static void
g_object_set_property_int(GObject *object, char *property_key, int value) {
GValue property = G_VALUE_INIT;
g_value_init (&property, G_TYPE_INT);
g_value_set_int (&property, value);
g_object_set_property (object, property_key, &property);
}

36
src/view/picture.c Normal file
View File

@ -0,0 +1,36 @@
#include <stdio.h>
#include <gtk/gtk.h>
#include <openmg/util/soup.h>
#include <openmg/util/gobject_utility_extensions.h>
GtkPicture *
create_picture_from_url (char *url, gint picture_height) {
GtkPicture *picture;
GFileIOStream *iostream;
GFile *tmp_image;
GError *error = NULL;
size_t size_downloaded_image = 0;
char *downloaded_image;
MgUtilSoup *util_soup = mg_util_soup_new ();
downloaded_image = mg_util_soup_get_request (util_soup,
url, &size_downloaded_image);
tmp_image = g_file_new_tmp ("mangareadertmpfileXXXXXX", &iostream, &error);
if (error) {
fprintf (stderr, "Unable to read file: %s\n", error->message);
return NULL;
}
error = NULL;
g_output_stream_write (g_io_stream_get_output_stream (G_IO_STREAM (iostream)),
downloaded_image, size_downloaded_image, NULL, &error);
if (error) {
fprintf (stderr, "Unable to write file: %s\n", error->message);
return NULL;
}
picture = GTK_PICTURE (gtk_picture_new_for_file (tmp_image));
g_object_set_property_int (G_OBJECT(picture), "height-request", picture_height);
return picture;
}