サムネイル画像

多くの画像を表示する場合、通常処理が重くなります。そこで、実際の画像より小な画像(サムネイル画像)を作成しておき、このサムネイル画像をクライアントのブラウザで表示します。

ImageKit.WPF.Web.Thumbnail コントロールの使用

ここでは Thumbail を使用した Microsoft ASP.NET 用の Web アプリケーションの作成方法を説明します。

Thumbnail コントロールの開発環境のツールボックスへの登録

インストールプログラムを実行すれば、コントロールは自動でツールボックスに登録されますが、ここでは、手動での登録方法を説明します。

  1. "ツールボックス"上でマウスの右クリックをし、"タブの追加"を行います。
  2. 追加したタブ上でマウスの右クリックをし、"アイテムの追加と削除"を選択します。
  3. "参照ボタン"を押して "Newtone.ImageKit.WPF.Web.Thumbnail.dll" を選択します。
  4. ツールボックス上でマウスの右クリックをし、タブの追加を行います。
  5. "OK" ボタンを押します。

Web 用の Thumbnail がツールボックスに登録されます。
 

仮想ディレクトリ

画像を保持するディレクトリと、この画像のサムネイル画像を保持するディレクトリは仮想ディレクトリとして指定します。

詳しくは、ここを参照してください。


プロジェクトの作成

以下は、簡単なプログラム例です。

  1. Visual Studio で新しいプロジェクト(ASP.NET Web アプリケーション)を作成します。
  2. ツールボックスから Thumbnail コントロールを Web フォームに貼ります。
  3. Thumbnail コントロールの位置や、ColumnNumber、RowNumber、ImageWidth、ImageHeight、CellSpacing 等のプロパティを設定してください。
  4. Page_Load イベントで、下記のコードを記述してください。
    ここでは、ポストバックが発生した場合はサムネイルの処理をおこないません。
    [Visual Basic]
    Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
    If IsPostBack = False Then ' 画像があるディレクトリを仮想ディレクトリとして設定 Thumbnail1.ImageDirectory = "/SampleImages/1" Thumbnail1.ThumbnailImageDirectory = "/SampleImages/1/ThumbnailImages" Thumbnail1.ShowThumbnailImages() End If End Sub
    [C#]
    private void Page_Load(object sender, System.EventArgs e)
    {
    Thumbnail1.ImageDirectory="/SampleImages/1"; Thumbnail1.ThumbnailImageDirectory="/SampleImages/1/ThumbnailImages"; Thumbnail1.ShowThumbnailImages(); }
  5. 画像を保持している SampleImagesl フォルダが仮想ディレクトリの設定であることと、パスが正しいことを確認して実行してください。クライアントのブラウザにサムネイル画像の一覧が表示されます。

この例の画像ディレクトリは "/SampleImages/1" となり、サムネイル画像ディレクトリは "/SampleImages/1/ThumbnailImages" となります。ここで、SampleImages は Web で共有するように設定する必要があります。


サーバーの負担軽減

このコンポーネントはサーバー側で動作します。従って、多くのクライアントからのアクセスの負荷をなるべく少なくする必要があります。そこで、

  1. DeleteThumbnailDirectory メソッドを出来るだけ使用しない。(サムネイル画像ディレクトリが存在しないとサムネイル画像を作成する)
  2. サムネイル画像のサイズを必要以上に大きくしない。
  3. サムネイル画像を作成する情報ファイルの内容をなるべく変更しない。

等を考慮する必要があります。


Thumbnail コントロールと ImageKit コントロールの使用

Thumbnail コントロールのフォームと別のフォームの ImageKit コントロールに画像を表示する場合は Thumbnail コントロールの EnablePaging を False に設定してください 。

(例)WebForm1 の Thumbnail コントロールで選択した画像を WebForm2 の ImageKit コントロールに表示

[Visual Basic.NET]
Private Sub Thumbnail1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Thumbnail1.Click
    Server.Transfer("WebForm2.aspx?str=" + Thumbnail1.ImageDirectory + "/" + Thumbnail1.FileName)
End Sub
[Visual C#.NET] private void Thumbnail1_Click(object sender, System.EventArgs e) { Response.Redirect("WebForm2.aspx?str=" + Thumbnail1.ImageDirectory + "/" + Thumbnail1.FileName, false); }


参照

Web.Thumbnail メンバ | Newtone.ImageKit.WPF.Web.Thumbnail