0

まとめ 概要

UITableViewSource に次のオーバーライド GetCell があります。すべて正常に動作しますが、サイズを変更せずに、セルの左側の画像を小さくしたいと考えています。基本的には、フレームを縮小して (幅 30 x 高さ 30)...そしておそらく角を丸くしたいだけです (Whatsapp のオープン チャットのリストに似ています)。

問題

ImageView の Frame プロパティに新しい RectangleF を適用するだけでは機能しないようです。

 if (tableItems[indexPath.Section].Items[indexPath.Row].ImageName != null)
                                {
//RESIZE IMAGE VIEW
cell.ImageView.Frame = new RectangleF(5,5,30,30);
                                        Console.WriteLine("Image name: " + tableItems[indexPath.Section].Items[indexPath.Row].ImageName);
                                        cell.ImageView.Image = UIImage.FromFile (tableItems[indexPath.Section].Items[indexPath.Row].Image); 
                                }

コード

 public override UITableViewCell GetCell (UITableView tableView, NSIndexPath indexPath)
            {
                    UITableViewCell cell = tableView.DequeueReusableCell (cellIdentifier);
                    Custom_UITableItem item = tableItems[indexPath.Section].Items[indexPath.Row];
                    var cellStyle = UITableViewCellStyle.Subtitle;

                    // if there are no cells to reuse, create a new one
                    if (cell == null) 
                    {
                            cell = new UITableViewCell (cellStyle, cellIdentifier);
                    }

                    try
                    {
                            if(cellAccessoryButtons.Count > 0)
                            {
                                    var cellAccessoryButton = cellAccessoryButtons [indexPath.Row];
                                    cell.AccessoryView = cellAccessoryButton;
                            }

                            cell.TextLabel.Text = tableItems[indexPath.Section].Items[indexPath.Row].Heading;
                            cell.TextLabel.Font = AppSettings.CellDetailTextLabelFontSize;
                            cell.TextLabel.LineBreakMode = UILineBreakMode.WordWrap;
                            cell.TextLabel.Lines = 2;
                            cell.DetailTextLabel.Text = tableItems[indexPath.Section].Items[indexPath.Row].SubHeading;
                            cell.DetailTextLabel.Font = AppSettings.CellDetailTextLabelFontSize;
                            cell.DetailTextLabel.LineBreakMode = UILineBreakMode.WordWrap;
                            cell.DetailTextLabel.Lines = 2;

                            if (tableItems[indexPath.Section].Items[indexPath.Row].ImageName != null)
                            {
//RESIZE IMAGE VIEW
cell.ImageView.Frame = new RectangleF(5,5,30,30);

                                    Console.WriteLine("Image name: " + tableItems[indexPath.Section].Items[indexPath.Row].ImageName);
                                    cell.ImageView.Image = UIImage.FromFile (tableItems[indexPath.Section].Items[indexPath.Row].Image); 
                            }

                            var trackUploadedDateFrame = new RectangleF (87, 55, 100, 20);
                            var trackUploadedDate = new UILabel (trackUploadedDateFrame);
                            trackUploadedDate.BackgroundColor = UIColor.Clear;
                            trackUploadedDate.Font = AppSettings.TrackUploadedDateFontSize;
                            trackUploadedDate.TextAlignment = UITextAlignment.Left;
                            trackUploadedDate.Text = "Uploaded: 16/10/13";
                            cell.AddSubview (trackUploadedDate);

                    }
                    catch(Exception ex) 
                    {
                            Console.WriteLine (ex.ToString ());
                    }

                    return cell;
            } 
4

2 に答える 2

1

要するに、「そこにいて、それを行った」ということで、ストックUITableViewCellのカスタマイズについてお話ししましょう。特に、ImageViewは王様の痛みです。

私の経験から、ストックUITableViewCellの機能が独自の目標に非常に近い場合を除き、UITableViewCellをコードまたはIBを使用して.xibでサブクラス化することにより、設計目標を達成する方が簡単です。

于 2013-10-24T13:06:43.780 に答える