在UITableView里面 定制滑动显示出来的 按钮的底色。

在项目中定制一个 tableview的cell。

这个cell支持手势滑动后,显示一个按钮的功能。

不做修改的话,出现的 按钮后面有个方块区域,底色是白色的。

显的很突兀。


基本思路是 在 定制的 cell 中 重载  

willTransitionToState
  方法,

在这个方法里面 判断相关uiview 组件,定位到 按钮组件。

然后把按钮组件的 superview 的背景色 设置成 这个 table cell的底色。

这样,2者就融为一体了。


- (void)willTransitionToState:(UITableViewCellStateMask)state
{
    NSLog(@"table view cell willTransitionToState ");
    [super willTransitionToState:state];
    if ((state & UITableViewCellStateShowingDeleteConfirmationMask) == UITableViewCellStateShowingDeleteConfirmationMask) {
        for (UIView *subview in self.subviews) {
            NSLog(@"按钮的子视图的类名:%@", NSStringFromClass([subview class]));
            if ([NSStringFromClass([subview class]) isEqualToString:@"UITableViewCellDeleteConfirmationControl"]) {
		// 这里把出现的按钮的上级视图的底色,设置成这个cell的底色相同。不会像原来的这么突兀。
                subview.superview.backgroundColor = self.contentView.backgroundColor ;
            }
            if ([NSStringFromClass([subview class]) isEqualToString:@"UIView"]) {

            }else{

            }
        }
    }
}


你可能感兴趣的:(在UITableView里面 定制滑动显示出来的 按钮的底色。)