直接上代码。

<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. Kernel methods on spike train space for neuroscience: a tutorial

    郑重声明:原文参见标题,如有侵权,请联系作者,将会撤销发布! 时序点过程:http://www.tensorinfinity.com/paper_154.html Abstract 在过去的十年中,人 ...

  2. 【转】python调用youtube-dl实现视频下载

    youtube-dl是一个命令行程序,用于从YouTube.com和更多网站下载视频.它需要Python解释器,版本2.6,2.7或3.2+,并且支持Unix,Windows或Mac OS X中运行. ...

  3. Windows Server 2012 R2 时间同步

    最近的项目两台服务器都是Windows Server 2012的系统,需要做时间同步,现在是一些从网上搜罗的步骤总结. 具体就是配置windows的注册表: 一.服务端配置 (NTP服务器,客户端将根 ...

  4. Navicat12 for Mysql激活

    1      下载 注册机和Navicat网盘下载地址 链接:https://pan.baidu.com/s/1AFpQIlHCXVHc8OuBZ9PAlA  提取码:xvi2 2      安装 2 ...

  5. Python发送get、post请求

    import json import requests #获取北京天气 # #url= "https://wis.qq.com/weather/common?source=xw&we ...

  6. 项目介入EF Core

    目前.Net主流的ORM有SqlSugar.Entity Framework.Dapper,其它的我就不列举了.其实和Java那边ibatis相比,他们都比较轻量.之前用ibatis开发,真的很麻烦, ...

  7. python接口测试自动化之python基础语法

    一.pycharm的使用和python基本语法 (一).pycharm的使用和python环境 1.python以及pycharm的安装 python 的版本选择:3.x 版本,不要安装2.x 版本, ...

  8. 利用分块传输吊打所有WAF--学习笔记

    在看了bypassword的<在HTTP协议层面绕过WAF>之后,想起了之前做过的一些研究,所以写个简单的短文来补充一下文章里“分块传输”部分没提到的两个技巧. 技巧1 使用注释扰乱分块数 ...

  9. SQL SERVER管理维护计划错误,备份错误,1053/3041/错误18204,严重性16,状态1

    在sqlserv2008/2012里设置了管理-维护计划-备份计划,前些天遇到报错-1053/3041/错误18204,严重性16,状态1等:分享下解决方法. 1.在服务器执行任务报错 2.解决办法 ...

  10. vue <compent> 结合is实现动态切换子组件

    这里就很自然的产生一个新问题:如何给相应的子组件传props?