下の画像に示すように、UITableview
の右からセルをスワイプするときに削除ボタンにカスタム画像を追加するにはどうすればよいですか?
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")!) }
上記のコードから、画像は表示されていますが、一緒に積み重ねられた画像のグループとして表示されています。つまり、"ContentMode"
の".ScaleToAspectFit"
を"UIImage"
に設定できません。
このアプローチの最良の方法は何ですか?
サンプルコードはかなりのものかもしれません。
デニーの答えに触発されました。これが彼のコードのobjective-cバージョンです。
- (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];
}
そして、以下は画像の描画方法です。
- (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;
}
基本的に、コンテキストで描画してから、コンテキストから新しい画像を取得します。
let label = UILabel(frame: CGRect(x: 0, y: 0, width: 80, height: 100))
label.text = "ADD"
label.textAlignment = .Center
label.textColor = UIColor.whiteColor()
let img: UIImage = UIImage(named: "delete")
UIGraphicsBeginImageContextWithOptions(imgSize, false, UIScreen.mainScreen().scale)
let context = UIGraphicsGetCurrentContext()
// Set background color
CGContextSetFillColorWithColor(context, UIColor.raangeRed().CGColor)
CGContextFillRect(context, CGRect(x: 0, y: 0, width: 80, height: 80))
// Draw image
img.drawInRect(CGRectMake(30, 15, 20, 20))
// Draw View
label.layer.renderInContext(context!)
// Retrieve new UIImage
let newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
let deleteRowAction = UITableViewRowAction(style: .Normal, title: " ") { (rowAction, indexPath) in
// Do stuff
}
deleteRowAction.backgroundColor = UIColor(patternImage: newImage)
(UIImageViewとUILabelを使用して)カスタムビューを作成し、コンテキスト内にレンダリングすることもできます。
これを試して
let backImage = UIImageView(image: UIImage(named: "remove"))
backImage.contentMode = .scaleAspectFit
remove.backgroundColor = UIColor(patternImage:backImage.image!)
選択肢-2
var img: UIImage = UIImage(named: "remove")
var imgSize: CGSize = tableView.frame.size
UIGraphicsBeginImageContext(imgSize)
img.drawInRect(CGRectMake(20, 0, 20, 20))
var newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
remove.backgroundColor = UIColor(patternImage: newImage)