0

私はこれがばかげた質問であることを知っています。どういうわけか私の心はこれについて空白です。何か案は?

申し訳ありませんが、もっと明確にすべきでした。

を使用してHtmlGenericControl、画像だけでなくリンクの説明も取り込みます。

 private void InternalCreateChildControls()
    {
        if (this.DataItem != null && this.Relationships.Count > 0)
        {
            HtmlGenericControl fieldset = new HtmlGenericControl("fieldset");
            this.Controls.Add(fieldset);
            HtmlGenericControl legend = new HtmlGenericControl("legend");
            legend.InnerText = this.Caption;
            fieldset.Controls.Add(legend);

            HtmlGenericControl listControl = new HtmlGenericControl("ul");
            fieldset.Controls.Add(listControl);

            for (int i = 0; i < this.Relationships.Count; i++)
            {
                CatalogRelationshipsDataSet.CatalogRelationship relationship =
                    this.Relationships[i];

                HtmlGenericControl listItem = new HtmlGenericControl("li");
                listControl.Controls.Add(listItem);

                RelatedItemsContainer container = new RelatedItemsContainer(relationship);
                listItem.Controls.Add(container);

                Image Image = new Image();
                Image.ImageUrl = relationship.DisplayName;




                LinkButton link = new LinkButton();
                link.Text = relationship.DisplayName;



               ///ToDO Add Image or Image and description
                link.CommandName = "Redirect";
                container.Controls.Add(link);
            }
        }
    }

私のためにこれを行うように誰かに頼むのではなく、単なる参照またはアイデアです。

ありがとう-過度にイライラし、謙虚に感じています。

4

3 に答える 3

2

URLに基​​づいて動的に画像を生成したいとします。

私が通常行うことは、画像を提供するための非常に軽量なHTTPHandlerを作成することです。

using System;
using System.Web;

namespace Example
{  
    public class GetImage : IHttpHandler
    {

        public void ProcessRequest(HttpContext context)
        {
            if (context.Request.QueryString("id") != null)
            {
                // Code that uses System.Drawing to construct the image
                // ...
                context.Response.ContentType = "image/pjpeg";
                context.Response.BinaryWrite(Image);
                context.Response.End();
            }
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}

これは、imgタグで直接参照できます。

<img src="GetImage.ashx?id=111"/>

または、それを実行するサーバーコントロールを作成することもできます。

using System;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace Example.WebControl
{

    [ToolboxData("<{0}:DynamicImageCreator runat=server></{0}:DynamicImageCreator>")]
    public class DynamicImageCreator : Control
    {

        public int Id
        {
            get
            {
                if (ViewState["Id" + this.ID] == null)
                    return 0;
                else
                    return ViewState["Id"];
            }
            set
            {
                ViewState["Id" + this.ID] = value;
            }
        }

        protected override void RenderContents(HtmlTextWriter output)
        {
            output.Write("<img src='getImage.ashx?id=" + this.Id + "'/>");
            base.RenderContents(output);
        }
    }
}

これは次のように使用できます

<cc:DDynamicImageCreator id="db1" Id="123" runat="server/>
于 2008-09-22T19:22:29.450 に答える
0

ASP.NETチームによってCodePlexでリリースされた新しいDynamicImageコントロールを確認してください。

于 2008-09-22T19:18:17.853 に答える
-1

これは一種の恐ろしい質問です。つまり、.NETには、ソースを任意に設定できるイメージコントロールがあります。何について話し合いたいのかわかりません。

于 2008-09-22T19:17:02.130 に答える