1

こんにちは私はSenchatouch2を使用してアプリケーションを実行しました。カルーセルでは、コントローラーレベルでWebサービスから動的に画像をバインドしていました。カルーセルで画像を移動/スライドすると、次の画像がカルーセルで読み込まれる/表示されるまでに時間がかかります。その時点で元の画像の読み込みに時間がかかる場合は、カルーセルにデフォルトの読み込みマスクが表示されます。カルーセルをスライドさせているときに元の画像を読み込むのに時間がかかる場合は、要件に従って、デフォルトの画像をカルーセルで表示する必要があります。元の画像が読み込まれると、デフォルトの画像を表示する必要はありません。明らかに読み込みマスクも使用されます。誰かがこの煎茶touch2を達成する方法を教えてもらえますか?

マイビューページコード:

Ext.define('SLS.BRND.WEB.view.ProjectsView', {
  extend: 'Ext.Panel',
  requires: [        
  'Ext.Carousel'
  ],
  id: 'projectprofile',
  xtype: "projectspage",
  config: {
    autoDestroy: true,
    fullscreen: true,       
    layout: {
      type: 'vbox'
    },
    items: [{
      xtype: 'panel',
      layout: 'fit',
      flex: Ext.os.is.Phone ? 5 : 5,
      items: [{
        xtype: 'carousel',
        direction: 'horizontal',
        directionLock: true,
        id: 'ImgId',
        flex: Ext.os.is.Phone ? 5 : 5,                          
        config: {
          fullscreen: true                               
        }
      }]
    }]
  }
});

マイコントローラーページコード:

var retrievedObject = localStorage.getItem('ProjectDetails');
jsonObj = Ext.decode(retrievedObject);
var cmp = Ext.getCmp('ImgId');

if (jsonObj != null) {
  if (jsonObj != null) {
    var itemsoverlay = [];
    if (jsonObj.ProjectMainGalleryRoyalGardenia != null) {
      for (var i = 0; i < jsonObj.ProjectMainGalleryRoyalGardenia.length; i++) {
        var imgURL = jsonObj.ProjectMainGalleryRoyalGardenia[i].ImageUrl;
        var senchaIoProjectImageURL = imgURL;
        var senchabigImage = imgURL;

        var images = [{ url: senchaIoProjectImageURL, bigUrl: senchabigImage}]
        Ext.each(images, function (picture) {
          var img = picture.url;
          var bigImg = picture.bigUrl;
          itemsoverlay.push({
            xtype: 'label',
            html: '<div style="width:' + window.innerWidth + 'px;height:' + SLS.BRND.WEB.Common.Constants.carouselCanvasHeight + 'px;"><img src=' + img + ' style="width:100%;height:100%"/></div>'
          });
        });
      }
    }
    cmp.setItems(itemsoverlay);
    cmp.setActiveItem(0);
  }
}
4

1 に答える 1

2

私が見ることができる簡単な解決策は、次のような画像を含むdivにCSSクラスを追加することです。

itemsoverlay.push({
  xtype: 'label',
  html: '<div cls="myDiv" style="width:' + window.innerWidth + 'px;height:' + SLS.BRND.WEB.Common.Constants.carouselCanvasHeight + 'px;"><img src=' + img + ' style="width:100%;height:100%"/></div>'
});

次に、CSSファイルに関連するCSSクラスを作成します。

.myDiv {
  background-image:url();
}

ここでは、プレースホルダー画像をBase 64データに変換し、それをdivの背景画像として追加しました。このようにして、実際の画像が読み込まれる前にデフォルトの画像が表示されます。

myDiv CSSクラスをdivから削除することで、実際の画像が読み込まれた後、デフォルトの画像を簡単に削除できます。

お役に立てれば

于 2012-12-04T17:03:06.807 に答える