epoc32/include/mw/eikbtgps.h
branchSymbian2
changeset 2 2fe1408b6811
parent 1 666f914201fb
child 4 837f303aceeb
--- a/epoc32/include/mw/eikbtgps.h	Tue Nov 24 13:55:44 2009 +0000
+++ b/epoc32/include/mw/eikbtgps.h	Tue Mar 16 16:12:26 2010 +0000
@@ -1,1 +1,76 @@
-eikbtgps.h
+/*
+* Copyright (c) 2002-2007 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
+* which accompanies this distribution, and is available
+* at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:  Button group stack class definition.
+*
+*/
+
+
+#ifndef __EIKBTGPS_H__
+#define __EIKBTGPS_H__
+
+#include <coemain.h>
+#include <eikbtgpc.h>
+
+/**
+ * A list of all button groups currently available within a thread. 
+ * 
+ * CEikButtonGroupStack maintains a list of all button groups currently 
+ * available within a thread. Only button groups that are expected to be 
+ * available to other controls will register here.
+ *
+ * @lib eikcoctl.lib
+ * @since S60 0.9 
+ */
+class CEikButtonGroupStack : public CCoeStatic
+    {
+public:
+    /**
+     * Gets the minimum size required to display all the visible button 
+     * groups on the button group stack.
+     *
+     * @return The minimum size required to display all the visible button
+     *         groups currently on the stack. 
+     */
+    IMPORT_C static TSize MinimumSize();
+
+    /**
+     * Gets the button group currently displayed.
+     *
+     * @return The button group currently displayed.
+     */
+    static CEikButtonGroupContainer* Current();
+    
+    /**
+     * Adds a button group to the button group stack.
+     *
+     * @param aGroup The button group to add to the button group stack. 
+     */    
+    static void AddL(CEikButtonGroupContainer& aGroup);
+    
+    /**
+     * Removes the specified button group from the button group stack.
+     *
+     * @param aGroup The button group to remove.
+     */    
+    static void Remove(CEikButtonGroupContainer& aGroup);
+    
+private:
+    inline CEikButtonGroupStack();
+    inline static CEikButtonGroupStack* Self();
+    
+private: // data
+    TDblQue<CEikButtonGroupContainer> iBtStack;
+    };
+
+#endif // __EIKBTGPS_H__