Retired Document
Important: This document may not represent best practices for current development. Links to downloads and other resources may no longer be valid.
Fixing the Layout Binding of the Tab control User Panes
Q: In Interface Builder on Mac OS X 10.3, I create a Carbon Tab control in a compositing window and embed a button in the first pane. Although I specify the correct layout bindings for both controls, when I resize the window only the Tab control adjusts its size but the button doesn't move. What's going on and what can I do to fix this?
A: In Interface Builder on Mac OS X 10.3, I create a Carbon Tab control in a compositing window and embed a button in the first pane. Although I specify the correct layout bindings for both controls, when I resize the window only the Tab control adjusts its size but the button doesn't move. What's going on and what can I do to fix this?
When you create a Carbon Tab control in Interface Builder, a User Pane control is automatically created, for your convenience, for each tab pane. When you create and embed a control in a tab pane (see Figure 1), it is actually embedded in the User Pane control (see the dump information in Listing 1).
data:image/s3,"s3://crabby-images/361ab/361abec671c2fe35fc4afd70b7767874b04380bf" alt=""
Listing 1 Control Hierarchy.
Dumping info for window 0x1146DF0 Window found. Dumping views... Control 0x1104ce0 <appl/cnvw> ( "" ), ID 'wind'/1, (22,0,382,480), Embedder, Vis, Act, Ena, ... Control 0x1145dd0 <appl/tabs> ( "" ), ID ''/0, (5,20,340,460), Embedder, Vis, Act, Ena, ... Control 0x114f260 <appl/upan> ( "" ), ID ''/0, (37,0,335,440), Embedder, Vis, Act, Ena, ... Control 0x114e340 <appl/upan> ( "" ), ID ''/0, (37,0,335,440), Embedder, Vis, Act, Ena, ... Control 0x114e2e0 <appl/push> ( "Button" ), ID 'bttn'/100, (258,350,278,420), Vis, Act, Ena, ... |
You can specify the layout bindings (see Figure 2) for the Tab control and for the button, but, even though you can select each tab pane and change, for example, its label, you cannot modify its layout settings (see Figure 3) and thus, when the window is resized, the Tab control adjusts itself correctly, but the User Pane does not and so the button does not either (see Figure 4).
data:image/s3,"s3://crabby-images/9d7dc/9d7dc56e0e3f61e629c5dfc117ed418e5c048d67" alt=""
data:image/s3,"s3://crabby-images/1af90/1af905e017fa48c22e2e8b9b5189a3650b6f3af5" alt=""
data:image/s3,"s3://crabby-images/7dd90/7dd901bd760db903bb88e149eb28c85e4e94dac0" alt=""
The simplest and best solution is to go back, in Interface Builder, to the Instances pane of the main window and select the list view instead of the icon view (see Figure 5), and there you can select the tab pane and change its layout in the inspector (see Figure 6).
data:image/s3,"s3://crabby-images/2853c/2853caf62e2cd624c58b343485a4a0d9aba28561" alt=""
data:image/s3,"s3://crabby-images/8981f/8981f6542afb7038738f6d4f7213dd76659061ae" alt=""
You can now change the layout settings (in this case, choosing the same settings as in Figure 2) and now the button at the bottom left will correcly bind to its parent after a resize (see Figure 7).
data:image/s3,"s3://crabby-images/1ac68/1ac68309a50d4b641e70f68b8b9e16970e132a86" alt=""
Of course, to be complete, these layout bindings should be applied to all the tab panes.
Document Revision History
Date | Notes |
---|---|
2004-10-14 | New document that describes the Tab control hierarchy and layouts of its panes and provides a fix to a common problem. |
Copyright © 2004 Apple Computer, Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2004-10-14