- 3D-Druck Einstieg und Tipps         
Seite 2 von 2 ErsteErste 12
Ergebnis 11 bis 18 von 18

Thema: qt5 creator + designer: super simple graphic examples

  1. #11
    HaWe
    Gast
    Anzeige

    Praxistest und DIY Projekte
    ah, nicht unter DisplayWidgets, sondern unter Containers - ok, danke, habe es gefunden.
    Habe auch deine mywidget.h und deine mywidget.cpp Datei ins Arbeitsverzeichnis kopiert.

    wie füge ich sie jetzt dem Projekt hinzu? habe ich bisher noch nie gemacht ...
    (deshalb wäre mir ein Code direkt in mainwindow.cpp auch viel lieber)

    Und wie rufe ich dann eine Zeichen-Routine in meinem mainwindow.cpp auf?

    dadurch, dass ich nur oben mit dazu schreibe
    #include "mywidget.h"

    passiert nichts, nach Compile +Starten sieht man nur meinen Quit Button, sonst nichts (auch keinen Rahmen vom "Widget")...


    mainwindow.cpp :
    Code:
    #include "mainwindow.h"
    #include "ui_mainwindow.h"
    
    #include "mywidget.h"
    
    
    
    MainWindow::MainWindow(QWidget *parent) :
        QMainWindow(parent),
        ui(new Ui::MainWindow)
    {
        ui->setupUi(this);
        //
        //....: hier soll der komplette Code für die paint-Funktionen rein!
        //....  evt. auch über eine lokale Funktion hier im mainwindow.cpp file
        //
    }
    
    MainWindow::~MainWindow()
    { 
        delete ui;
    }
    
    
    
    void MainWindow::on_pushButton1_clicked()
    { 
        QCoreApplication::quit();
    }
    Geändert von HaWe (03.06.2020 um 14:00 Uhr)

  2. #12
    Erfahrener Benutzer Roboter-Spezialist
    Registriert seit
    13.01.2014
    Beiträge
    454
    Blog-Einträge
    3
    Für mein Beispiel ist kein händisches #include notwendig. Schau rechts im Objekt-Fenster, ob das Widget von der Klasse MyWidget ist. Wenn nicht, hat was mit dem Platzhalter-Zeugs nicht funktioniert (Rechtsklick ins Widget im Designer). Wenn's geklappt hat findest du in der .pro-Datei den Eintrag mywidget.h unter Headers und in der .ui-Datei steht der Eintrag <widget class="MyWidget" name="widget" native="true">.

  3. #13
    HaWe
    Gast
    hm - kapier ich nicht, was ich machen soll. Per Rechtsklick ins Widget: da finde ich nichts.
    Kannst du mir das komplette Projekt mit allen notwendigen Dateien und Einstellungen mal hochladen?

    Ist das mit den extra cpp und h files denn auch unbedingt nötig?
    ich wollte eigentlich alles komplett in mainwindow.cpp verfügbar haben...

    PS,
    insbesondere die aktuelle Malfunktion muss unbedingt in mainwindow.cpp programmiert werden können, nicht in einem externen file (mywidget etc.)

    Und gibt es keine "eingebaute" canvas-widget für qpainter, muss man das wirklich unbedingt so kompliziert selber schreiben? Ein fertiges widget kann man ja einfach in die Form ziehen, ohne weitere Schreiberei...
    Geändert von HaWe (03.06.2020 um 14:26 Uhr)

  4. #14
    Erfahrener Benutzer Roboter-Spezialist
    Registriert seit
    13.01.2014
    Beiträge
    454
    Blog-Einträge
    3
    mainwindow.ui
    Code:
    <?xml version="1.0" encoding="UTF-8"?>
    <ui version="4.0">
     <class>MainWindow</class>
     <widget class="QMainWindow" name="MainWindow">
      <property name="geometry">
       <rect>
        <x>0</x>
        <y>0</y>
        <width>474</width>
        <height>411</height>
       </rect>
      </property>
      <property name="windowTitle">
       <string>MainWindow</string>
      </property>
      <widget class="QWidget" name="centralWidget">
       <widget class="QPushButton" name="pushButton">
        <property name="geometry">
         <rect>
          <x>180</x>
          <y>300</y>
          <width>101</width>
          <height>31</height>
         </rect>
        </property>
        <property name="text">
         <string>Quit</string>
        </property>
       </widget>
       <widget class="MyWidget" name="widget" native="true">
        <property name="geometry">
         <rect>
          <x>10</x>
          <y>10</y>
          <width>451</width>
          <height>271</height>
         </rect>
        </property>
       </widget>
      </widget>
      <widget class="QMenuBar" name="menuBar">
       <property name="geometry">
        <rect>
         <x>0</x>
         <y>0</y>
         <width>474</width>
         <height>21</height>
        </rect>
       </property>
      </widget>
      <widget class="QToolBar" name="mainToolBar">
       <attribute name="toolBarArea">
        <enum>TopToolBarArea</enum>
       </attribute>
       <attribute name="toolBarBreak">
        <bool>false</bool>
       </attribute>
      </widget>
      <widget class="QStatusBar" name="statusBar"/>
      <widget class="QToolBar" name="toolBar">
       <property name="windowTitle">
        <string>toolBar</string>
       </property>
       <attribute name="toolBarArea">
        <enum>TopToolBarArea</enum>
       </attribute>
       <attribute name="toolBarBreak">
        <bool>false</bool>
       </attribute>
      </widget>
      <action name="action">
       <property name="text">
        <string/>
       </property>
      </action>
     </widget>
     <layoutdefault spacing="6" margin="11"/>
     <customwidgets>
      <customwidget>
       <class>MyWidget</class>
       <extends>QWidget</extends>
       <header>mywidget.h</header>
       <container>1</container>
      </customwidget>
     </customwidgets>
     <resources/>
     <connections>
      <connection>
       <sender>pushButton</sender>
       <signal>clicked()</signal>
       <receiver>MainWindow</receiver>
       <slot>close()</slot>
       <hints>
        <hint type="sourcelabel">
         <x>234</x>
         <y>171</y>
        </hint>
        <hint type="destinationlabel">
         <x>260</x>
         <y>229</y>
        </hint>
       </hints>
      </connection>
     </connections>
    </ui>
    qt_btn_paint.pro
    Code:
    #-------------------------------------------------
    #
    # Project created by QtCreator 2019-09-16T12:09:00
    #
    #-------------------------------------------------
    
    QT       += core gui
    
    greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
    
    TARGET = GUI_app
    TEMPLATE = app
    
    # The following define makes your compiler emit warnings if you use
    # any feature of Qt which as been marked as deprecated (the exact warnings
    # depend on your compiler). Please consult the documentation of the
    # deprecated API in order to know how to port your code away from it.
    DEFINES += QT_DEPRECATED_WARNINGS
    
    # You can also make your code fail to compile if you use deprecated APIs.
    # In order to do so, uncomment the following line.
    # You can also select to disable deprecated APIs only up to a certain version of Qt.
    #DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0
    
    
    SOURCES += main.cpp\
            mainwindow.cpp \
            mywidget.cpp
    
    HEADERS  += mainwindow.h \
        mywidget.h
    
    FORMS    += mainwindow.ui
    - - - Aktualisiert - - -
    Angehängte Dateien Angehängte Dateien

  5. #15
    HaWe
    Gast
    hallo,
    vielen Dank für deine Mühe!
    Es ließ sich nach ein paar kleinen Anpassungen starten (Dateidaten lagen in der Zukunft, *.pro.user musste gelöscht und neu erstellt werden) , aber leider zeigt es nur ein paar diagonale Striche, kein Rechteck, keinen Kreis.

    Außerdem müsste es so sein, dass ich alle Zeichenoperationen bedarfsgerecht vom mainwindow.cpp Hauptprogramm aus machen kann (Ort, Größe, Farbe), ggf per lokaler Funktion, an die Koordinaten etc. übergeben werden, denn was wie und wo in der Canvas gezeichnet werden soll, ist letztlich abhängig von Daten, die genau hier berechnet werden (=> Visualisierung von Mess- und Rechenergebnissen).

    In deinem Hauptprogramm ist aber überhaupt keine Zeichenfunktion für Linien, Kreise, Rechtecke etc. aufgerufen worden, wie kann man das umschreiben?
    Geändert von HaWe (03.06.2020 um 16:06 Uhr)

  6. #16
    Erfahrener Benutzer Roboter-Spezialist
    Registriert seit
    13.01.2014
    Beiträge
    454
    Blog-Einträge
    3
    Es werden auch nur Striche gezeichnet, das ist also ok.

    Die Komponenten kannst du mit Signals und Slots verbinden, um Daten im Programm weiterzuleiten.

    In der paintEvent_Methode wird gemalt. Wie findest du schon selbst raus, da gibts genug Beispiele.

  7. #17
    HaWe
    Gast
    nein, sorry, genau das kriege ich nicht raus, das habe ich schon aus anderen Beispielen heraus probiert, und ich habe nach wie vor keine Idee, wie man Linien, Kreise, Rechtecke etc. direkt vom Hauptprogramm aus zeichnet:

    jede einzelne geometrische Figur je nach Erfordernissen in einer kurzen eigenen Zeile, nacheinander, auch ggf. in anderer Reihenfolge, so wie man auch Text aktualisiert und bedarfsgerecht in ein TextBox-Widget schreiben würde, also z.B.

    zum Schreiben (funktioniert):
    ui->pin23Label->setText(QString("High"));
    ui->plainTextEdit1->appendPlainText("pinstate24="+QString::number(pin state24));

    und nun zum Zeichnen (funktioniert noch nicht):
    ui->myWidget1->Qpainter(SetBackground(BLACK));
    ui->myWidget1->Qpainter(ClearScreen());
    ui->myWidget1->Qpainter(SetColor(RED));
    ui->myWidget1->Qpainter(SetBrushWidth(2));
    ui->myWidget1->Qpainter(RectOutline(20, 20, 40, 40));
    ui->myWidget1->Qpainter(SetColor(YELLOW));
    ui->myWidget1->Qpainter(Circle(30, 24, 10));

    oder wie auch immer die korrekte Syntax sein mag...
    Geändert von HaWe (03.06.2020 um 18:55 Uhr)

  8. #18
    HaWe
    Gast
    war mit Qpainter nicht zu lösen, habe es aber jetzt mit QGraphicsScene:

    https://github.com/dsyleixa/Raspberr...tn_paint_timer

Seite 2 von 2 ErsteErste 12

Ähnliche Themen

  1. Tipps Meine Software: LCD-Charakter-Creator
    Von pro-bot128 im Forum Offtopic und Community Tratsch
    Antworten: 3
    Letzter Beitrag: 20.06.2011, 12:55
  2. Ks108 und Graphic Converter
    Von carfan im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 3
    Letzter Beitrag: 10.08.2008, 21:00
  3. Menü Creator
    Von guenter1604 im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 15
    Letzter Beitrag: 02.08.2008, 10:12
  4. Antworten: 6
    Letzter Beitrag: 30.07.2007, 15:30
  5. PIC mit Graphic LCD
    Von chosn im Forum PIC Controller
    Antworten: 3
    Letzter Beitrag: 02.06.2005, 12:20

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

LiFePO4 Speicher Test