How to add custom image to delete button when swiping cell from right on UITableview
as shown in the below image?
func tableView(tableView: UITableView, editActionsForRowAtIndexPath indexPath: NSIndexPath) -> [UITableViewRowAction]? {
let remove = UITableViewRowAction(style: .Default, title: "\nRemove") { action, indexPath in }
remove.backgroundColor = UIColor(patternImage: UIImage(named: "remove")!) }
From the above code, Image is showing but, it is showing as a group of images stacked together. I mean, I am unable to set the "ContentMode"
to ".ScaleToAspectFit"
for the "UIImage"
What is the best way for this approach?
sample code could be appreciable.
Inspired with Denny's answer. Here is objective-c version of his code.
- (NSArray *)tableView:(UITableView *)tableView editActionsForRowAtIndexPath:(NSIndexPath *)indexPath {
UITableViewRowAction *deleteAction = [UITableViewRowAction rowActionWithStyle:UITableViewRowActionStyleDefault title:@" " handler:^(UITableViewRowAction *action, NSIndexPath *indexPath)
{
UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"Do you really want to delete this comment?" message:@"" delegate:self cancelButtonTitle:@"NO" otherButtonTitles:@"YES", nil];
[alertView setTag:101];
[alertView show];
}];
UITableViewCell *commentCell = (UITableViewCell *)[tableView cellForRowAtIndexPath:indexPath];
CGFloat height = commentCell.frame.size.height;
UIImage *backgroundImage = [self deleteImageForHeight:height];
deleteAction.backgroundColor = [UIColor colorWithPatternImage:backgroundImage];
return @[deleteAction];
}
And below is the image drawing method:
- (UIImage*)deleteImageForHeight:(CGFloat)height{
CGRect frame = CGRectMake(0, 0, 62, height);
UIGraphicsBeginImageContextWithOptions(CGSizeMake(62, height), NO, [UIScreen mainScreen].scale);
CGContextRef context = UIGraphicsGetCurrentContext();
CGContextSetFillColorWithColor(context, [UIColor redColor].CGColor);
CGContextFillRect(context, frame);
UIImage *image = [UIImage imageNamed:@"icon-delete"];
[image drawInRect:CGRectMake(frame.size.width/2.0, frame.size.height/2.0 - 10, 18, 20)];
UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return newImage;
}
And the result is:
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With