OCCT3D (Open CASCADE Technology) Open Source 8.0 bylo vydáno. OCCT3D (Wikipedie, GitHub) je objektově orientovaná knihovna pro 3D CAD, CAM nebo CAE. Používá se například v softwarech FreeCAD a KiCad.
Ve FreeBSD byla nalezena a již opravena 21letá zranitelnost CVE-2026-42511 v dhclient. Jedná se o vzdálené spuštění kódu (RCE). Útočník mající pod správou DHCP server může získat plnou kontrolu nad systémem FreeBSD pouze jeho připojením k místní síti.
Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.3. Současně oznámila, že nadcházející větší vydání 24.04-2.0 bude mít modernější webový prohlížeč.
Ploopy po DIY trackballech či sluchátkách představuje nový externí DIY trackpoint se čtyřmi tlačítky Bean. Obsahuje snímač Texas Instruments TMAG5273, spínače Omron D2LS-21 a řadič RP2040, používá firmware QMK. Schémata jsou na GitHubu; sadu lze předobjednat za 69 kanadských dolarů (bez dopravy a DPH).
Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.
Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].
Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.
Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.
Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
S qt4 si hraju celkem krátce, ale nikde nemůžu příjít na následující. V QtDesigneru si udělám hlavní okno (MainWindow). V něm mi vše funguje jak má. Pak si vytvořím Widget (formulář), ten si naimportuju do hlavního programu, ale už nevím, jak ho z MainWindow mám spustit (zobrazit). Omlouvám se za tenhle asi stupidní dotaz, ale nikde to nemůžu nalézt. Díky
Chtělo by to více přiblížit co vlastně chceš. Příklad jak to přibližně máš. Máš definici window.ui a form.ui. Ve fci main() voláš zobrazení window a zároveň chceš zobrazit i form. Ten zobrazíš stejně jako window:
QWidget *form_widget = new QWidget;
Ui_Form form_ui;
form_ui.setupUi(form_widget);
form_widget->show();
Nebo ho chceš zobrazit kliknutím na tlačítko ve window? Pak opět použiješ předchozí kód, jen ho vložíš do fce, která se zavolá po kliknutí na tlačítko. (Signals and Slots)
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'untitled.ui'
#
# Created: Wed Dec 05 14:22:22 2007
# by: PyQt4 UI code generator 4.3.1
#
# WARNING! All changes made in this file will be lost!
import sys,urllib
from PyQt4 import QtCore, QtGui
data = urllib.urlopen("http://www.google.com/")
yazdir = data.read()
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
MainWindow.setObjectName("MainWindow")
MainWindow.resize(QtCore.QSize(QtCore.QRect(0,0,640,800).size()).expandedTo(MainWindow.minimumSizeHint()))
self.centralwidget = QtGui.QWidget(MainWindow)
self.centralwidget.setObjectName("centralwidget")
self.textBrowser = QtGui.QTextBrowser(self.centralwidget)
self.textBrowser.setGeometry(QtCore.QRect(0,0,640,800))
self.textBrowser.setObjectName("textBrowser")
self.textBrowser.setOpenExternalLinks(True)
MainWindow.setCentralWidget(self.centralwidget)
self.menubar = QtGui.QMenuBar(MainWindow)
self.menubar.setGeometry(QtCore.QRect(0,0,623,21))
self.menubar.setObjectName("menubar")
MainWindow.setMenuBar(self.menubar)
self.statusbar = QtGui.QStatusBar(MainWindow)
self.statusbar.setObjectName("statusbar")
MainWindow.setStatusBar(self.statusbar)
self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)
def retranslateUi(self, MainWindow):
MainWindow.setWindowTitle(QtGui.QApplication.translate("MainWindow", "Tarayıcı", None, QtGui.QApplication.UnicodeUTF8))
self.textBrowser.setHtml(yazdir)
if __name__ == "__main__":
import sys
app = QtGui.QApplication(sys.argv)
MainWindow = QtGui.QMainWindow()
ui = Ui_MainWindow()
ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())
A já bych potřeboval, aby po stisknutí tlačítka (které v tomhle příkladě není) se zobrazil další formulář (který si opět vytvořím v qt designeru). Ten vypadá třeba takhle (opět příklad):
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'f_chat2.ui'
#
# Created: Mon Apr 28 10:29:07 2008
# by: PyQt4 UI code generator 4.3.3
#
# WARNING! All changes made in this file will be lost!
import sys
from PyQt4 import QtCore, QtGui
from PyQt4.QtCore import *
from PyQt4.QtGui import *
class Ui_Form(object):
def setupUi(self, Form):
Form.setObjectName("Form")
Form.resize(QtCore.QSize(QtCore.QRect(0,0,478,395).size()).expandedTo(Form.minimumSizeHint()))
self.button_envoyer = QtGui.QPushButton(Form)
self.button_envoyer.setGeometry(QtCore.QRect(350,310,101,31))
self.button_envoyer.setObjectName("button_envoyer")
self.txt = QtGui.QLineEdit(Form)
self.txt.setGeometry(QtCore.QRect(20,310,321,31))
self.txt.setObjectName("txt")
self.fenetre = QtGui.QTextEdit(Form)
self.fenetre.setGeometry(QtCore.QRect(20,30,321,261))
self.fenetre.setObjectName("fenetre")
self.retranslateUi(Form)
QtCore.QObject.connect(self.button_envoyer,QtCore.SIGNAL("clicked()"),self.copier_txt)
QtCore.QMetaObject.connectSlotsByName(Form)
def retranslateUi(self, Form):
Form.setWindowTitle(QtGui.QApplication.translate("Form", "Form", None, QtGui.QApplication.UnicodeUTF8))
self.button_envoyer.setText(QtGui.QApplication.translate("Form", "envoyer", None, QtGui.QApplication.UnicodeUTF8))
def copier_txt(self):
ch = self.txt.text()
ch = unicode(ch, 'UTF-8')
self.fenetre.setText("C>")
self.fenetre.append(QString(ch))
self.txt.clear()
V tomhle formuláři bych potřeboval vybrat položku ze seznamu a tu pak předat při návratu zpět do hlavního okna (ale s tim už se poperu). Teď mi jde o to zobrazení formuláře. Díky
Možná se Ti bude hodit příklad:
#!/usr/bin/python
# -*- coding: utf-8 -*-
import sys
from PyQt4.QtCore import *
from PyQt4.QtGui import *
from ui_window import *
from ui_form import *
class Window(QMainWindow, Ui_MainWindow):
def __init__(self, form):
QMainWindow.__init__(self)
self.setupUi(self)
self.connect(self.pushButton, SIGNAL("clicked()"), form.show)
if __name__ == "__main__":
app = QApplication(sys.argv)
form = QWidget()
form_ui = Ui_Form()
form_ui.setupUi(form)
window = Window(form)
window.show()
sys.exit(app.exec_())
Tiskni
Sdílej: