Book Image

Qt5 C++ GUI Programming Cookbook

By : Lee Zhi Eng
Book Image

Qt5 C++ GUI Programming Cookbook

By: Lee Zhi Eng

Overview of this book

With the advancement of computer technology, the software market is exploding with tons of software choices for the user, making their expectations higher in terms of functionality and the look and feel of the application. Therefore, improving the visual quality of your application is vital in order to overcome the market competition and stand out from the crowd. This book will teach you how to develop functional and appealing software using Qt5 through multiple projects that are interesting and fun. This book covers a variety of topics such as look-and-feel customization, GUI animation, graphics rendering, implementing Google Maps, and more. You will learn tons of useful information, and enjoy the process of working on the creative projects provided in this book
Table of Contents (16 chapters)
Qt5 C++ GUI Programming Cookbook
Credits
About the Author
About the Reviewer
www.PacktPub.com
Preface
Index

Animating widget properties using animators


In this recipe, we will learn how to animate the properties of our GUI widgets using the animator feature provided by QML.

How to do it…

  1. Create a rectangle object and add a scale animator to it:

    Rectangle {
      id: myBox;
      width: 50;
      height: 50;
      anchors.horizontalCenter: parent.horizontalCenter;
      anchors.verticalCenter: parent.verticalCenter;
      color: "blue";
    
      ScaleAnimator {
        target: myBox;
        from: 5;
        to: 1;
        duration: 2000;
        running: true;
      }
    }
  2. Add a rotation animator and set the running value in the parallel animation group, but not in any of the individual animators:

    ParallelAnimation {
      ScaleAnimator {
        target: myBox;
        from: 5;
        to: 1;
        duration: 2000;
      }
      RotationAnimator {
        target: myBox;
        from: 0;
        to: 360;
        duration: 1000;
      }
      running: true;
    }
  3. Add an easing curve to the scale animator:

    ScaleAnimator {
      target: myBox;
      from: 5;
      to: 1;
      duration: 2000;
      easing.type: Easing.InOutElastic;
    ...