我正在使用到目前为止受到巨大打击的FlickrNet c#库。
然而,我有一个问题。我可以获取用户ID的所有照片,但我无法获取特定照片所属的设置名称,而无需再执行其他API调用。这个单独的电话给我带来了巨大的性能问题。主页需要30秒才能加载40张图像。这只会增加。
我需要获取每张照片的设置名称,因为我正在使用同位素来显示图像。
我只是从api抓取图像并将它们绑定到转发器上。
这是我的代码。
C#
Flickr f = FlickrManager.GetAuthInstance();
protected void Page_Load(object sender, EventArgs e)
{
string userID = f.PeopleFindByEmail("me@yahoo.com").UserId;
PhotoSearchOptions options = new PhotoSearchOptions
{
UserId = userID,
Extras = PhotoSearchExtras.AllUrls | PhotoSearchExtras.Description | PhotoSearchExtras.Tags,
SortOrder = PhotoSearchSortOrder.Relevance,
};
var photos = f.PhotosSearch(options);
rptPhotos.DataSource = photos;
rptPhotos.DataBind();
}
protected string GetSetNameForImageID(string imageID)
{
var sets = f.PhotosGetAllContexts(imageID).Sets;
return sets[0].Title.ToLower().Replace(" ", "-");
}
HTML
<asp:Repeater runat="server" ID="rptPhotos">
<ItemTemplate>
<section class="<%# GetSetNameForImageID( Convert.ToString( Eval("PhotoID") ) ) %> item">
<%--<a href="@Url.Action("Image", "Home", new {id = item.PhotoId})">--%>
<a href="/View.aspx?pid=<%# DataBinder.Eval(Container.DataItem, "PhotoID") %>">
<div>
<div class="item_hover">
<header>
<span>D</span>
<%--<p title="@item.Description" class="tiptip">_</p> --%>
<p title="<%# DataBinder.Eval(Container.DataItem, "Description") %>" class="tiptip">_</p>
<hgroup>
<%--<h2>@item.Title</h2>
<h3>@item.Tags[0]</h3>--%>
<h2><%# DataBinder.Eval(Container.DataItem, "Title") %></h2>
<h3><%# DataBinder.Eval(Container.DataItem, "Tags[0]") %></h3>
</hgroup>
</header>
</div>
<%--<img src="@item.Small320Url" alt="Video sit amet consectetur" />--%>
<img src="<%# DataBinder.Eval(Container.DataItem, "Small320Url") %>" alt="Video sit amet consectetur" />
</div>
</a>
</section>
</ItemTemplate>
</asp:Repeater>
有没有更快的方法来获取每个图像的设置名称而没有GetSetNameForImageID和后续的api调用?
答案 0 :(得分:3)
我注意到PhotosGetAllContexts
的一个问题是,您使用的Sets
属性是ContextSet
个对象的集合,而PhotoSetId
个对象又存储了Title
和{ {1}}。
如何合并PhotosetsGetList和PhotosetsGetPhotos方法?我认为您可以使用这两个来避免使用PhotosGetAllContexts
方法时遇到的开销。
免责声明:未经过测试的代码。
var photoSets = f.PhotosetsGetList(userId);
Dictionary<string, List<Photo>> photoSetPhotoMap = new Dictionary<string, List<Photo>>();
foreach (var photoSet in photoSets)
{
var photoSetPhotos = f.PhotosetsGetPhotos(photoSet.PhotosetId,
PhotoSearchExtras.AllUrls | PhotoSearchExtras.Description | PhotoSearchExtras.Tags);
photoSetPhotoMap.Add(photoSet.PhotosetId, photoSetPhotos.ToList());
}
var photos =
from kvp in photoSetPhotoMap
from photo in kvp.Value
select new
{
SetTitle = kvp.Key, PhotoId = photo.PhotoId, Description = photo.Description,
PhotoTitle = photo.Title, Tags = photo.Tags[0], Small320Url = photo.Small320Url
};
rptPhotos.DataSource = photos;
rptPhotos.DataBind();
我认为这种方法的主要困难是有效地实现分页 - 取决于photoset的大小(您可以通过NumberOfPhotos
属性确定),您可能会遇到页面剪切的情况在照片集中途中途。
要解决这个问题,我建议您使用NumberOfPhotos
属性来计算照片总数,然后使用页面大小乘以页码来确定需要的数量和PhotoSets
完成请求。