I try to use the simplicity of ABPersonViewController and at the same time adjust its appearance a little to match the look of my application.
I subclassed ABPersonViewController and used this technique , I go through the hierarchy of ABPersonViewController views, and here is my conclusion:
UIView: 0x5a45d80; frame = (0 0; 320 416); autoresize = W + H; layer =>
| ABPersonTableView: 0x6041a00; baseClass = UITableView; frame = (0 0; 320 416); clipsToBounds = YES; autoresize = W + H; layer =; contentOffset: {0, 0}>
| | ABMultiCell: 0x5a50080; baseClass = UITableViewCell; frame = (0 94; 320 45); autoresize = W; tag = 10; layer =>
| | | UIGroupTableViewCellBackground: 0x5a678d0; frame = (9 0; 302 45); autoresize = W; layer =>
| | | UITableViewCellContentView: 0x5a62670; frame = (10 1; 300 43); layer =>
| | | | ABMultiCellContentView_Simple: 0x5a4fef0; frame = (0 0; 300 43); text = '(555) 555-5555'; clipsToBounds = YES; layer =>
| | | | | UILabel: 0x5a61590; frame = (5 14.54; 70 16); text = 'mobile'; clipsToBounds = YES; userInteractionEnabled = NO; layer =>
| | | | | ABDividerView: 0x5a62ff0; frame = (79 0; 1 44); alpha = 0; layer =>
| | | | | | ABSteadfastLineView: 0x5a53ab0; frame = (0 0; 1 44); layer =>
| | | | | ABHighlightingTextField: 0x5a53c30; baseClass = UITextField; frame = (85 12; 210 21); text = '(555) 555-5555'; clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; layer =>
| | | | | | UITextFieldLabel: 0x5a53db0; frame = (0 0; 210 19); text = '(530) 305-0835'; clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; layer =>
| | UIView: 0x5a5b300; frame = (0 0; 320 94); layer =>
| | | ABPersonTableHeaderView: 0x5a444b0; frame = (0 0; 320 94); clipsToBounds = YES; autoresize = W; layer =>
| | | | ABPersonImageView: 0x5a449c0; baseClass = UIControl; frame = (19 15; 64 64); clipsToBounds = YES; autoresize = RM + BM; layer =>
| | | | | ABClippingImageView: 0x5a6aae0; frame = (0 0; 64 64); opaque = NO; userInteractionEnabled = NO; layer =>
| | | | | ABImageWellLabelView: 0x5a6c0b0; frame = (0 0; 64 64); alpha = 0; opaque = NO; userInteractionEnabled = NO; layer =>
| | | | ABPersonNameEditingViewContainer: 0x5a4a9e0; frame = (101 15; 530 64); alpha = 0; autoresize = W + BM; layer =>
| | | | | ABMultiCellContentView_Name: 0x5a4b480; frame = (1 0; 208 64); clipsToBounds = YES; layer =>
| | | | | | ABHighlightingTextField: 0x5a4d7c0; baseClass = UITextField; frame = (-5 12; 10 21); text = 'First Name'; clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; tag = 1; layer =>
| | | | | | | UITextFieldLabel: 0x5a4b3e0; frame = (-10 0; 10 19); text = 'First Name'; clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; layer =>
| | | | | | ABHighlightingTextField: 0x5a50a90; baseClass = UITextField; frame = (-5 56; 10 21); text = 'Last Name'; clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; tag = 2; layer =>
| | | | | | | UITextFieldLabel: 0x5a4e5d0; frame = (-10 0; 10 19); text = 'Last Name'; clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; layer =>
| | | | | | ABDividerView: 0x5a52300; frame = (0 44; 0 1); layer =>
| | | | | | | ABSteadfastLineView: 0x5a525d0; frame = (0 0; 0 1); layer =>
| | | | | | ABHighlightingTextField: 0x5a52400; baseClass = UITextField; frame = (-5 100; 10 21); clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; tag = 3; layer =>
| | | | | | | UITextFieldLabel: 0x5a5a4e0; frame = (-8 0; 10 19); text = 'Company'; clipsToBounds = YES; opaque = NO; userInteractionEnabled = NO; layer =>
| | | | | | ABDividerView: 0x5a53f00; frame = (0 88; 0 1); layer =>
| | | | | | | ABSteadfastLineView: 0x5a53f80; frame = (0 0; 0 1); layer =>
| | | | ABPersonNameDisplayView: 0x5a45cf0; baseClass = UIControl; frame = (97 15; 204 64); autoresize = W; layer =>
| | | | | UILabel: 0x5a4bbd0; frame = (0 21; 109 23); text = 'First Name Last Name'; clipsToBounds = YES; autoresize = W; userInteractionEnabled = NO; layer =>
| | | | | UILabel: 0x5a4c020; frame = (0 0; 204 0); clipsToBounds = YES; autoresize = W; userInteractionEnabled = NO; layer =>
| | UIImageView: 0xcc032a0; frame = (0 409; 320 7); alpha = 0; opaque = NO; autoresize = TM; userInteractionEnabled = NO; layer =>
| | UIImageView: 0xcc03350; frame = (313,262; 7,154); alpha = 0; opaque = NO; autoresize = LM; userInteractionEnabled = NO; layer =>
Sweet! Thus, I should be able to recursively cycle, although the root UIView subviews, and change the content of my heart.
, UIView
(ABPersonTableView), .
, ? ABPersonTableView , , /?
, :
if ([subview isKindOfClass:[UITableView class]]) {
((UITableView *)subview).backgroundColor = [UIColor purpleColor];
}
UILabels, ABPersonTableView.
?