Mobile Angular UI - Acara Sentuh

Untuk bekerja dengan Touch dan acaranya, Anda perlu menambahkan modul berikut -

mobile-angular-ui.gestures

Jika Anda hanya tertarik dengan modul sentuh, maka Anda hanya dapat menambahkan mobile-angular-ui.gestures.touch .

$ touch adalah layanan yang tersedia dengan modul sentuh. Ini akan berfungsi pada perangkat input apa pun yang ingin Anda gunakan. Ini memberikan detail seperti gerakan, durasi, kecepatan, arah, dll.

Metode di $ touch

Berikut ini adalah metode yang tersedia di $ touch -

mengikat

Mari kita lihat metode mengikat .

Syntax

$touch.bind(element, eventHandlers, [options])

Parameters

element - Elemen html yang ingin Anda tangani dengan detail sentuh.

eventHandlers- Objek dengan penangan untuk acara sentuh tertentu. EventHandlers yang tersedia adalah -

  • start - Ini panggilan balik untuk acara touchstart.

  • end - Ini acara callback untuk touchend.

  • move - Ini panggilan balik untuk acara touchmove.

  • cancel - Ini panggilan balik untuk acara touchcancel.

options - Merupakan obyek yang dapat memiliki detail sebagai berikut -

  • movementThreshold- Nilai integer. Jumlah piksel gerakan sebelum mulai memicu penangan touchmove.

  • valid - Ini adalah fungsi yang mengembalikan nilai boolean yang memutuskan apakah sentuhan harus ditangani atau diabaikan.

  • sensitiveArea- Ini bisa berupa fungsi, atau elemen atau BoundingClientRect. Area sensitif menentukan batas untuk melepaskan sentuhan saat ada gerakan di luar.

  • pointerTypes - Ini adalah larik penunjuk yang memiliki kunci yang merupakan bagian dari peta peristiwa penunjuk default.

Jenis tersedia di $ touch

Berikut ini adalah tipe yang tersedia di $ touch -

Properti Tipe Deskripsi
Tipe tali Ini akan memberi tahu Anda jenis acara. Misalnya - touchmove, touchstart, touchend, touchcancel
cap waktu Tanggal Stempel waktu saat sentuhan terjadi
durasi int Perbedaan antara acara sentuh saat ini dan awal sentuh
startX mengapung Koordinat X untuk touchstart
startY mengapung Koordinat Y untuk touchstart
prevX mengapung Koordinat X dari touchstart atau touchmove yang terjadi sebelumnya
menang mengapung Koordinat Y dari touchstart atau touchmove yang terjadi sebelumnya
x mengapung Koordinat X acara sentuh
y mengapung Koordinat Y acara sentuh
langkah mengapung Jarak antara poin prevX, prevY dan x, y
stepX mengapung Jarak antara poin prevX dan x
stepY mengapung Jarak antara poin prevY dan y
kecepatan mengapung Kecepatan dalam piksel dari peristiwa sentuh per detik
kecepatan rata-rata mengapung Kecepatan rata-rata peristiwa touchstart per detik
jarak mengapung Jarak antara titik startX, startY dan x, y
jarakX mengapung Jarak antara titik startX dan x
jarak mengapung Jarak antara titik startY dan y
total mengapung Gerakan total yaitu gerakan horizontal dan vertikal yang dilakukan di seluruh perangkat
totalX mengapung Gerakan total yaitu arah horizontal, termasuk perputaran dan perubahan arah
totalY mengapung Gerakan total yaitu arah vertikal, termasuk perputaran dan perubahan arah
arah mengapung Lokasi sentuhan arah kiri, atas, bawah, kanan
sudut mengapung Sudut dalam derajat dari sumbu x dan y

Berikut adalah contoh kerja yang menunjukkan jenis sentuhan.

index.html

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8" />
      <title>Mobile Angular UI Demo</title>
      <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
      <meta name="apple-mobile-web-app-capable" content="yes" />
      <meta name="viewport" content="user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimal-ui" />
      <meta name="apple-mobile-web-app-status-bar-style" content="yes" />
      <link rel="shortcut icon" href="/assets/img/favicon.png" type="image/x-icon" />
      <link rel="stylesheet" href="node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-hover.min.css" />
      <link rel="stylesheet" href="node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-base.min.css" />
      <link rel="stylesheet" href="node_modules/mobile-angular-ui/dist/css/mobile-angular-ui-desktop.min.css" />
      <script src="node_modules/angular/angular.min.js"></script>
      <script src="node_modules/angular-route/angular-route.min.js"></script>
      <script src="node_modules/mobile-angular-ui/dist/js/mobile-angular-ui.min.js"></script>
      <script src="node_modules/angular-route/angular-route.min.js"></script>
      <script src="node_modules/mobile-angular-ui/dist/js/mobile-angular-ui.gestures.min.js"></script>
      <link rel="stylesheet" href="src/css/app.css" />
      <script src="src/js/app.js"></script>
      <style>
         a.active {
            color: blue;
         }
      </style>
   </head>

   <body ng-app="myFirstApp" ng-controller="MainController" class="listening">
      
      <!-- Sidebars -->
      <div class="sidebar sidebar-left ">
         <div class="scrollable">
            <h1 class="scrollable-header app-name">Tutorials</h1>
            <div class="scrollable-content">
               <div class="list-group" ui-turn-off='uiSidebarLeft'>
                  <a class="list-group-item" href="/">Home Page </a>
                  <a class="list-group-item" href="#/academic"><i class ="fa fa-caret-right"></i>Academic Tutorials </a>
                  <a class="list-group-item" href="#/bigdata"><i class ="fa fa-caret-right"></i>Big Data & Analytics </a>
                  <a class="list-group-item" href="#/computerProg"><i class="fa fa-caret-right"></i>Computer Programming </a>
                  <a class="list-group-item" href="#/computerscience"><i class="fa fa-caret-right"></i>Computer Science </a>
                  <a class="list-group-item" href="#/databases"><i class="fa fa-caret-right"></i>Databases </a>
                  <a class="list-group-item" href="#/devops"><i class="fa fa-caret-right"></i>DevOps </a>
               </div>
            </div>
         </div>
      </div>
      <div class="sidebar sidebar-right">
         <div class="scrollable">
            <h1 class="scrollable-header app-name">eBooks</h1>
            <div class="scrollable-content">
               <div class="list-group" ui-toggle="uiSidebarRight">
                  <a class="list-group-item" href="#/php"><i class="fa fa-caret-right"></i>PHP </a>
                  <a class="list-group-item" href="#/Javascript"><i class="fa fa-caret-right"></i>Javascript </a>
               </div>
            </div>
         </div>
      </div>
      <div class="app">
         <div class="navbar navbar-app navbar-absolute-top">
            <div class="navbar-brand navbar-brand-center" ui-yield-to="title">
               TutorialsPoint
            </div>
            <div class="btn-group pull-left">
               <div ui-toggle="uiSidebarLeft" class="btn sidebar-left-toggle">
                  <i class="fa fa-th-large "></i> Tutorials
               </div>
            </div>
            <div class="btn-group pull-right" ui-yield-to="navbarAction">
               <div ui-toggle="uiSidebarRight" class="btn sidebar-right-toggle">
                  <i class="fal fa-search"></i> eBooks
               </div>
            </div>
         </div>
         <div class="navbar navbar-app navbar-absolute-bottom">
            <div class="btn-group justified">
               <a ui-turn-on="aboutus_modal" class="btn btn-navbar"><i class="fal fa-globe"></i> About us</a>
               <a ui-turn-on="contactus_overlay" class="btn btn-navbar"><i class="fal fa-map-marker-alt"></i> Contact us</a>
            </div>
         </div>

         <!-- App body -->
         <div class='app-body'>
            <div class='app-content'>
               <ng-view></ng-view>
            </div>
         </div>
      </div><!-- ~ .app -->
      
      <!-- Modals and Overlays -->
      <div ui-yield-to="modals"></div>
   </body>
</html>

Ada touchtest direktif ditambahkan di app.js yang menggunakan metode $ touch.bind.

directive('touchtest', ['$touch', function($touch) {
   return {
      restrict: 'C',
      link: function($scope, elem) {
         $scope.touch=null;
         $touch.bind(elem, {
            start: function(touch) {
               $scope.containerRect=elem[0].getBoundingClientRect();
               $scope.touch=touch;
               $scope.$apply();
            },
            cancel: function(touch) {
               $scope.touch=touch;
               $scope.$apply();
            },
            move: function(touch) {
               $scope.touch=touch;
               $scope.$apply();
            },
            end: function(touch) {
               $scope.touch=touch;
               $scope.$apply();
            }
         });
      }
   };
}]);

Kode lengkap di dalam app.js adalah sebagai berikut -

/* eslint no-alert: 0 */

'use strict';
//
// Here is how to define your module
// has dependent on mobile-angular-ui
//
var app=angular.module('myFirstApp', ['ngRoute',
   'mobile-angular-ui',
   'mobile-angular-ui.gestures',
]);
app.config(function($routeProvider, $locationProvider) {
   $routeProvider
   .when("/", {
      templateUrl : "src/home/home.html"
   });
   $locationProvider.html5Mode({enabled:true, requireBase:false});
});
app.directive('touchtest', ['$touch', function($touch) {
   return {
      restrict: 'C',
      link: function($scope, elem) {
         $scope.touch=null;
         $touch.bind(elem, {
            start: function(touch) {
               $scope.containerRect=elem[0].getBoundingClientRect();
               $scope.touch=touch;
               $scope.$apply();
            },
            cancel: function(touch) {
               $scope.touch=touch;
               $scope.$apply();
            },
            move: function(touch) {
               $scope.touch=touch;
               $scope.$apply();
            },
            end: function(touch) {
               $scope.touch=touch;
               $scope.$apply();
            }
         });
      }
   };
}]);
app.controller('MainController', function($rootScope, $scope, $routeParams) {
   $scope.msg="Welcome to TutorialsPoint!";
});

src/home/home.html

Touchtest direktif digunakan di dalam html seperti yang ditunjukkan di bawah ini -

<div class="section touchtest">
   <h4>Touch Around on the screen to see the values changing</h4>
   <div>
      <p>type: {{touch.type}}</p>
      <p>direction: {{touch.direction == null ? '-' : touch.direction}}</p>
      <p>point: [{{touch.x}}, {{touch.y}}]</p>
      <p>step: {{touch.step}} [{{touch.stepX}}, {{touch.stepY}}]</p>
      <p>distance: {{touch.distance}} [{{touch.distanceX}}, {{touch.distanceY}}]</p>
      <p>total: {{touch.total}} [{{touch.totalX}}, {{touch.totalY}}]</p>
      <p>velocity: {{touch.velocity}} px/sec</p>
      <p>averageVelocity: {{touch.averageVelocity}} px/sec</p>
      <p>angle: {{touch.angle == null ? '-' : touch.angle}} deg</p>
   </div>
</div>

Sekarang mari kita uji tampilan di browser. Layar yang dihasilkan adalah sebagai berikut -