/* * Copyright (c) 2008-2024 Jonathan Schleifer * * All rights reserved. * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License version 3.0 only, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License * version 3.0 for more details. * * You should have received a copy of the GNU Lesser General Public License * version 3.0 along with this program. If not, see * . */ #import "OHGameControllerProfile.h" OF_ASSUME_NONNULL_BEGIN /** * @class OHGamepad OHGamepad.h ObjFWHID/OHGamepad.h * * @brief A game controller profile representing a gamepad. */ @interface OHGamepad: OHGameControllerProfile { OF_RESERVE_IVARS(OHGamepad, 4) } /** * @brief The north button on the gamepad's diamond pad. */ @property (readonly, nonatomic) OHGameControllerButton *northButton; /** * @brief The south button on the gamepad's diamond pad. */ @property (readonly, nonatomic) OHGameControllerButton *southButton; /** * @brief The west button on the gamepad's diamond pad. */ @property (readonly, nonatomic) OHGameControllerButton *westButton; /** * @brief The east button on the gamepad's diamond pad. */ @property (readonly, nonatomic) OHGameControllerButton *eastButton; /** * @brief The left shoulder button. */ @property (readonly, nonatomic) OHGameControllerButton *leftShoulderButton; /** * @brief The right shoulder button. */ @property (readonly, nonatomic) OHGameControllerButton *rightShoulderButton; /** * @brief The left trigger button. */ @property (readonly, nonatomic) OHGameControllerButton *leftTriggerButton; /** * @brief The right trigger button. */ @property (readonly, nonatomic) OHGameControllerButton *rightTriggerButton; /** * @brief The left thumb stick button. * * This button is optional and may be `nil`. */ @property OF_NULLABLE_PROPERTY (readonly, nonatomic) OHGameControllerButton *leftThumbstickButton; /** * @brief The right thumb stick button. * * This button is optional and may be `nil`. */ @property OF_NULLABLE_PROPERTY (readonly, nonatomic) OHGameControllerButton *rightThumbstickButton; /** * @brief The menu button, sometimes also called start button. */ @property (readonly, nonatomic) OHGameControllerButton *menuButton; /** * @brief The options button, sometimes also called select button. */ @property (readonly, nonatomic) OHGameControllerButton *optionsButton; /** * @brief The home button. * * This button is optional and may be `nil`. */ @property OF_NULLABLE_PROPERTY (readonly, nonatomic) OHGameControllerButton *homeButton; /** * @brief The left thumb stick. */ @property (readonly, nonatomic) OHGameControllerDirectionalPad *leftThumbstick; /** * @brief The right thumb stick. */ @property (readonly, nonatomic) OHGameControllerDirectionalPad *rightThumbstick; /** * @brief The D-Pad. */ @property (readonly, nonatomic) OHGameControllerDirectionalPad *dPad; @end OF_ASSUME_NONNULL_END