Angular Bootstrap Mobile
Angular Mobile - Bootstrap 4 & Material Design
Note: This documentation is for an older version of Bootstrap (v.4). A
newer version is available for Bootstrap 5. We recommend migrating to the latest version of our product - Material Design for
Bootstrap 5.
Go to docs v.5
Angular Bootstrap mobile gestures are touch-based interactions with mobile devices. A variety different fingers movements may indicate particular component responses.
MDB provides you with support for the most common touch gestures.
data:image/s3,"s3://crabby-images/505f4/505f4ab3618c3e531f481bca32828fb4b9208a20" alt="Pan gesture"
data:image/s3,"s3://crabby-images/f60fe/f60fe29766c5947b52c41b8b47115210d67c78e1" alt="Rotate gesture"
data:image/s3,"s3://crabby-images/10fad/10fadae3048a078e95934acd7f0d95b1228abc56" alt="Press gesture"
data:image/s3,"s3://crabby-images/942b9/942b974dcbdc8645b59a717e908ac571304a7fe2" alt="Tap gesture"
data:image/s3,"s3://crabby-images/6a3af/6a3afa9935358c2cd2d3222561f80379237a6edb" alt="Swipe gesture"
data:image/s3,"s3://crabby-images/c2bc5/c2bc586189d8223af1eaa0b06a762afcfc417671" alt="Pinch gesture"
Carousel with gesture support
data:image/s3,"s3://crabby-images/bdd20/bdd2089ffd5d7ca2a60627e3eeea519f2d12cb92" alt="Mobile - Material Design for Bootstrap"
Click on the button below to launch a live example and see the Carousel with gesture support in action.
Live previewTo make it work, use the code below together with one of MDB carousels.
Note: Remember to set a corresponding ID in both Carousel and script.
<mdb-carousel #carousel>
[ Slides ]
</mdb-carousel>
import { Component, ViewChild, HostListener } from '@angular/core';
import { CarouselComponent } from 'path-to-carousel-component';
@Component({
selector: 'app-root',
templateUrl: 'app.component.html'
})
export class AppComponent {
@ViewChild('carousel', { static: true }) carousel!: CarouselComponent;
@HostListener('swipeleft', ['$event'])
swipePrev(event: any) {
this.carousel.previousSlide();
}
@HostListener('swiperight', ['$event'])
swipeNext(event: any) {
this.carousel.nextSlide();
}
}
Usage
It’s easy to use, just add a global HammerJS config in app.module.ts
file:
import { HammerGestureConfig, HAMMER_GESTURE_CONFIG } from '@angular/platform-browser';
declare var Hammer: any;
export class MyHammerConfig extends HammerGestureConfig {
overrides = <any> {
'pan': { direction: Hammer.DIRECTION_All },
'swipe': { direction: Hammer.DIRECTION_VERTICAL },
};
buildHammer(element: HTMLElement) {
const mc = new Hammer(element, {
touchAction: 'auto',
inputClass: Hammer.SUPPORT_POINTER_EVENTS ? Hammer.PointerEventInput : Hammer.TouchInput,
recognizers: [
[Hammer.Swipe, {
direction: Hammer.DIRECTION_HORIZONTAL
}]
]
});
return mc;
}
}
@NgModule({
declarations: [
...
],
imports: [
...
],
providers: [
...,
{
provide: HAMMER_GESTURE_CONFIG,
useClass: MyHammerConfig
}
],
})
Also, the viewport meta tag is recommended, it gives more control back to the webpage by disabling the double-tap/pinch zoom. More recent browsers which support the touch-action property don’t require this.
<meta name="viewport" content="user-scalable=no, width=device-width, initial-scale=1, maximum-scale=1">