Есть ответ 👍

У меня есть скрипт и интерфейс, код интерфейса снизу, мне нужно сделать чтобы запускался и он и скрипт одновременно

281
295
Посмотреть ответы 2

Ответы на вопрос:

annafa5
4,6(47 оценок)

Если вы запустите одновременно "интерфейс" и скрипт, вы никак не сможете обмениваться данными между ними. Это будут два независимых скрипта, исполняемых параллельно. Для реализации программ, использующих графические интерфейсы пользователя, обычно используют ОО-стиль, и основное окно приложения описывается классом, наследующим какой либо графический элемент (в tkinter чаще всего наследуются либо от tkinter.Frame, либо от базового класса tkinter.Tk). В таком классе вы без проблем сможете описать методы, выполняющие различные действия (для работы с интернетом используйте потоки или asyncio, иначе окно приложения будет зависать), и из которых будут доступны все элементы GUI, если те являются атрибутами вашего класса.

В качестве примера такой реализации приведу вам код, который я когда то давно писал. Из него вы сможете понять один из шаблонов создания приложений с граф. интерфейсом на базе ОО и библиотеки tkinter. Суть этого приложения была донельзя - оно рисовало беспорядочные треугольники внутри графического окна. К вашему сожалению, приложения с GUI, делающие что либо более полезное, я так, на всеобщее обозрение, кидать не буду.

import tkinter as tk  

import random

import threading

import time

class TriangleStruct(object):

   def __init__(self, fx, fy, sx, sy, thx, thy):

       self.leftuppercorner = {'leftupper_x': fx, 'leftupper_y' : fy}

       self.secondcorner = {'middle_x': sx, 'middle_y':sy}

       self.thirdcorner = {'lower_x' : thx, 'lower_y':thy}

   

class MainWin(tk.Frame):

   def __init__(self, root):

       super().__init__(root)

       root.bind('<space>', self.pause)

       self.avaiable_colors = ['orange', 'red', 'green', 'yellow', 'purple']

       self._graphstack_depth = 7

       self._graphstack_buffer = []

       self.is_run = True

       self.build()

   def build(self):

       self.canv = tk.Canvas(self, width = 640, height = 480)

       self.canv.pack()

       threading.Thread(target=self.infinity_triangle_drawing).start()

   def draw_triangles(self):

       for step in range(self._graphstack_depth):

           self._graphstack_buffer.append(self.gen_rand_triangle())

       for step in range(self._graphstack_depth):

           self.canv.create_polygon(

               (self._graphstack_buffer[step].leftuppercorner['leftupper_x'], self._graphstack_buffer[step].leftuppercorner['leftupper_y']),

               (self._graphstack_buffer[step].secondcorner['middle_x'], self._graphstack_buffer[step].secondcorner['middle_y']),

               (self._graphstack_buffer[step].thirdcorner['lower_x'], self._graphstack_buffer[step].thirdcorner['lower_y']),

               fill = random.choice(self.avaiable_colors),

               outline = 'black'

               )

   def gen_rand_triangle(self):

       firstxpos, firstypos = random.randint(0, 540), random.randint(0, 380)

       secxpos, secypos = random.randint(10, 620), random.randint(10, 440)

       thirdxpos, thirdypos = random.randint(0, 620), random.randint(20, 440)

       return TriangleStruct(firstxpos, firstypos, secxpos, secypos, thirdxpos, thirdypos)

   def infinity_triangle_drawing(self):

       while True:

           if self.is_run:

               self.canv.delete('all')

               self._graphstack_buffer.clear()

               self.draw_triangles()

               time.sleep(0.1)  

           else:

               pass

   def pause(self, event):

       if self.is_run:

           self.is_run = False

       else:

           self.is_run = True

if __name__ == '__main__':

   root = tk.Tk()

   win = MainWin(root)

   win.pack()

   root.title('triangles')

   root.resizable(False, False)

   root.geometry('650x490')

   root.mainloop()

Объяснение:


Снизу

Объяснение:

1 - 1 байт = 8 бит

32000 * 8 / 16000  = 32000 / 16000 * 8 = 16 секунд

2 - 25 * 80 = 2000 Символов помещается на экране.

16 бит - один символ.

1 байт - 8 бит.

2000 * (16 / 8) = 4000 байт

3 - 32 = 2 ^ i

i = 5

1 символ - 5 бит

180 * 5 = 900 бит / 8 = 112,5 байт

Реши свою проблему, спроси otvet5GPT

  • Быстро
    Мгновенный ответ на твой вопрос
  • Точно
    Бот обладает знаниями во всех сферах
  • Бесплатно
    Задай вопрос и получи ответ бесплатно

Популярно: Информатика

Caktus Image

Есть вопросы?

  • Как otvet5GPT работает?

    otvet5GPT использует большую языковую модель вместе с базой данных GPT для обеспечения высококачественных образовательных результатов. otvet5GPT действует как доступный академический ресурс вне класса.
  • Сколько это стоит?

    Проект находиться на стадии тестирования и все услуги бесплатны.
  • Могу ли я использовать otvet5GPT в школе?

    Конечно! Нейросеть может помочь вам делать конспекты лекций, придумывать идеи в классе и многое другое!
  • В чем отличия от ChatGPT?

    otvet5GPT черпает академические источники из собственной базы данных и предназначен специально для студентов. otvet5GPT также адаптируется к вашему стилю письма, предоставляя ряд образовательных инструментов, предназначенных для улучшения обучения.

Подпишись на наш телеграмм канал

GTP TOP NEWS