向左/向右滑动用户媒体卡以显示下一个

Swipe user media cards left/right to reveal next one

本文关键字:媒体 显示 下一个 用户 向左      更新时间:2023-09-26

我正在尝试实现一个水平ng-repeats用户媒体对象的小部件,我应该能够向左/向右滑动以显示下一个媒体卡。 小部件应该看起来像这样

如您所见的图像

下一个卡牌头像是半可见的,暗示有更多的卡可以刷。

这就是我目前所拥有的一切..我被困在这里

div class="media  people-card-media col-xs-12" ng-repeat="item in cats">
        <div class="media-left ">
            <div class="person-photo presence" >
                <img  class="media-object list__photo img-circle" ng-src="{{item.photo}}" />
            </div>
        </div>
        <div class="media-body list__body">
            <div class="people_name_title">
                <h4 class="media-heading title">{{item.name}}</h4>
            </div>
        </div>
        <div class="media-right media-middle contacts-chat-call flex-it-align-top">
            <a  style="margin-right: 10px;">
               call
            </a>
        </div>
    </div>

这是普伦克 http://plnkr.co/edit/YESgpGIXQrK9sYl79FVI?p=preview

这是一个带有工作实现的 plunkr。

http://plnkr.co/edit/wmIyCFM57hniZQ82Z8Ba?p=preview

我添加了ngTouch,并在HTML中添加了一个ng-class和触摸事件处理程序。

  <div class="media people-card-media col-xs-12" 
       ng-class="item.displayClass"
       ng-repeat="item in heroes"
       ng-click="gonext()"
       ng-swipe-left="gonext()"
       ng-swipe-right="goprev()">

在 MainController 中,它通过为活动项目分配一个 current 类,为邻居分配一个next-upprevious类来翻转活动项目。

$scope.gonext = function () {
  for (var i=0, len=$scope.heroes.length; i<len; i++) {
    if ($scope.heroes[i].displayClass == 'current') {
      $scope.heroes[i].displayClass = 'previous';
      if (i<len-1) $scope.heroes[i+1].displayClass = 'current';
      if (i<len-2) $scope.heroes[i+2].displayClass = 'next-up';
      i=len;
    };
  };
};

只需要更好地处理边界。