Implemented the HEIF converter, save and load system for choosen images

This commit is contained in:
2023-05-18 06:26:45 +02:00
parent f71c190b1f
commit cb64d7dcda
3 changed files with 252 additions and 35 deletions

4
.gitignore vendored
View File

@@ -1,2 +1,4 @@
*.glade~ *.glade~
*.glade# *.glade#
extracted/
*.txt

View File

@@ -13,10 +13,15 @@
<column type="gchararray"/> <column type="gchararray"/>
</columns> </columns>
</object> </object>
<object class="GtkListStore" id="ls_preview">
<columns>
<!-- column-name gchararray1 -->
<column type="gchararray"/>
</columns>
</object>
<object class="GtkWindow" id="main_window"> <object class="GtkWindow" id="main_window">
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="window-position">center</property> <property name="window-position">center</property>
<property name="default-width">1000</property>
<property name="default-height">768</property> <property name="default-height">768</property>
<property name="icon">../icons/icon.png</property> <property name="icon">../icons/icon.png</property>
<signal name="destroy" handler="onDestroy" swapped="no"/> <signal name="destroy" handler="onDestroy" swapped="no"/>
@@ -24,7 +29,10 @@
<object class="GtkScrolledWindow"> <object class="GtkScrolledWindow">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">True</property> <property name="can-focus">True</property>
<property name="hscrollbar-policy">never</property>
<property name="shadow-type">in</property> <property name="shadow-type">in</property>
<property name="overlay-scrolling">False</property>
<property name="propagate-natural-width">True</property>
<child> <child>
<object class="GtkViewport"> <object class="GtkViewport">
<property name="visible">True</property> <property name="visible">True</property>
@@ -51,7 +59,8 @@
<object class="GtkAlignment"> <object class="GtkAlignment">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="left-padding">12</property> <property name="left-padding">8</property>
<property name="right-padding">8</property>
<child> <child>
<!-- n-columns=2 n-rows=2 --> <!-- n-columns=2 n-rows=2 -->
<object class="GtkGrid"> <object class="GtkGrid">
@@ -84,7 +93,7 @@
<property name="receives-default">False</property> <property name="receives-default">False</property>
<property name="active">True</property> <property name="active">True</property>
<property name="draw-indicator">True</property> <property name="draw-indicator">True</property>
<signal name="toggled" handler="onRadioIncludedImageSet" swapped="no"/> <signal name="toggled" handler="onRadioImageSet" swapped="no"/>
</object> </object>
<packing> <packing>
<property name="left-attach">1</property> <property name="left-attach">1</property>
@@ -100,7 +109,6 @@
<property name="active">True</property> <property name="active">True</property>
<property name="draw-indicator">True</property> <property name="draw-indicator">True</property>
<property name="group">rb_included_image_set</property> <property name="group">rb_included_image_set</property>
<signal name="toggled" handler="onRadioExternalImageSet" swapped="no"/>
</object> </object>
<packing> <packing>
<property name="left-attach">1</property> <property name="left-attach">1</property>
@@ -137,7 +145,8 @@
<object class="GtkAlignment"> <object class="GtkAlignment">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="left-padding">12</property> <property name="left-padding">8</property>
<property name="right-padding">8</property>
<child> <child>
<!-- n-columns=2 n-rows=2 --> <!-- n-columns=2 n-rows=2 -->
<object class="GtkGrid"> <object class="GtkGrid">
@@ -168,6 +177,7 @@
<property name="no-show-all">True</property> <property name="no-show-all">True</property>
<property name="filter">filefilter1</property> <property name="filter">filefilter1</property>
<property name="title" translatable="yes"/> <property name="title" translatable="yes"/>
<signal name="file-set" handler="onHeifSelected" swapped="no"/>
</object> </object>
<packing> <packing>
<property name="left-attach">1</property> <property name="left-attach">1</property>
@@ -266,8 +276,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_1"> <object class="GtkImage" id="img_preview_1">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -281,9 +294,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_1">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -329,8 +351,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_2"> <object class="GtkImage" id="img_preview_2">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -343,9 +368,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_2">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -391,8 +425,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_3"> <object class="GtkImage" id="img_preview_3">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -405,9 +442,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_3">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -453,8 +499,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_4"> <object class="GtkImage" id="img_preview_4">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -467,9 +516,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_4">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -515,8 +573,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_5"> <object class="GtkImage" id="img_preview_5">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -529,9 +590,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_5">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -577,8 +647,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_6"> <object class="GtkImage" id="img_preview_6">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -591,9 +664,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_6">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -639,8 +721,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_7"> <object class="GtkImage" id="img_preview_7">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -653,9 +738,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_7">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -701,8 +795,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_8"> <object class="GtkImage" id="img_preview_8">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -715,9 +812,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_8">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@@ -763,8 +869,11 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="orientation">vertical</property> <property name="orientation">vertical</property>
<property name="spacing">8</property>
<child> <child>
<object class="GtkImage" id="img_preview_9"> <object class="GtkImage" id="img_preview_9">
<property name="width-request">300</property>
<property name="height-request">200</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="vexpand">True</property> <property name="vexpand">True</property>
@@ -777,9 +886,18 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkComboBox"> <object class="GtkComboBox" id="cb_preview_9">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can-focus">False</property> <property name="can-focus">False</property>
<property name="model">ls_preview</property>
<property name="has-entry">True</property>
<property name="entry-text-column">0</property>
<signal name="changed" handler="onPreviewComboboxSelected" swapped="no"/>
<child internal-child="entry">
<object class="GtkEntry">
<property name="can-focus">False</property>
</object>
</child>
</object> </object>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>

View File

@@ -1,23 +1,38 @@
import gi, os import gi, os, glob
gi.require_version("Gtk", "3.0") gi.require_version("Gtk", "3.0")
from gi.repository import Gtk from gi.repository import Gtk, GdkPixbuf
DIR = os.path.dirname(os.path.abspath(__file__))
UI_FILE = DIR + "/image-configurator.glade"
EXPORT_DIR = "extracted"
UI_FILE = os.path.dirname(os.path.abspath(__file__)) + "/image-configurator.glade"
class ImageConfigurator: class ImageConfigurator:
def __init__(self) -> None: def __init__(self) -> None:
########### Class variables ###########
try:
os.mkdir(DIR + "/" + EXPORT_DIR)
except:
pass
########### GTK stuff ###########
self.builder = Gtk.Builder() self.builder = Gtk.Builder()
self.builder.add_from_file(UI_FILE) self.builder.add_from_file(UI_FILE)
self.builder.connect_signals(self) self.builder.connect_signals(self)
# Get all resources from the glade file ########### Glade Ressources ###########
self.imageSetText = self.builder.get_object("lb_image_set") self.imageSetText = self.builder.get_object("lb_image_set")
self.imageSetCb = self.builder.get_object("cb_image_set") self.imageSetCb = self.builder.get_object("cb_image_set")
self.fileChooserText = self.builder.get_object("lb_heic_file") self.fileChooserText = self.builder.get_object("lb_heic_file")
self.fileChooserFc = self.builder.get_object("fc_heic_file") self.fileChooserFc = self.builder.get_object("fc_heic_file")
self.image_set_list_store = self.builder.get_object("image_set_list_store") self.image_set_list_store = self.builder.get_object("image_set_list_store")
self.ls_preview = self.builder.get_object("ls_preview")
self.img_previews = [ self.img_previews = [
self.builder.get_object("img_preview_1"), self.builder.get_object("img_preview_1"),
@@ -31,10 +46,39 @@ class ImageConfigurator:
self.builder.get_object("img_preview_9") self.builder.get_object("img_preview_9")
] ]
# Predefinition self.cb_previews = [
self.builder.get_object("cb_preview_1"),
self.builder.get_object("cb_preview_2"),
self.builder.get_object("cb_preview_3"),
self.builder.get_object("cb_preview_4"),
self.builder.get_object("cb_preview_5"),
self.builder.get_object("cb_preview_6"),
self.builder.get_object("cb_preview_7"),
self.builder.get_object("cb_preview_8"),
self.builder.get_object("cb_preview_9")
]
########### Load predefinitions and settings ###########
self.image_set_list_store.append(["Big Sur Beach 2"]) self.image_set_list_store.append(["Big Sur Beach 2"])
self.image_set_list_store.append(["Firewatch"]) self.image_set_list_store.append(["Firewatch"])
self.image_set_list_store.append(["Lakeside"]) self.image_set_list_store.append(["Lakeside"])
# todo
try:
# Create the combobox content
self.createExtracted()
self.changePreviewSpinners(self.extracted)
# Load the images
with open(DIR + "/selected_images.txt", "r") as file:
for i, line in enumerate(file.readlines()):
line = line.removesuffix("\n")
self.changePreviewImage(i, EXPORT_DIR + "/" + line)
self.cb_previews[i].set_active(self.extracted.index(line))
except:
pass
def showMainWindow(self): def showMainWindow(self):
@@ -44,29 +88,82 @@ class ImageConfigurator:
Gtk.main() Gtk.main()
def changeImage(self, imageId: int, imageURI: str): def changePreviewImage(self, imageId: int, imageURI: str):
self.img_previews[imageId].set_from_file(os.path.dirname(os.path.abspath(__file__)) + "/" + imageURI) pixbuf = GdkPixbuf.Pixbuf.new_from_file(DIR + "/" + imageURI)
pixbuf = pixbuf.scale_simple(300, 200, GdkPixbuf.InterpType.BILINEAR)
self.img_previews[imageId].set_from_pixbuf(pixbuf)
def onRadioIncludedImageSet(self, rb): def extractHeifImages(self, imageURI: str):
if rb.get_active(): imageURI = imageURI.replace("%20", "\ ")
self.imageSetText.set_visible(True)
self.imageSetCb.set_visible(True) filename = imageURI[imageURI.rfind("/"):imageURI.rfind(".")]
self.fileChooserText.set_visible(False) self.wipeImages()
self.fileChooserFc.set_visible(False) os.system("heif-convert " + imageURI + " " + DIR + "/" + EXPORT_DIR + filename + ".jpg")
def onRadioExternalImageSet(self, rb): def wipeImages(self):
if rb.get_active(): for file in glob.glob(DIR + "/" + EXPORT_DIR + "/*"):
self.fileChooserText.set_visible(True) os.remove(file)
self.fileChooserFc.set_visible(True)
self.imageSetText.set_visible(False) def changePreviewSpinners(self, options: list):
self.imageSetCb.set_visible(False) for option in options:
self.ls_preview.append([option])
def createExtracted(self):
self.extracted = os.listdir(DIR + "/" + EXPORT_DIR)
self.extracted.sort()
########## UI Signals ##########
def onHeifSelected(self, fc):
# Get the URI to the file
uri = fc.get_file().get_uri()
uri = uri[7:]
self.extractHeifImages(uri)
self.createExtracted()
self.changePreviewSpinners(self.extracted)
def onRadioImageSet(self, rb):
""" UI Signal, if the radio buttons are toggled
Args:
rb (GtkRadioButton): The toggled RadioButton
"""
self.imageSetText.set_visible(rb.get_active())
self.imageSetCb.set_visible(rb.get_active())
self.fileChooserText.set_visible(not rb.get_active())
self.fileChooserFc.set_visible(not rb.get_active())
def onPreviewComboboxSelected(self, cb):
number = Gtk.Buildable.get_name(cb)
number = number[number.rfind("_") + 1:]
self.changePreviewImage(int(number) - 1, EXPORT_DIR + "/" + self.extracted[cb.get_active()])
def onApply(self, *args): def onApply(self, *args):
buffer = []
for cb in self.cb_previews:
if cb.get_active() != -1:
buffer.append(self.extracted[cb.get_active()])
else:
buffer.append(buffer[len(buffer) - 1])
with open(DIR + "/selected_images.txt", "w") as file:
for buff in buffer:
file.write(buff + "\n")
# todo # todo
Gtk.main_quit() Gtk.main_quit()