Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. QML and Qt Quick
  4. C++ to change QML object properties
Forum Updated to NodeBB v4.3 + New Features

C++ to change QML object properties

Scheduled Pinned Locked Moved QML and Qt Quick
57 Posts 4 Posters 44.4k Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • p3c0P Offline
    p3c0P Offline
    p3c0
    Moderators
    wrote on last edited by
    #41

    bq. This code: “color: btnMouseArea.pressed ? Qt.darker(newColor, 1.5) : newColor” works but This code: “gradColor: btnMouseArea.pressed ? Qt.darker(newColor, 1.5) : newColor” doesn’t works. Why?

    Since you are assigning gradColor a value twice, remove the latter one. You can assign an expression even when you declare a property.
    @
    property string gradColor : btnMouseArea.pressed ? Qt.darker(newColor, 1.5) : newColor

    @

    bq. I was trying to put a if statement to around gradient: to switch on and off using “gradOn” custom property. It is not allowed. Any other way of doing this?

    Yes, AFAIK but you must create Gradient outside.
    @
    Gradient {
    id: gradient
    GradientStop { position: 0.0; color: gradColor }
    GradientStop { position: 0.17; color: "#6A6D6A" }
    GradientStop { position: 0.77; color: gradColor }
    GradientStop { position: 1.0; color: "#6A6D6A" }
    }
    gradient: if(gradOn) { return gradient } else { return undefined }
    @

    I'd prefer a ternary one here.

    157

    1 Reply Last reply
    0
    • V Offline
      V Offline
      Vignes
      wrote on last edited by
      #42

      I tried both, none of them are working for me (I cleaned and build it several times).

      @property string gradColor : btnMouseArea.pressed ? Qt.darker(newColor, 1.5) : newColor@ has no complain, but doesn't darken the color

      @gradient: if(gradOn)...@

      complain with underline and doesn't build

      1 Reply Last reply
      0
      • p3c0P Offline
        p3c0P Offline
        p3c0
        Moderators
        wrote on last edited by
        #43

        See if this works,
        @
        Item {
        id: item
        width: 200
        height: 200
        property bool gradOn: false
        property color newColor: "red"
        property string gradColor : mousearea.pressed ? Qt.darker(newColor, 1.5) : newColor

        Rectangle {
            color: "red"
            anchors.fill: parent
            MouseArea {
                id: mousearea
                anchors.fill: parent
                onClicked: { gradOn = true }
            }
        
            Gradient {
                id: gradient
                GradientStop { position: 0.0; color: gradColor }
                GradientStop { position: 0.17; color: "#6A6D6A" }
                GradientStop { position: 0.77; color: gradColor }
                GradientStop { position: 1.0; color: "#6A6D6A" }
            }
            gradient: if(gradOn) { return gradient } else { return undefined }
        }
        

        }
        @

        157

        1 Reply Last reply
        0
        • V Offline
          V Offline
          Vignes
          wrote on last edited by
          #44

          Yes this works, thanks, I thought "Rectangle" Inherits every things from "Item" and add its' additional properties.

          Is "mousearea" has ".entered" event (@gradColor : mousearea.entered ? Qt.darker(newColor, 1.5) : newColor@)

          Now the important part. I need to read a compressed file and create an Image on the screen. This image will be made of square block region of 64, 31, 16, 8, 4 pixels. When each square is clicked, an information window will display.

          I found these libraries can create pixel: #include <QGraphicsScene>, #include <QtOpenGL>, #include <QQuickImageProvider> and #include <QPainter>.

          But I don't know which one will be best for me (speed of image creation is very important and easy to implement)?

          The number of square block sizes differ from picture to picture. So is It easier to create from Cpp or QML ?

          Thank you

          1 Reply Last reply
          0
          • p3c0P Offline
            p3c0P Offline
            p3c0
            Moderators
            wrote on last edited by
            #45

            bq. Is “mousearea” has “.entered” event

            That won't work. AFAIK, you can use "containsMouse":http://qt-project.org/doc/qt-5/qml-qtquick-mousearea.html#containsMouse-prop to do that provided you must set hoverEnabled to true for MouseArea

            bq. I need to read a compressed file and create an Image on the screen

            Do you mean jpg, png etc.. ? And do you mean you have those images and you have to just set them using Image element with size you mentioned? You can have MouseArea for Image element.

            Since you are using QML, there would be no use of QGraphicsView, Scene etc..
            QQuickImageProvider allows you to provide an image from C++ to qml. Check its documentation for more details.
            Using QPainter you can draw acording to you needs, since you are using QML, to use QPainter you will have to use QQuickPaintedItem, override paint method and draw your contents. Have a look at it's docs for a basic idea.

            bq. But I don’t know which one will be best for me (speed of image creation is very important and easy to implement)?

            Do you mean you are creating your own image ? or you want to set an existing image in a QML

            bq. The number of square block sizes differ from picture to picture. So is It easier to create from Cpp or QML ?

            What do you intend to use for square blocks, Image element ?

            The best way IMO to help you would be if you would post codes like previous of what you done so that we get a clear understanding of what you intend to do.

            157

            1 Reply Last reply
            0
            • V Offline
              V Offline
              Vignes
              wrote on last edited by
              #46

              The images are from a compress video clip similar to H.264, but not same and file format is .BIN. Each frame in the compressed video is processed by splitting it into square blocks and doing several processes.

              I need to read this bin file, then extract a frame or picture at given point, then display its' compression processes details. E.g. the first picture in the compressed video is on the screen. This will be split into a combination of block regions like complex grids. When each block is clicked, a popup window will open next to it and display details of the compression process was done to it.

              I need to play this video file at the highest possible frame rate. I believe QML uses OpenGL. I also need to extract picture and display and able to play .YUV format video.

              The video file or picture size will go up to 4K resolution. If I'm successful, with your help I'll. Qt QML based next generation compressed video player with analytical tools and video editor will be built.

              (I may need to switch the display into Luma, Croma mode, which is filtering process.)

              1 Reply Last reply
              0
              • p3c0P Offline
                p3c0P Offline
                p3c0
                Moderators
                wrote on last edited by
                #47

                What i think is you need to do those processing i.e read this bin file, then extract a frame or picture at given point on C++ side and use a Grid element to place these pictures using may be an Image element. QML definitely uses OpenGL.
                Sorry, but i have never worked on Video using QML so i can't be useful there. And coming to image i think QML image element can handle that resolution.
                May be you should have look at "QtAV":https://github.com/wang-bin/QtAV if its useful.

                157

                1 Reply Last reply
                0
                • V Offline
                  V Offline
                  Vignes
                  wrote on last edited by
                  #48

                  Hi, I want to detect .bin file on load and call a function in qml. I mange to do the follow code.
                  @
                  onAccepted: {
                  var str = openFile.fileUrl;
                  var rx = /.bin/;
                  if(rx.test(str)){
                  urlCpp(str);
                  }
                  else {
                  imageViewer.source = str;
                  }
                  }
                  @

                  But I am looking for full QML RegExp reference list. I couldn't locate it on http://qt-project.org/. Could you let me know the url for QML RegExp reference please.
                  Thank you.

                  1 Reply Last reply
                  0
                  • jeremy_kJ Offline
                    jeremy_kJ Offline
                    jeremy_k
                    wrote on last edited by
                    #49

                    I find the w3schools.com javascript reference to be pretty good for js portion of QML.

                    http://www.w3schools.com/jsref/jsref_obj_regexp.asp

                    Asking a question about code? http://eel.is/iso-c++/testcase/

                    1 Reply Last reply
                    0
                    • p3c0P Offline
                      p3c0P Offline
                      p3c0
                      Moderators
                      wrote on last edited by
                      #50

                      You can extract the filename extension using split and then compare
                      @
                      var f = "myfile.bin"
                      console.log(f.split('.').pop())
                      @

                      157

                      1 Reply Last reply
                      0
                      • V Offline
                        V Offline
                        Vignes
                        wrote on last edited by
                        #51

                        Hi,
                        I tried to test QtAV examples (downloaded the ZIP file), but I couldn't get them build. I even tried the following link https://github.com/wang-bin/QtAV/wiki/Use-QtAV-In-Your-Projects
                        I couldn't get it build.
                        There is qml example code :
                        @import QtQuick 2.0
                        import QtAV 1.3
                        Item {
                        VideoOutput {
                        anchors.fill: parent
                        source: player
                        }
                        AVPlayer { //or MediaPlayer
                        id: player
                        source: "test.mp4"
                        }
                        MouseArea {
                        anchors.fill: parent
                        onClicked: player.play()
                        }
                        }@

                        • If I want to get this to work, what should I do?
                        • If I were to add new video decoder format e.g H.265, where should I add?

                        Thanks

                        1 Reply Last reply
                        0
                        • p3c0P Offline
                          p3c0P Offline
                          p3c0
                          Moderators
                          wrote on last edited by
                          #52

                          Since this is a completely new topic now than the original one I would suggest you to create a new Post, add there what you have done and what errors do you get on compiling plus your new questions related to it.

                          157

                          1 Reply Last reply
                          0
                          • V Offline
                            V Offline
                            Vignes
                            wrote on last edited by
                            #53

                            Hi,
                            I have an issue that is related to Mac OS. In QML, I am setting the window flag to "SplashScreen" at starting point then after one second, I change the window flag to "Window". This second change course the contents inside the window to disappear. But the same code on MS Windows works fine (contents does not disappear).

                            I want the window start without frame then after a second frame appears.

                            Is it possible to solve this issue?

                            Thanks

                            1 Reply Last reply
                            0
                            • V Offline
                              V Offline
                              Vignes
                              wrote on last edited by
                              #54

                              Hi,
                              I have an issue that is related to Mac OS. In QML, I am setting the window flag to "SplashScreen" at starting point then after one second, I change the window flag to "Window". This second change course the contents inside the window to disappear. But the same code on MS Windows works fine (contents does not disappear).

                              I want the window start without frame then after a second frame appears.

                              Is it possible to solve this issue?

                              Thanks

                              1 Reply Last reply
                              0
                              • p3c0P Offline
                                p3c0P Offline
                                p3c0
                                Moderators
                                wrote on last edited by
                                #55

                                I'm not quite sure about this one as I don't have Mac OS to try this. But since it works on Windows and not on Mac it could probably a bug. You can report it on "Qt Bug Tracker":https://bugreports.qt.io.

                                157

                                1 Reply Last reply
                                0
                                • p3c0P Offline
                                  p3c0P Offline
                                  p3c0
                                  Moderators
                                  wrote on last edited by
                                  #56

                                  I'm not quite sure about this one as I don't have Mac OS to try this. But since it works on Windows and not on Mac it could probably a bug. You can report it on "Qt Bug Tracker":https://bugreports.qt.io.

                                  157

                                  1 Reply Last reply
                                  0
                                  • p3c0P p3c0

                                    Please encapulate your code in the code tags '@@' so that its easily readable to others.

                                    You should either use QQmlApplicationEngine or QQuickView not both.
                                    If using QQmlApplicationEngine you can try
                                    @
                                    QGuiApplication app(argc, argv);
                                    QQmlApplicationEngine engine;
                                    engine.load(QUrl(QStringLiteral("qrc:///main.qml")));
                                    QQuickItem item = engine.rootObjects().at(0)->findChild<QQuickItem>("myRect");
                                    if (item) {
                                    item->setProperty("color", QColor(Qt::yellow));
                                    }
                                    return app.exec();
                                    @

                                    S Offline
                                    S Offline
                                    sagarbade
                                    wrote on last edited by
                                    #57

                                    @p3c0 said in C++ to change QML object properties:

                                    myRect

                                    hello ..i have question related this topic ..i have 2 qml pages main.qml and mynew.qml
                                    in my main.cpp i load main.qml page and execute and main.qml have sack view and in this stack i push mynew.qml in mynew.qml page one button for start thread scanner.cpp and one label for display result coming from thread ....now the question is i want to pass signel from thread to set label text in mynew.qml

                                    1 Reply Last reply
                                    0

                                    • Login

                                    • Login or register to search.
                                    • First post
                                      Last post
                                    0
                                    • Categories
                                    • Recent
                                    • Tags
                                    • Popular
                                    • Users
                                    • Groups
                                    • Search
                                    • Get Qt Extensions
                                    • Unsolved