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 -