直接上代码。

<template>
<div class="home">
</div>
</template> <script>
export default {
name: "Home",
data() {
return {
interval: null,//时间间隔
};
},
created() {
var _this = this;
// 监听游戏手柄
window.addEventListener("gamepadconnected", function(e) {
var gp = navigator.getGamepads()[e.gamepad.index];
console.log(gp);
_this.startgamepad(); // 启动手柄
});
// 监听游戏手柄拔出
window.addEventListener("gamepaddisconnected", function(e) {
clearInterval(_this.interval); // 停止获取手柄数据
});
},
methods: {
// 启动手柄
startgamepad() {
var _this = this;
// 每200ms 获取一次手柄数据,查看是否按下手柄按键
this.interval = setInterval(function() {
var gamepad = navigator.getGamepads()[0];
_this.remoteSensing(gamepad.axes);
_this.pressKey(gamepad.buttons);
}, 200);
},
// 手柄遥感
remoteSensing(arr) {
console.log(arr);
// 下面是个人测试的:
// arr[0] -1 ~ 1 : 左手边 左 ~ 右
// arr[1] -1 ~ 1 : 左手边 上 ~ 下
// arr[2] -1 ~ 1 : 右手边 左 ~ 右
// arr[3] -1 ~ 1 : 右手边 上 ~ 下
},
// 手柄按键
pressKey(arr) {
// console.log(arr);
for (let i = 0; i < arr.length; i++) {
if (arr[i].value == 1) {
console.log(i);
// 根据个人情况判断;不同手柄值不同。
if (i == 0) {
console.log("A");
}
if (i == 1) {
console.log("B");
}
if (i == 2) {
console.log("X");
}
if (i == 3) {
console.log("Y");
} if (i == 4) {
console.log("左手1");
}
if (i == 5) {
console.log("右手1");
}
if (i == 6) {
console.log("左手2");
}
if (i == 7) {
console.log("右手2");
} if (i == 8) {
console.log("BACK");
}
if (i == 9) {
console.log("START");
} if (i == 10) {
console.log("左遥感按下");
}
if (i == 11) {
console.log("右遥感按下");
} if (i == 12) {
console.log("上");
}
if (i == 13) {
console.log("下");
}
if (i == 14) {
console.log("左");
}
if (i == 15) {
console.log("右");
}
}
}
},
}
};
</script> <style lang="scss" scoped>
.home {
position: fixed;
width: 100%;
height: 100%;
}
</style>

vue 游戏手柄使用的更多相关文章

  1. Vue.js 和 MVVM 小细节

    MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式,其核心是提供对View 和 ViewModel 的双向数据绑定,这使得ViewModel 的状态改变可以自 ...

  2. wepack+sass+vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  3. wepack+sass+vue 入门教程(二)

    六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...

  4. wepack+sass+vue 入门教程(一)

    一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...

  5. Vue + Webpack + Vue-loader 系列教程(2)相关配置篇

    原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ 使用预处理器 在 Webpack 中,所有的预处理器需要和一个相应的加载器一同使用.vue- ...

  6. Vue + Webpack + Vue-loader 系列教程(1)功能介绍篇

    原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ Vue-loader 是什么? vue-loader 是一个加载器,能把如下格式的 Vue ...

  7. 关于Vue.js 2.0 的 Vuex 2.0,你需要更新的知识库

    应用结构 实际上,Vuex 在怎么组织你的代码结构上面没有任何限制,相反,它强制规定了一系列高级的原则: 应用级的状态集中放在 store 中. 改变状态的唯一方式是提交mutations,这是个同步 ...

  8. Vue.js 2.0 和 React、Augular等其他框架的全方位对比

    引言 这个页面无疑是最难编写的,但也是非常重要的.或许你遇到了一些问题并且先前用其他的框架解决了.来这里的目的是看看Vue是否有更好的解决方案.那么你就来对了. 客观来说,作为核心团队成员,显然我们会 ...

  9. 窥探Vue.js 2.0 - Virtual DOM到底是个什么鬼?

    引言 你可能听说在Vue.js 2.0已经发布,并且在其中新添加如了一些新功能.其中一个功能就是"Virtual DOM". Virtual DOM是什么 在之前,React和Em ...

随机推荐

  1. Java面试题(JVM篇)

    JVM 194.说一下 jvm 的主要组成部分?及其作用? 类加载器(ClassLoader) 运行时数据区(Runtime Data Area) 执行引擎(Execution Engine) 本地库 ...

  2. shrio总结

    AccessControlFilter(https://www.jianshu.com/p/9bfa22b0e905) SpringBoot+Shiro学习之自定义拦截器管理在线用户(踢出用户)   ...

  3. 集成学习小结(RF、adaboost、xgboost)

    目录 回顾监督学习的一些要素 集成学习(学什么) bagging boosting 梯度提升(怎么学) GBDT Xgboost 几种模型比较 Xgboost 与 GBDT xgboost 和 LR ...

  4. 【趣味设计模式系列】之【代理模式4--ASM框架解析】

    1. 简介 ASM是assemble英文的简称,中文名为汇编,官方地址https://asm.ow2.io/,下面是官方的一段英文简介: ASM is an all purpose Java byte ...

  5. Python 装饰器填坑指南 | 最常见的报错信息、原因和解决方案

    本文为霍格沃兹测试学院学员学习笔记. Python 装饰器简介 装饰器(Decorator)是 Python 非常实用的一个语法糖功能.装饰器本质是一种返回值也是函数的函数,可以称之为“函数的函数”. ...

  6. The Triangle (简单动态规划)

    7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 (Figure 1) Figure 1 shows a number triangle. Write a program that calc ...

  7. 答应我,用了这个jupyter插件,别再重复造轮子了

    1 简介 在使用Python.R等完成日常任务的过程中,可能会经常书写同样或模式相近的同一段代码,譬如每次使用matplotlib绘制图像的时候可以在开头添加下面两行代码来解决中文乱码等显示问题: p ...

  8. C# 获取当前月的月初和月末

    /// <summary> /// 获取当前月的月末日期 /// </summary> /// <returns></returns> public s ...

  9. cdq分治——bzoj2683简单题

    https://www.lydsy.com/JudgeOnline/problem.php?id=2683 知识点:1.以操作的顺序进行分治  2.cdq分治维护矩阵 3.计算比mid小的给比mid大 ...

  10. SpringBoot简单(登录/显示/登出)工程下载 使用Thymeleaf输出页面文字

    下载地址:https://files.cnblogs.com/files/xiandedanteng/SessionShare20191226.zip 测试用,画面如下: SpringMVC入门弟子也 ...