Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
timer SALE ENDS IN
0 Days
:
00 Hours
:
00 Minutes
:
00 Seconds
Arrow up icon
GO TO TOP
Game Programming Using Qt Beginner's Guide

You're reading from   Game Programming Using Qt Beginner's Guide A complete guide to designing and building fun games with Qt and Qt Quick 2 using associated toolsets

Arrow left icon
Product type Paperback
Published in Jan 2016
Publisher
ISBN-13 9781782168874
Length 512 pages
Edition 1st Edition
Tools
Arrow right icon
Authors (2):
Arrow left icon
Lorenz Haas Lorenz Haas
Author Profile Icon Lorenz Haas
Lorenz Haas
Witold Wysota Witold Wysota
Author Profile Icon Witold Wysota
Witold Wysota
Arrow right icon
View More author details
Toc

Table of Contents (13) Chapters Close

Preface 1. Introduction to Qt FREE CHAPTER 2. Installation 3. Qt GUI Programming 4. Qt Core Essentials 5. Graphics with Qt 6. Graphics View 7. Networking 8. Scripting 9. Qt Quick Basics 10. Qt Quick A. Pop Quiz Answers Index

Time for action – rendering the pieces


Now that we can see the board, it is time to put the pieces on it. We are going to use images for that purpose. In my case, we found a number of SVG files with chess pieces and decided to use them. SVG is a vector graphics format where all curves are defined not as a fixed set of points but rather as mathematic curves. Their main benefit is that they scale very well without causing an aliasing effect.

Let's equip our view with a registry of images to be used for "stamping" a particular piece type. Since each piece type is identified with char, we can use it to generate keys for a map of images. Let's put the following API into ChessView:

public:
  void setPiece(char type, const QIcon &icon);
  QIcon piece(char type) const;
private:
  QMap<char,QIcon> m_pieces;

For the image type, we do not use QImage or QPixmap but rather QIcon. This is because QIcon can store many pixmaps of different sizes and use the most appropriate one when we request an...

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image