{"id":8225,"date":"2021-01-10T12:06:34","date_gmt":"2021-01-10T11:06:34","guid":{"rendered":"https:\/\/pythonprogramming.altervista.org\/?p=8225"},"modified":"2021-01-10T12:07:32","modified_gmt":"2021-01-10T11:07:32","slug":"pybook-version-2-6","status":"publish","type":"post","link":"https:\/\/pythonprogramming.altervista.org\/pybook-version-2-6\/","title":{"rendered":"Pybook, version 2.6"},"content":{"rendered":"\n<p class=\"wp-block-paragraph\">This app is made to take notes of what you want to build. It is a wip, so there are many bugs, the code is on <a href=\"https:\/\/github.com\/formazione\/pysnippets\">github<\/a> (click on the left).<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Teh result can be seen here:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">I will post the code also here<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-19.png\"><img loading=\"lazy\" decoding=\"async\" width=\"637\" height=\"489\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-19.png\" alt=\"A notepad to memorize all the stuffs you need to memorize with python and tkinter\" class=\"wp-image-8231\" srcset=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-19.png 637w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-19-320x246.png 320w\" sizes=\"auto, (max-width: 637px) 100vw, 637px\" \/><\/a><\/figure>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># tkinter advanced: pybookgen\n\n'''\nStarted: 03.12.2020 - v. 0.1\n\n- chapter\n    - chapter1.txt\n    - chapter1img1.png\n\nGUI\n---------------------------------\nPyEbookGen\n---------------------------------\n chapter1  | text\n           |\n\n'''\n# module for the gui\nimport tkinter as tk\n# module to check files\nimport os\nfrom tkinter import simpledialog\nfrom tkinter import messagebox\nimport time\n\nclass Win:\n    def __init__(self, title, version, folder, extension):\n        self.extension = extension\n        self.letter_size = 16\n        self.root = tk.Tk()\n        self.filename= \"\"\n        self.folder = folder\n        self.root.title(f\"{title}.{version}\")\n        self.window()\n        self.binding()\n        self.expand_widgets()\n\n    def expand_widgets(self):\n        # tk.Grid.rowconfigure(self.root, 0, weight=1)\n        tk.Grid.rowconfigure(self.root, 1, weight=1)\n        tk.Grid.columnconfigure(self.root, 0, weight=1, minsize=100)\n\n    # ==== This are for adjusting characters inside _text\n    def big_letters(self):\n        if self.letter_size &lt; 72:\n            self.letter_size += 2\n        self._text['font'] = \"Arial \" + str(self.letter_size)\n\n    def small_letters(self):\n        if self.letter_size > 8:\n            self.letter_size -= 2\n        self._text['font'] = \"Arial \" + str(self.letter_size)\n\n    def wheel(self, event):\n        if event.delta == 120:\n            self.big_letters()\n        else:\n            self.small_letters()\n\n    def popup(self,\n        title=\"\",\n        sentence=\"\"):\n        \"Simple wrapper function for messagebox.showinfo\"\n\n        tk.Tk().withdraw()\n        name = messagebox.showinfo(\n                title=title,\n                message=sentence)\n\n    def save(self):\n        \"Saves the file selected in the listbox\"\n        if self.filename != \"\":\n            try:\n                with open(f\"{self.folder}\/{self.filename}\", \"w\") as file:\n                    file.write(self._text.get(\"0.0\", tk.END))\n            except:\n\n                self.popup(\"Message\", \"Nothing selected\")\n\n\n    def delete(self):\n        try:\n            cur = self._lbx.curselection()\n            for i in cur:\n                self.filename = self._lbx.get(i)\n                os.remove(f\"{self.folder}\/{self.filename}\")\n                print(f\"Deleted {self.folder}\/{self.filename}\")\n            self.showlistitems()\n        except OSError as e:\n                    print(\"Failed with:\" , e.sterror)\n                    print(\"Error code:\" , e.code)\n\n\n    def input_filename(self,\n        title=\"Enter a new name\",\n        sentence=\"Do not put the extension\"):\n\n        #tk.Tk().withdraw()\n        name = simpledialog.askstring(title, sentence)\n        try:\n            if name != \"\":\n                return name + self.extension\n        except TypeError:\n            return \"\"\n\n    def run(self, evt):\n        print(\"ok\")\n        print(\"Running: \" + self.folder + \"\\\\\" + self.filename)\n        os.startfile(f\"{self.folder}\\\\{self.filename}\")\n\n\n    def binding(self):\n        self.root.protocol(\"WM_DELETE_WINDOW\", self.quit)\n        self.root.bind(\"&lt;Control-n>\", self.newfile)\n        self.root.bind(\"&lt;Escape>\", self.quit)\n        self._lbx.bind(\"&lt;&lt;ListboxSelect>>\", self.showcontent)\n        self._lbx.bind(\"&lt;Double-Button-1>\", self.run)\n        self._lbx.bind(\"&lt;B1-Motion>\", self.multiple_select)\n        self._text.bind(\"&lt;Control-s>\", lambda x: self.save())\n        self._text.bind(\"&lt;Control-MouseWheel>\", self.wheel)\n\n    def multiple_select(self, evt):\n        print(\"Hello\")\n\n    def open_folder(self):\n    \t# print(self.filename)\n    \tos.startfile(self.folder)\n\n    def quit(self, evt=\"\"):\n    \t#self.save()\n    \tself.root.destroy()\n\n    def newfile(self, evt):\n        \"Create a new file\"\n        self.save()\n        self.newfilename = self.input_filename()\n        if newfilename != \"\":\n            with open(f\"snippets\/{self.newfilename}\", \"w\") as file:\n                pass\n            self._lbx.insert(0, self.newfilename)\n\n\n    def newfile2(self):\n        \"Create a new file\"\n        self.save()\n        newfilename = self.input_filename()\n        if newfilename != \"\":\n            with open(f\"{self.folder}\/{newfilename}\", \"w\") as file:\n                pass\n            self._lbx.insert(0, newfilename)\n        return newfilename\n\n    def showlistitems(self):\n        self._lbx.delete(0, tk.END)\n        list_of_items = os.listdir(f\"{self.folder}\")\n        list_of_items.sort()\n        for file in list_of_items:\n            if file.endswith(self.extension):\n                self._lbx.insert(0, file)\n        self._lbx.focus()\n    \n    def window(self):\n        \"Contains all the widgets\"\n        \n        def frame0():\n            \"Contains the text\"\n            self._frame0 = tk.Frame(self.root, bg=\"gold\")\n            self._frame0.grid(\n                column=0,\n                row=0,\n                columnspan=2,\n                sticky=\"nswe\"\n                )\n            self._frame0.grid_rowconfigure(0, weight=0)\n            self._frame0.grid_columnconfigure(0, weight=0)\n            self._frame0.grid_columnconfigure(1, weight=0)\n        \n        def label_banner():\n            \"This is at 0,0 and occupies 2 column\"\n            img = tk.PhotoImage(file=f\"{self.folder}\/banner.png\")\n            self.lb_banner = tk.Label(self._frame0, image=img, bg=\"yellow\")\n            self.lb_banner.image = img\n            self.lb_banner.grid(\n                column=0,\n                row=0,\n                columnspan=2,\n                sticky=\"nswe\"\n                )\n\n        def frame():\n            \"Contains the list of chapter names in listbox\"\n            self._frame = tk.Frame(self.root, bg=\"gray\")\n            self._frame.grid(column=0, row=1, sticky=\"nswe\")\n            for n in range(9):\n                self._frame.grid_rowconfigure(n, weight=1)\n            self._frame.grid_columnconfigure(0, weight=1)\n            # self._frame.grid_columnconfigure(1, weight=1)\n        \n        def frame2():\n            \"Contains the text\"\n            self._frame2 = tk.Frame(self.root, bg=\"gold\")\n            self._frame2.grid(column=1, row=1, sticky=\"nswe\" )\n            self._frame2.grid_rowconfigure(0, weight=1)\n            # self._frame2.grid_rowconfigure(1, weight=1)\n            self._frame2.grid_columnconfigure(0, weight=1, minsize=1)\n        \n\n        def listbox():\n            \"The book chapter name list goes here\"\n            self._lbx = tk.Listbox(\n                self._frame,\n                bg=\"yellow\",\n                # selectmode=tk.MULTIPLE\n                )\n            self._lbx.grid(\n                column=0,\n                row=0,\n                sticky=\"nswe\"\n                ) # adapt the listbox to the frame\n            # self._lbx.configure(selectmode=\"\")\n            self.showlistitems()\n\n        def button(text, column, row, command):\n            \"The book chapter name list goes here\"\n            but1 = tk.Button(self._frame,\n                text=text,\n                bg=\"yellow\",\n                command=command)\n            but1.grid(\n                column=column,\n                row=row,\n                sticky=\"nswe\"\n                ) # adapt the listbox to the frame\n\n        def scrollbars():\n            self.scrollbar = tk.Scrollbar(self._frame2)\n            self.scrollbar.grid(column=2, row=0,\n                sticky=\"nswe\")\n\n        def text():\n            \"Contains the text of selected chapter in listbox\"\n            self._text = tk.Text(self._frame2, wrap=tk.WORD)\n            self._text.grid(column=0, row=0, sticky=\"nswe\")\n            self._text.config(yscrollcommand=self.scrollbar.set)\n            self.scrollbar.config(command=self._text.yview)\n            \n        def widgets_order():\n            \"The widgets on the screen\"\n            frame0()\n            frame()\n            frame2()\n            label_banner()\n            listbox()\n            button(\"save\", 0, 1, self.save)\n            button(\"new\", 0, 2, self.newfile2)\n            button(\"delete\", 0, 3, self.delete)\n            button(\"open fld\", 0, 4, self.open_folder)\n            button(\"Files .py\", 0, 5, lambda: self.new_file_extension(\".py\"))\n            button(\"Files .txt\", 0, 6, lambda: self.new_file_extension(\".txt\"))\n            button(\"Join\", 0, 7, self.join)\n            button(\"CLEAR\", 0, 8, self.clear)\n            scrollbars()\n            text()\n            \n        widgets_order()\n\n    def write_in_text(self, text):\n        self._text.delete(\"0.0\", tk.END)\n        self._text.insert(tk.END, text)\n        # self._lbx.config(state=\"normal\")\n\n    def join(self):\n        print(\"Joining all files\")\n        text = \"\"\n        # self._lbx.config(state=tk.DISABLED)\n        list_files = [f for f in os.listdir(\"snippets\/\") if f.endswith(self.extension)]\n        print(list_files)\n        list_files.sort()\n        for file in list_files:\n            with open(f\"snippets\/{file}\") as file_to_add:\n                text += file.split(\".\")[0] + \"\\n=========\\n\"\n                text += file_to_add.read()\n            text += \"\\n\\n\\n\\n\\n\"\n        self.write_in_text(text)\n        # self.nf = self.newfile2()\n        # self.save()\n\n    \n    def new_file_extension(self, ext):\n        self.extension = ext\n        self.showlistitems()\n\n    def showcontent(self, evt):\n        self._lbx.focus_set()\n        #self.save()\n        try:\n            filenum = self._lbx.curselection()\n            self.filename = self._lbx.get(filenum)\n            with open(f\"{self.folder}\/{self.filename}\") as file:\n                content = file.read()\n            self._text.delete(\"0.0\", tk.END)\n            self._text.insert(tk.END, content)\n        except:\n            self.save()\n\n    def clear(self):\n        self._text.delete(\"0.0\", tk.END)\n        self.save()\n\ndef create_chapters_folder(folder):\n    \"Create the folder for the snippets if not exists\"\n    if folder not in os.listdir():\n        os.mkdir(folder)\n        print(\"Created a folder named chatpters\")\n\ndef console_intro():\n    print(\"\"\"\nSave your chapters in chapters folder\n\"\"\")\n\n# ================ main ============\nif __name__ == \"__main__\":\n    console_intro()\n    ###########################################################\n    # CHOOSE TYPE OF FILE AND THE FOLDER WHERE YOU STORE THEM #\n    #\n    #  In case you want to store txt files change to .txt the\n    #  FILE_EXTENSION costant.\n    #  If you need to change the name of the folder where to\n    #  search or save the files change the FOLDER_FOR_FILES\n    #  value to the name of the folder you want\n    #  \n    #                  https:\/\/pythonprogramming.altervista.org\n    #\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\n    FOLDER_FOR_FILES = \"snippets\"\n    FILE_EXTENSION = \".txt\"\n    #\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\u00b0\n    create_chapters_folder(FOLDER_FOR_FILES)\n    ver = \"0.1\"\n    win = Win(__file__, \"1.1\",\n        folder=FOLDER_FOR_FILES,\n        extension=FILE_EXTENSION)\n    win.root.mainloop()<\/pre>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-20.png\"><img loading=\"lazy\" decoding=\"async\" width=\"800\" height=\"600\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-20.png\" alt=\"\" class=\"wp-image-8232\" srcset=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-20.png 800w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-20-320x240.png 320w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2021\/01\/image-20-768x576.png 768w\" sizes=\"auto, (max-width: 800px) 100vw, 800px\" \/><\/a><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\"><!-- se vuoi mettere un testo scorrevole\r\n[hoops name=\"typeWriterGen\"]\r\n\r\npoi metti un id diverso per ogni testo nella stessa pagina\r\n\r\n<div id=\"div01\">\r\n<script>\r\n\r\ntypeWriterGen(\"div01\",\"Esempio di testo scorrevole\");\r\n<\/script>\r\n\r\n-->\r\n<style>\r\n.avatar {\r\n  vertical-align: middle;\r\n  width: 100px;\r\n  height: 100px;\r\n  border-radius: 50%;\r\n}\r\n<\/style>\r\n\r\n<hr>\r\n\r\n<!-- NEWSLETTER LINK -->\r\n<a href=\"https:\/\/docs.google.com\/forms\/d\/e\/1FAIpQLSf7TniIPCWHDzCSGh2dYZaCwDvi9yLKS5ovFdKuK1sdfOvwEg\/viewform\">\r\n<img decoding=\"async\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2023\/08\/image-13.png\" class=\"avatar\">\r\nSubscribe to the <b>newsletter<\/b> for updates<\/a><br>\r\n\r\n<!-- TKINTER TEMPLATE LINK -->\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/tkinter-templates\/\">\r\n<img decoding=\"async\" src=\"https:\/\/i0.wp.com\/pythonprogramming.altervista.org\/wp-content\/uploads\/2023\/07\/image-26.png\" class=\"avatar\">\r\nTkinter templates<\/a><br>\r\n\r\n<!-- MY AVATAR PUT A LINK TO YOUTUBE CHANNEL-->\r\n<iframe loading=\"lazy\" frameborder=\"0\" src=\"https:\/\/itch.io\/embed\/711828\" width=\"552\" height=\"167\"><a href=\"https:\/\/pythonprogrammi.itch.io\/pysnake\">PySnake by PythonProgrammi<\/a><\/iframe>\r\n<br>\r\n<style>\r\n.avatar {\r\n  vertical-align: middle;\r\n  width: 100px;\r\n  height: 100px;\r\n  border-radius: 50%;\r\n}\r\n<\/style>\r\n\r\n\r\n<a href=\"https:\/\/www.youtube.com\/channel\/UCzbxq5e9gLiY-je2-br1rvg\">\r\n\t<img decoding=\"async\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2020\/10\/avatar64x64.png\" alt=\"Avatar\" class=\"avatar\">\r\n\t My youtube channel<\/a><br>\r\n\r\n<br>\r\n\r\nTwitter: <a href=\"https:\/\/twitter.com\/pythonprogrammi\">@pythonprogrammi - python_pygame<\/a>\r\n<h3>Claude's Games<\/h3>\r\n<p><a href=\"https:\/\/pythonprogramming.altervista.org\/random-daily-game-1-arkanoid\/\">Arkanoid<\/a><br>\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/platform-2d-with-pygame-made-with-claude\/\">Platform 2d<\/a><\/p> <!-- videogames made with claude -->\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/artifacts-games-day-1-memory-game\/\">1. Memory game<\/a>\r\n<h4>Videos<\/h4>\r\n<a href=\"https:\/\/youtu.be\/ciLjWWw5pLY\">Speech recognition game<\/a>\r\n<h3>Pygame's Platform Game<\/h3>\r\n\r\n<a href=\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-5-sounds-and-mixer\/\"><img decoding=\"async\" src=\"https:\/\/i1.wp.com\/pythonprogramming.altervista.org\/wp-content\/uploads\/2020\/01\/climbercover.png?w=557&ssl=1\"\/ width=\"50%\"><\/a>\r\n<script>\r\nvar title = \"Platform Pygame\";\r\n\t\tvar links = [\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-animation-of-a-sprite-v-1-3\/\",\"Animation 1.3\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-sprite-animation-v-2-better-coding-test-it-checking-fps-on-the-screen\/\",\"Animation 1.2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-how-to-display-the-frame-rate-fps-on-the-screen\/\",\"Display Frame rate\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-sprite-animation-update\/\",\"Animation 1.1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platformer-1\/\",\"Pygame Platform Game 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/python-platform-game-2\/\",\"Pygame Platform 2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-3-recap-cheatsheet\/\",\"Pygame PLatform 3 - recap and some Cheat Sheet\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-4-background-and-stuffs\/\",\"Pygame Platform 4 - Background & organizing code\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platform-game-5-sounds-and-mixer\/\",\"Pygame Platform 5 - Sounds\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/platform-game-in-detail-part-1\/\",\"Game in detail part 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/map-maker-1-2\/\", \"Map maker 1.2\"]\r\n\t\t];\r\n\t\t<\/script>\r\n<script>\r\n\t\r\nif (typeof next2 != \"undefined\"){let next2 = 0;}\r\n\t\r\nnext2 = 0;\r\n\thtml = \"\";\/\/<b style='color:coral;font-size:1.2em'>Other posts about \" + title + \"<\/b><br>\";\r\nfor (address of links) \r\n{\r\n\r\n\tif (next2 == 1){\r\n\t\thtml += \"<div style='background:coral'>\";\r\n\t\thtml += \"Next link => <a href='\" + address[0] + \"'>\" + address[1] + \"<\/a>\";\r\n\t\thtml += \"<\/div><br>\";\r\n\t\tnext2 = 0;\r\n\t}\r\n\tif (address[0] == document.URL) {\r\n\t\tnext2 = 1;\r\n\t}\r\n}\r\n\r\nif (typeof next != \"undefined\") {let next = 0;}\r\nif (typeof addressStart != \"undefined\") {let addressStart = \"\";}\r\nnext = 0;\r\naddressStart = \"<a href='\";\r\nfor (address of links) {\r\n\tif (next == 1){\r\n\t\thtml += \">>>\" + addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t\tnext = 0;\r\n\t}\r\n\telse if (addressStart + address[0] != document.URL)\r\n\t{\r\n\t\thtml += addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t}\r\n\telse\r\n\t{\r\n\t\tnext = 1;\r\n\t\tnext_address = address[0]\r\n\t\tnext_title = address[1]\r\n\t\thtml += \"<span style='color:gray'>\" + address[1] + \"<\/span><br>\";\r\n\t}\r\n\r\n}\r\n\r\n\thtml += `<span style=\"font-size:8px\">Powered by <a href=\"https:\/\/pythonprogramming.altervista.org\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-2673\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png\" alt=\"\" width=\"70\" height=\"25\" srcset=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png 156w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2-150x56.png 150w\" sizes=\"auto, (max-width: 70px) 100vw, 70px\" \/>pythonprogramming.altervista.org<\/a><\/span>`\r\n\thtml = \"<div style='background:yellow'>\" + html + \"<\/div>\";\r\n\tdocument.write(html)\r\n<\/script>\r\n\r\n<h3>Other Pygame's posts<\/h3>\r\n\r\n<script>\r\nvar title = \"Pygame's Posts\"\r\nvar links = [\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-platformer-1\/\",\"Platform game 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/make-a-platform-game-with-pygame-dafluffypotato\/\",\"DaFluffyPotato Platform Tutorials\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/python-and-classic-arcade-games-pong\/\",\"Pong Game Full\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/python-draws-in-colors-app-to-draw-with-pygame\/\",\"PyGameGIF 2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-draw-app-with-animation\/\",\"PyGameGIF 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pydraw-2-0-app-to-draw-gif\/\",\"PyDraw 2.0\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-drawing-2\/\",\"Draw with Pygame\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/animation-with-pygame\",\"Sprite animation 1\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/animation-on-pygame-2-free-characters-and-more-actions\/\",\"Sprite animation 2\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/starting-with-pygame\/\",\"Starting movements with Pygame\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-3-move-sprite\/\", \"Move a Sprite\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-4-fonts\/\",\"Text and Fonts\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-animate-a-sprite\/\", \"Animate a sprite\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pygame-and-mouse-events\/\",\"Mouse events\"],\r\n[\"https:\/\/pythonprogramming.altervista.org\/pgp-aka-pygamepresentation-project\/\",\"Pygame presentation\"],\r\n\t[\"https:\/\/pythonprogramming.altervista.org\/moving-the-player-in-pygame-with-key-get_pressed\/\",\"How to use key.get_pressed()\"]\r\n]\r\n<\/script>\r\n\r\n\r\n<script>\r\n\t\r\nif (typeof next2 != \"undefined\"){let next2 = 0;}\r\n\t\r\nnext2 = 0;\r\n\thtml = \"\";\/\/<b style='color:coral;font-size:1.2em'>Other posts about \" + title + \"<\/b><br>\";\r\nfor (address of links) \r\n{\r\n\r\n\tif (next2 == 1){\r\n\t\thtml += \"<div style='background:coral'>\";\r\n\t\thtml += \"Next link => <a href='\" + address[0] + \"'>\" + address[1] + \"<\/a>\";\r\n\t\thtml += \"<\/div><br>\";\r\n\t\tnext2 = 0;\r\n\t}\r\n\tif (address[0] == document.URL) {\r\n\t\tnext2 = 1;\r\n\t}\r\n}\r\n\r\nif (typeof next != \"undefined\") {let next = 0;}\r\nif (typeof addressStart != \"undefined\") {let addressStart = \"\";}\r\nnext = 0;\r\naddressStart = \"<a href='\";\r\nfor (address of links) {\r\n\tif (next == 1){\r\n\t\thtml += \">>>\" + addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t\tnext = 0;\r\n\t}\r\n\telse if (addressStart + address[0] != document.URL)\r\n\t{\r\n\t\thtml += addressStart + address[0] + \"'>\" + address[1] + \"<\/a><br>\";\r\n\t}\r\n\telse\r\n\t{\r\n\t\tnext = 1;\r\n\t\tnext_address = address[0]\r\n\t\tnext_title = address[1]\r\n\t\thtml += \"<span style='color:gray'>\" + address[1] + \"<\/span><br>\";\r\n\t}\r\n\r\n}\r\n\r\n\thtml += `<span style=\"font-size:8px\">Powered by <a href=\"https:\/\/pythonprogramming.altervista.org\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-2673\" src=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png\" alt=\"\" width=\"70\" height=\"25\" srcset=\"https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2.png 156w, https:\/\/pythonprogramming.altervista.org\/wp-content\/uploads\/2019\/06\/altervista2-150x56.png 150w\" sizes=\"auto, (max-width: 70px) 100vw, 70px\" \/>pythonprogramming.altervista.org<\/a><\/span>`\r\n\thtml = \"<div style='background:yellow'>\" + html + \"<\/div>\";\r\n\tdocument.write(html)\r\n<\/script><\/p>\n","protected":false},"excerpt":{"rendered":"This app is made to take notes of what you want to build. It is a wip, so there are many bugs, the \n<a class=\"moretag\" href=\"https:\/\/pythonprogramming.altervista.org\/pybook-version-2-6\/\"> [...]<\/a>","protected":false},"author":1,"featured_media":8232,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_crdt_document":"","footnotes":""},"categories":[1,49,923],"tags":[924,957,534,4,51],"class_list":["post-8225","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-examples","category-tkinter","category-tkinter-advanced","tag-advanced","tag-memo","tag-notepad","tag-python","tag-tkinter"],"avopt_banners_inside_post":true,"avopt_banners_on_page":true,"av_copy_from":"","av_sharing_message":"","av_sharing_allowed":true,"av_sharing_on":{"fb":[],"tw":[]},"av_allow_affiliate_banner":false,"av_allow_affiliate_multi_banner":false,"av_show_affiliation_buy_button":false,"av_post_rating":true,"av_have_post_rating_value":false,"av_is_artificial_intelligence_content":false,"_links":{"self":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts\/8225","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/comments?post=8225"}],"version-history":[{"count":3,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts\/8225\/revisions"}],"predecessor-version":[{"id":8235,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/posts\/8225\/revisions\/8235"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/media\/8232"}],"wp:attachment":[{"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/media?parent=8225"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/categories?post=8225"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/pythonprogramming.altervista.org\/wp-json\/wp\/v2\/tags?post=8225"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}