方法1. 简单1 LED方法

这是一个很忽悠的方法,把LED看成是屏幕中心,把光枪摄像头的视野范围看作是屏幕范围。

假设WII枪头摄像头的数据范围为[0,1024]*[0,768],显示器屏幕分辨率为dx,dy。如果从手柄获取到的坐标值为x,y,则对应的屏幕位置为(x*dx/1024,y*dy/1024)。LED的位置放在屏幕中间最好,放在边缘也不差。如果给定人所站位置及屏幕大小等数据,那么可以得到精确的打法。

方法2. 貌似是官方的2LED方法

使用2 LED。感觉跟上面的方法原理类似,由于是2LED,所以还能多识别枪的旋转方向。2LED的位置放在屏幕上方或下方中间。

参考:

wiki - wiimote/pointing

---http://www.wiibrew.org/wiki/Wiimote/Pointing

A Better Wiimote Pointer

----http://blog.dawnofthegeeks.com/?p=496

 

上面两种方法的精确度改进

上面两种方法都是不精确的,没有定位过程和关于屏幕分辨率的设置。为了加强使用体验,我发现了一个来自http://www.davidhawley.co.uk/WiiSensorBar.aspx的文章《Make your Wiimote aim accurately and how the Wii sensor bar works with widescreen tv's》。按照里面的方法,可以通过修改人距离屏幕的距离或者LED间距离来改良精确度。最赞的是,页面里还包含了一个计算器,直接看图:

 

方法3:我的精确方法

假设1:2(不够求解就用3)个LED与屏幕处于同一个平面,令该平面为X-Y平面。

假设2枪使用总是平衡的。(如果这个不假设的话,可以多加LED或者使用枪内置的加速度传感器的数据也可以,不过暂不确定加速度传感器的精确程度)

那么要解决的问题有2个:

问题1如果枪所在点为(x,y,z)且方向为(n,m,p),那么通过这条直线的方程及平面方程Z=0就可以求得枪射在X-Y平面上的位置。

如何求x,y,z,n,m,p这6个值?有些值是可以直接固定的,例如方向不考虑大小则可以令p=1。当然,基本解决思路是用待定系数法。 系数法中的方程来源:有方向向量(n,m,p)及A,B,可以求出新的方向向量P(下面有解释)。其中A,B是枪头摄像头所获得的某LED的x,y坐标点转化得到的该LED到枪与枪所指方向的x,y轴方向的偏移角度。这样,用P和点(x,y,z)可以得到某LED的坐标值(这个已知),那么可以两个方程。

问题2通过开始对屏幕的四个角分别开一枪得到四角的X-Y坐标值,以及通过获取屏幕的分辨率,那么以后得到的X-Y坐标值就可以通过映射转换到屏幕分辨率值。如何转换,没思考下去,应该挺简单的。

当前遇到的问题是: 有方向向量(n,m,p), 给出A,B后, 如何求出新的方向向量P?

为了解释下A,B,是什么,看下面新的坐标系。

如果用这个新的坐标系来解释A、B的话。方便点,左边箭头轴是X',上箭头是Y',斜的那个是Z'。  那么向量P在Z'Y'上投影与Z'轴正方向的夹角为A,在Z'X'上投影与Z'轴正方向的夹角为B。

待续。。。

特别鸣谢:

其实1LED方法是追不了月的名字很长的火云大爷最先提出的而我在后面看到2LED方法时才决定使用的,虽然说理论上有明显的缺陷,但是实际效果还不错。另外他还提出了一个很忽悠的理论上都还不知道怎么求解的2LED方法,这里就略过了。

非常感谢小罗同学在这个问题上花费了不少时间并在最后给我指出了这个问题其实不是那么容易解决的,于是我想到下次可以试试用数值方法去求解。

关于WII光枪定位的设计(转)的更多相关文章

  1. EasyPR--开发详解(5)颜色定位与偏斜扭转

    本篇文章介绍EasyPR里新的定位功能:颜色定位与偏斜扭正.希望这篇文档可以帮助开发者与使用者更好的理解EasyPR的设计思想. 让我们先看一下示例图片,这幅图片中的车牌通过颜色的定位法进行定位并从偏 ...

  2. 游戏数值——LOL篇 以LOL为起点-说游戏数值设计核心思路

      附     文   文档在今年三月份我动笔写了一小部分,但当时思路凌乱,行文梗阻,于是丢在一边构思了半年,现在又回过头来慢慢写,希望能写好写完吧,初衷是希望即时萌新也能看懂,但是好像并不能行——本 ...

  3. 室内定位系列(一)——WiFi位置指纹(译)

    原文:<Advanced Location-Based Technologies and Services>--chapter 2 WiFi Location Fingerprint 作者 ...

  4. WebApp 设计要素

    从去年开始就负责公司WebApp的产品跟设计工作,最近整体大改了两个版本,也算累积了一些实际的经验.在不断学习的过程中,发现对于WebApp可以直接用于项目上的资料比较零碎,在这里总结一下,供初做 W ...

  5. [Architecture Design] 跨平台架构设计

    [Architecture Design] 跨平台架构设计 跨越平台 Productivity Future Vision 2011 在开始谈跨平台架构设计之前,请大家先看看上面这段影片,影片内容是微 ...

  6. 几种MEMS陀螺仪(gyroscope)的设计和性能比较

    现在市场上的MEMS陀螺仪主要有SYSTRON.BOSCH和INVENSENSE设计和生产.前两者设计的陀螺仪属高端产品,主要用于汽车.后者的属低端产品,主要用于消费类电子,象任天堂的Wii.ADI2 ...

  7. 一步一步实现基于Task的Promise库(三)waitFor方法的设计

    在上一篇中我们已经完成了Task.js里面的all和any方法,已经可以完美的解决大部分需求,我们再来看一个需求: 我们要先读取aa.txt的内容,然后去后台解析,同时由用户指定一个文件,也要读取解析 ...

  8. Windows 平台 (UWP)应用设计

    Make Your Apps Cooperate with Cross-App Communication :  https://rewards.msdn.microsoft.com/Challeng ...

  9. selenium 难定位元素,时间插件,下拉框定位,string

    1.元素定位 ID定位元素: findElement(By.id(“”)); 通过元素的名称定位元素: findElement(By.name(“”)); 通过元素的html中的位置定位元素: fin ...

随机推荐

  1. 利用LibreOffice转换ppt、doc转化pdf

    利用LibreOffice转换ppt.doc转化pdf LibreOffice下载地址:  http://www.libreoffice.org/download/libreoffice-fresh/ ...

  2. Facebook Graph API 接口请求

    Graph API 调试器 这两天因项目需求,在调试FB的接口.项目的应用在FB上面.L特傻.没有区分FB的api的使用方式. 因为应用是在FB上面的.所以在登录应用的时候,就已经登录了FB平台.对于 ...

  3. NEST.net Client For Elasticsearch简单应用

    NEST.net Client For Elasticsearch简单应用 由于最近的一个项目中的搜索部分要用到 Elasticsearch 来实现搜索功能,苦于英文差及该方面的系统性资料不好找,在实 ...

  4. JFinal 源码分析 [DB+ActiveRecord]

    我记得以前有人跟我说,“面试的时候要看spring的源码,要看ioc.aop的源码"那为什么要看这些开源框架的源码呢,其实很多人都是"应急式"的去读,就像读一篇文章一下, ...

  5. 剔除数组或List中重复的元素

    import java.util.Arrays; import java.util.Collection; import java.util.HashSet; import java.util.Lis ...

  6. 自己学习编程时间比较短,现在把一下自己以前刚刚接触C++时的程序上传一下,有空可以看看

    键盘输入十个数,找出最大值和最小值. #include<iostream.h>void main (){int a[10];int i,t,max,min;cout<<&quo ...

  7. Mybatis错误调试(二)

    错误日志信息:  Caused by: java.sql.BatchUpdateException: ORA-00911: 无效字符 at oracle.jdbc.driver.OraclePrepa ...

  8. 【BZOJ】【1986】【USACO 2004 Dec】/【POJ】【2373】划区灌溉

    DP/单调队列优化 首先不考虑奶牛的喜欢区间,dp方程当然是比较显然的:$ f[i]=min(f[k])+1,i-2*b \leq k \leq i-2*a $  当然这里的$i$和$k$都是偶数啦~ ...

  9. 【BZOJ】【1406】【AHOI2007】密码箱

    数论 Orz iwtwiioi 果然数论很捉鸡>_>完全不知道怎么下手 $$x^2 \equiv 1 \pmod n \rightarrow (x+1)*(x-1)=k*n $$ 所以,我 ...

  10. 【BZOJ】【3504】【CQOI2014】危桥

    网络流/最大流 比较裸的最大流= = 无向图上走来回其实就等价与走两遍>_> 如果路径有相交其实不影响答案的 比较恶心的是两个人路过同一座桥,但走的方向不同互相抵消流量了…… 其实只要在第 ...