آموزش Qt Designer (PyQt): روش شروع به کار و نکات کاربردی

رتبه: 5 ار 2 رای SSSSS
qt designer
نویسنده: تیم تولید محتوا زمان مطالعه 8 دقیقه
Banner Image

برنامه ‌های زیادی با استفاده از کد پایتون ایجاد می ‌شوند که در بسیاری از موارد هم عالی عمل می ‌کنند، اما با بزرگ‌ تر شدن برنامه‌ ها یا پیچیده ‌تر شدن رابط‌ ها، تعریف همه ویجت ‌ها در قالب برنامه ‌نویسی می ‌تواند کمی دشوار باشد. خبر خوب این است که Qt یک ویرایشگر گرافیکی به نام Qt Designer دارد که حاوی ویرایشگری است که با کشیدن و رها کردن کار می ‌کند. با استفاده از Qt Designer می ‌توانید رابط کاربری خودتان را به صورت بصری تعریف کنید و سپس به سادگی منطق برنامه را بعدا به آن ربط بدهید.

در این مقاله اصول ایجاد رابط کاربری با Qt Designer را پوشش خواهیم داد . اصول، آرایش و ویجت ‌ها یکسان هستند، بنابراین می ‌توانید همه چیز هایی که قبلا آموخته‌ اید را پیاده ‌سازی کنید. البته باید با Python API هم آشنا باشید تا بتوانید منطق برنامه را بعدا با رابط هماهنگ کنید.

برای پیش رفتن با این آموزش لازم است Qt Creator را نصب کنید. شما می ‌توانید آن را به صورت رایگان از وب سایت Qt دانلود کنید. به https://www.qt.io/download بروید و بسته Qt را دانلود کنید . البته می‌ توانید فقط Creator را نصب کنید.

Qt Creator را باز کنید، با پنجره اصلی روبرو خواهید شد. دیزاینر از زبانه سمت چپ در دسترس است. با این حال، برای فعال کردنش اول باید یک فایل .uiرا فعال کنید.

The Qt Creator interface, with the Design section shown on the left.

برای ایجاد یک فایل .ui به قسمت File > New File or Project بروید . . . در پنجره ظاهر شده Qt را در قسمت Files and Classes در سمت چپ انتخاب کنید، سپس Qt Designer Form را در سمت راست انتخاب کنید. متوجه خواهید شد که نماد “ui” روی آن قرار دارد که نوع فایلی که ایجاد می‌ کنید را نشان می‌ دهد.

Create a new Qt .ui file.

در مرحله بعد از شما پرسیده می ‌شود که چه نوع ویجتی را می‌ خواهید ایجاد کنید. اگر در حال راه اندازی یک برنامه هستید، Main Window گزینه مناسبی است. با این حال، شما می ‌توانید فایل های .ui را برای کادر های محاوره‌ ای، فرم ‌ها و ویجت ‌های ترکیبی سفارشی ایجاد کنید.

Select the type of widget to create, for most applications this will be Main Window. بعد یک نام برای فایل انتخاب کرده و پوشه فایل تان را ذخیره کنید. فایل .ui تان را با همان نام کلاسی که می ‌سازید ذخیره کنید تا دستورات بعدی هم ساده ‌تر شوند.

Choose save name and folder your your file.

در نهایت، اگر از سیستم کنترل نسخه استفاده می ‌کنید، می‌ توانید انتخاب کنید که فایل را به سیستم کنترل نسخه‌ تان اضافه کنید یا خیر. از این مرحله رد شوید زیرا روی رابط کاربری تان تأثیری ندارد .

Optionally add the file to your version control, e.g. Git.

در کنار این مطلب بخوانید: آموزش شی گرایی در پایتون برای مبتدیان (به زبان ساده)

آرایش پنجره اصلی

پنجره اصلی جدید ایجاد شده در طراح رابط کاربری به شما نمایش داده می ‌شود. اول کار چیز زیادی وجود ندارد، فقط یک ناحیه کاری خاکستری که نمایانگر پنجره است همراه با ابتدای نوار منوی پنجره دیده می‌ شود.

The initial view of the created main window.

می ‌توانید با کلیک کردن روی پنجره و کشیدن دستگیره‌ های آبی رنگ در هر گوشه، اندازه پنجره را هم تغییر بدهید.

The initial view of the created main window.

اولین گام در ساختن یک برنامه، افزودن تعدادی ویجت به پنجره است. در اولین برنامه‌های مان یاد گرفتیم که برای تنظیم ویجت مرکزی برای یک QMainWindowباید از .()setCentralWidget. استفاده کنیم. همچنین دیدیم که برای افزودن چندین ویجت با یک طرح ‌بندی، به یک QWidgetواسطه نیاز داریم تا طرح را روی آن اعمال کنیم ، نه این که طرح را مستقیما به پنجره اضافه کنیم.

Qt Creator به طور خودکار این کار را برای تان انجام می ‌دهد.

برای افزودن چندین ویجت به پنجره اصلی که طرحی دارد ، اول ویجت ‌های تان را روی QmainWindow بکشید. در این جا ما 3 برچسب یا Label را می ‌کشیم. مهم نیست کجا رهای شان کنیم.

Main window with 1 labels and 1 button added.

ما 2 ویجت را با کشیدن شان روی پنجره ایجاد و آن ها را فرزندان آن پنجره کرده ‌ایم. حالا می ‌توانیم آن ها را بچینیم.

QmainWindow را در پنل سمت راست پیدا (باید در بالا باشد) پیدا کنید . در زیر centralwidget را می ‌بینید که ویجت مرکزی پنجره را نشان می ‌دهد. نماد ویجت مرکزی طرح فعلی اعمال شده را نشان می‌ دهد. اولش یک دایره قرمز رنگ دارد که نشان می ‌دهد هیچ آرایش فعالی وجود ندارد.

روی شی QmainWindow کلیک راست کرده و”Layout” را در منوی آبشاری پیدا کنید .

Right click on the main window, and choose layout.

سپس لیستی از طرح ها را می ‌بینید که می ‌توانید آن ‌ها را روی پنجره اعمال کنید . Lay Out Horizontally را انتخاب کنید تا این آرایش روی ویجت اعمال می ‌شود.

Select layout to apply to the main window.

آر انتخاب ‌شده روی ویجت مرکزی QMainWindow اعمال می ‌شود و ویجت ‌ها به چیدمان اضافه و بسته به آرایش انتخاب ‌شده چیده می ‌شوند. توجه داشته باشید که در Qt Creator می ‌توانید ویجت ‌ها را در چیدمان موجود بکشید و دوباره مرتبش کنید ، یا آرایش دیگری را به دل خواه انتخاب کنید.

یادگیری هر زبان برنامه نویسی به صورت کاملا رایگان

استفاده از فایل .ui تولید شده توسط شما

ما یک رابط کاربری بسیار ساده ایجاد کرده‌ ایم. گام بعدی این است که این رابط را وارد پایتون و از آن برای ساختن یک برنامه کاربردی استفاده کنید.

ابتدا فایل .ui را ذخیره کنید . این فایل به طور پیش فرض در مکانی که هنگام ایجاد آن انتخاب کرده ‌اید، ذخیره می‌ شود، البته در صورت تمایل می ‌توانید مکان دیگری را انتخاب کنید.

فایل .uiبا فرمت XML خواهد بود . برای استفاده از رابط کاربری پایتون ما دو روش جایگزین داریم:

1-بارگذاری در یک کلاس با استفاده از متد .()loadUI

2- تبدیل رابط به پایتون با استفاده از ابزار.pyuic6

در ادامه به این دو متد پرداخته شده است. من شخصا ترجیح می ‌دهم رابط کاربری را به یک فایل پایتون تبدیل کنم تا همه چیز از نظر برنامه ‌نویسی و بسته ‌بندی یک جور بماند .

بارگذاری مستقیم فایل .ui

برای بارگذاری فایل های .ui می‌توانیم از ماژول uicموجود در PyQt6، یعنی متد ()uic.loadUI استفاده کنیم. این متد نام فایل یک فایل رابط کاربری را می‌گیرد و با ایجاد یک شی PyQt6 کاملا کاربردی آن را بارگیری می‌کند.

import sys

from PyQt6 import QtWidgets, uic

app = QtWidgets.QApplication(sys.argv)

چرب زبان

طراحی رابط کاربری UI UX رو قورت بده! بدون کلاس، سرعت 2 برابر، ماندگاری 3 برابر، پولسازی عالی با طراحی جذاب اپلیکیشن، نرم افزار وبسایت... دانلود:

window = uic.loadUi(“mainwindow.ui”)

window.show()

app.exec()

A (very) simple UI designed in Qt Creator

از آن جایی که متد ()uid.loadUI یک شی نمونه را تبدیل می ‌کند، نمی ‌توانید کد سفارشی ()__init__را پیوست کنید. با این حال، می ‌توانید از طریق یک تابع تنظیم سفارشی این کار را انجام بدهید.

برای بارگیری یک رابط کاربری از بلوک __init__یک ویجت موجود (مثلاQmainWindow ) می ‌توانید از uic.loadUI(filename, self) برای PyQt6 استفاده کنید.

import sys

from PyQt6 import QtCore, QtGui, QtWidgets

from PyQt6 import uic

class MainWindow(QtWidgets.QMainWindow):

def __init__(self, *args, **kwargs):

super().__init__(*args, **kwargs)

uic.loadUi(“mainwindow.ui”, self)

app = QtWidgets.QApplication(sys.argv)

window = MainWindow()

window.show()

app.exec_()

تبدیل فایل .ui به پایتون

برای تولید یک فایل خروجی پایتون، pyuic6 را از خط فرمان اجرا کنید . فایل .uiو فایل هدف را با یک پارامتر -oبرای خروجی ارسال کنید. مثال زیر یک فایل پایتون به نام MainWindow.py که حاوی رابط کابری ایجاد شده توسط ما است را ایجاد می ‌کند.

pyuic6 mainwindow.ui -o MainWindow.py

اگر از PyQt5 استفاده می‌ کنید، این ابزار ” pyuic4 ” نام دارد.

شما می توانید فایل به دست آمده MainWindow.py را به منظور بررسی در یک ویرایشگر باز کنید ، البته نباید این فایل را ویرایش کنید . مزیت استفاده از Qt Creator این است که می ‌توانید برنامه را در حین توسعه ویرایش، بهینه ‌سازی و به روز رسانی کنید. هر تغییری که در این فایل ایجاد شده باشد ، با به روز رسانی آن از بین خواهد رفت. با این حال ، هنگام وارد کردن و استفاده از فایل در برنامه‌های تان، می ‌توانید هر چیزی که دوست دارید را لغو کنید و تغییر هم بدهید.

وارد کردن فایل پایتون حاصل مثل هر فایل دیگری است. می‌ توانید کلاس تان را به صورت زیر وارد کنید . ابزار pyuic6 رابط کاربری را به نام شی تعریف شده در Qt Creator اضافه می ‌کند و این همان شی‌ ای است که می‌ خواهید وارد کنید.

from MainWindow import Ui_MainWindow

برای ایجاد پنجره اصلی در برنامه‌ تان، یک کلاس به صورت عادی اما هم در قالب زیر کلاسی از QmainWindow و هم کلاس Ui_MainWindowکه وارد کرده ‌اید، ایجاد کنید . در نهایت، self.setupUi(self) را از داخل __init__برای این که سبب راه‌ا ندازی رابط شود ، فراخوانی کنید.

import sys

from PyQt6 import QtWidgets, uic

from MainWindow import Ui_MainWindow

class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):

def __init__(self, *args, obj=None, **kwargs):

super(MainWindow, self).__init__(*args, **kwargs)

self.setupUi(self)

app = QtWidgets.QApplication(sys.argv)

window = MainWindow()

window.show()

app.exec()

این دقیقا همان نتیجه قبلی را تولید می‌ کند.

همین! پنجره شما حالا به صورت کامل تنظیم شده است. از آن جایی که استفاده از یک فایل .ui کد مختص رابط کاربری را خلاصه می ‌کند، می ‌توانید از همین الگو برای بار گذاری هر رابطی که طراحی می ‌کنید، استفاده کنید.

اضافه کردن منطق برنامه

می‌ توانید با ویجت‌ هایی که از طریق Qt Creator ایجاد شده‌ اند، مثل آن هایی که با کد ایجاد کرده ‌اید، رفتار کنید. برای ساده ‌تر کردن کار ها، uicهمه ویجت‌ های فرزند را با نام شناسه ‌شان همان طور که در Qt Creator مشخص شده است به شی پنجره اضافه می ‌کند.

حتما دانلود کنید: آموزش صفر تا صد پایتون

profile name
تیم تولید محتوا

بخندید کتاب بخونید و خوب باشید تا جامعه مون به آرامش برسه. لطفا ! هر سوالی دارید در بخش نظرات مطرح کنید. ما یا سایر هموطنان عزیز پاسخ خواهیم داد. برای کمک به سایت ما و گسترش آموزش در بین هموطنان، در سایتها، وبلاگ ها و شبکه های اجتماعی لینک سایت ما را درج کنید.

مطالب پیشنهادی برای شما

محصولات مرتبط

مشاهده همه

دیدگاهتان را بنویسید

1 2 3 4 5

0 نظر درباره «آموزش Qt Designer (PyQt): روش شروع به کار و نکات کاربردی»

  • ناشناس
    ناشناس آیا این دیدگاه مفید بود ؟

    خیلی تمیز و خلاصه

    پاسخ
  • ناشناس
    ناشناس آیا این دیدگاه مفید بود ؟

    ok

    پاسخ
مشاهده همه نظرات
سبد خرید
سبد خرید شما خالی است
× جهت نصب روی دکمه زیر در گوشی کلیک نمائید
آی او اس
سپس در مرحله بعد برروی دکمه "Add To Home Screen" کلیک نمائید