在列表中呈现在彼此顶部的图像
本文关键字:顶部 图像 列表 | 更新日期: 2023-09-27 17:58:46
我正在创建一个基于Monotouch元素的元素。这样做的结果是,它在每个单元格中创建一个包含主题、域名和Fav图标的列表(如Twitter Timeline)。问题是:列表中的第一个和最后一个fav图标显示两次,因此它们位于彼此的顶部。
下面是代码。有人看到我犯了什么错误吗/Robert
public override void Draw (RectangleF rect)
{
const int padright = 12;//21;
var ctx = UIGraphics.GetCurrentContext ();
bool highlighted = (Superview.Superview as UITableViewCell).Highlighted;
var bounds = Bounds;
var midx = bounds.Width/2;
if (highlighted){
UIColor.FromRGB (4, 0x79, 0xef).SetColor ();
ctx.FillRect (bounds);
//Images.MenuShadow.Draw (bounds, CGBlendMode.Normal, 0.5f);
//textColor = UIColor.White;
} else {
UIColor.White.SetColor ();
ctx.FillRect (bounds);
ctx.DrawLinearGradient (bottomGradient, new PointF (midx, bounds.Height-17), new PointF (midx, bounds.Height), 0);
ctx.DrawLinearGradient (topGradient, new PointF (midx, 1), new PointF (midx, 3), 0);
}
float boxWidth;
float boxHeight = Bounds.Height;
boxWidth = 0;
//SizeF ssize;
//string label;
//label = Date;
//ssize = StringSize (label, SubjectFont);
//float dateSize = ssize.Width + padright + 5;
//DrawString (label, new RectangleF (Bounds.Width-dateSize-5, 5, dateSize, 14), DateFont, UILineBreakMode.Clip, UITextAlignment.Right);
const int offset = 46; //33;
float bw = Bounds.Width-offset;
UIColor.Black.SetColor ();
//Extracting the domain name that I get.
string domainName = new Uri(Sender).DnsSafeHost;
if(domainName.StartsWith("www"))
{
domainName = domainName.Substring(4, domainName.Length-4);
}
//Checking to see if there is any subdomain.
//If so, I start at the first dot to get the domainname "clean".
int countDots = domainName.Split('.').Length - 1;
if(countDots > 1)
{
Console.WriteLine("Dots: " + countDots);
int i = domainName.IndexOf('.') + 1;
Console.WriteLine("Position: " + i);
domainName = domainName.Substring(i).Trim();
Console.WriteLine("Domain: " + domainName);
}
DrawString (Subject, new RectangleF (offset, 6, bw-boxWidth-5, 24), SubjectFont, UILineBreakMode.TailTruncation, UITextAlignment.Left);
DrawString (domainName, new PointF (offset, 28), bw/*-dateSize*/, SenderFont, UILineBreakMode.TailTruncation);
//Getting the fav icon from the domainname and posting it to g.etfv.co.
string favUrl = "http://www."+domainName;
Console.WriteLine("Fav icon: " + favUrl);
Uri imageBackground = null;
imageBackground = new Uri ("http://g.etfv.co/"+ favUrl);
var avatar = ImageLoader.DefaultRequestImage (imageBackground, this);
var imageRect = new RectangleF(15f, 10f, 16f, 16f);
using (var myImage = new UIImageView(imageRect))
{
if(avatar == null)
{
//A local avatar if something goes wrong
string localAvatar = "Images/avatar.png";
myImage.Image = UIImage.FromFile(localAvatar);
}
else
{myImage.Image = avatar;}
AddSubview(myImage);
}
avatar = null;
}
有人看到我犯了什么错误吗?
第1部分
你的描述"因此他们在一起"并不完全清楚。
但我猜这个问题可能隐藏在这个方法的作用背后?
var avatar = ImageLoader.DefaultRequestImage (imageBackground, this);
如果这是异步请求化身的,那么您需要确保当异步方法返回时,该单元格没有被重用到其他位置。
在TweetStation中,这是在void IImageUpdated.UpdatedImage (long onId)
回调中的以下行中完成的:
// Discard notifications that might have been queued for an old cell
if (tweet == null || (tweet.UserId != onId && tweet.RetweeterId != onId))
return;
你的回拨中有类似的行吗?
有人看到我犯了什么错误吗?
第2部分
我想说你犯了一个错误,把一种方法做得太久了,连你都看不懂
考虑使用像"提取方法"这样的重构工具,以便将其分解为有意义的较小函数。参见
这都是正常重构的一部分——在一个函数中编写代码,然后将其重构成更小的部分,因为它变得太长、太难处理。。。
很多人会说我写的方法太小了。。。
所以无论你做什么,只要找到适合你和你的代码的东西:)