File indexing completed on 2024-09-08 03:47:08

0001 /*
0002     This file is part of the KDE games lskat program
0003     SPDX-FileCopyrightText: 2006 Martin Heni <kde@heni-online.de>
0004 
0005     SPDX-License-Identifier: LGPL-2.0-or-later
0006 */
0007 
0008 #ifndef ABSTRACT_INPUT_H
0009 #define ABSTRACT_INPUT_H
0010 
0011 // Qt includes
0012 #include <QObject>
0013 
0014 // KF includes
0015 
0016 // Local includes
0017 #include "lskat_debug.h"
0018 
0019 namespace InputDevice
0020 {
0021 /** Determine the type of input to use for the player */
0022 typedef enum {TypeMouseInput = 0, TypeAiInput = 1} InputDeviceType;
0023 }
0024 
0025 /**
0026  * Abstract input device for the game.
0027  */
0028 class AbstractInput : public QObject
0029 {
0030     Q_OBJECT
0031 
0032 public:
0033     /**
0034      * Constructor for the input
0035      * @param parent The parent object
0036      */
0037     explicit AbstractInput(QObject *parent);
0038 
0039     /**
0040      * Allow or disallow input with this device
0041      * @param allowed True if input is allowed
0042      */
0043     virtual void setInputAllowed(bool allowed);
0044 
0045     /**
0046      * Retrieve whether input is allowed or not.
0047      * @return True if input from this device is allowed.
0048      */
0049     virtual bool inputAllowed();
0050 
0051     /**
0052      * Set the player id number to whom this input belongs to.
0053      * @param id The id number
0054      */
0055     virtual void setId(int id);
0056 
0057     /**
0058      * Retrieve the type of device.
0059      * @return The device type.
0060      */
0061     virtual InputDevice::InputDeviceType type() = 0;
0062 
0063 Q_SIGNALS:
0064     /**
0065      * Signals the availability of player input
0066      * @param id           The input device id
0067      * @param playerNumber The player number [0-1]
0068      * @param cardNumber   The card number [0-7]
0069      */
0070     void signalPlayerInput(int id, int playerNumber, int cardNumber);
0071 
0072 protected:
0073     /** Player id to whom this input belongs */
0074     int mId;
0075     /** Is input allowed? */
0076     bool mInputAllowed;
0077 };
0078 
0079 #endif