• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            GSensor的角度計算

               目前負責關于GSensor的模式識別,這里貼出自己的研究成果,供自己備忘。
            ACCEL_DIRECTION CGSensorModule::CalDirection(smb380acc_t& a_xyz,const unsigned char nAccelRange, double* pdbAngle)
            {
                ACCEL_DIRECTION adNew 
            = AD_UNKNOWN;
                
            double dbAngle = 0;
                
            // expressions: tan(angle) = a_xyz.x / a_xyz.y
                
            // angle is start from AD_LAYRIGHT

                
            // notice:    1. a_xyz.x and a_xyz.y should not be small together, so we need to give a liminal value
                
            //            2. the a_xyz.z should be enough small to ensure the G-Sensor is vertical,
                
            //                the degree is 45, means abs(a_xyz.z) should not larger than nAccelRange*sin(45)
                if((abs(a_xyz.x) < nAccelRange/10
                    
            && (abs(a_xyz.y) < nAccelRange/10)
                    
            || abs(a_xyz.z) > (nAccelRange*0.707))
                
            {
                    dbAngle 
            = nAccelRange;
                    
            return AD_UNKNOWN;
                }


                
            float fTanValue = float(a_xyz.y)/float(a_xyz.x);
                dbAngle 
            = atan(fTanValue);
                
            // AD_LAYRIGHT or AD_LAYLEFT
                if(fTanValue>-1 && fTanValue<1)
                
            {
                    
            if(a_xyz.x>0)
                    
            {
                        adNew 
            = AD_LAYRIGHT;
                    }

                    
            else
                    
            {
                        dbAngle 
            += PI;
                        adNew 
            = AD_LAYLEFT;
                    }

                }

                
            else
                
            {
                    
            if(a_xyz.y>0)
                    
            {
                        
            if (dbAngle<0)
                            dbAngle 
            += PI;
                        adNew 
            = AD_LAYUP;
                    }

                    
            else
                    
            {
                        
            if (dbAngle>0)
                            dbAngle 
            -= PI;
                        adNew 
            = AD_LAYDOWN;
                    }

                }


                
            if(dbAngle<0)
                    dbAngle
            +=(PI*2);

                
            if(pdbAngle != NULL)
                    
            *pdbAngle = dbAngle;
                
            return adNew;
            }


            BOOL CGSensorModule::GetDirection(ACCEL_DIRECTION
            & adNew, double* pdbAngle)
            {
                CHECK_GSENSOR_HANDLE();
                smb380acc_t a_xyz;
                unsigned 
            char nRange;
                
            if(!GetAccelXYZT(a_xyz))
                
            {
                    
            return FALSE;
                }

                
            if(!GetRange(nRange))
                
            {
                    
            return FALSE;
                }

                adNew 
            = CalDirection(a_xyz,MAX_ACCELRANGE/(2<<nRange),pdbAngle);
                
            return TRUE;
            }

            posted on 2008-05-26 11:37 迷宮の未來 閱讀(4039) 評論(4)  編輯 收藏 引用

            評論

            # re: GSensor的角度計算 2009-01-08 14:04 elle

            G-Sensor的型號是多少?  回復  更多評論   

            # re: GSensor的角度計算 2009-04-13 09:23 游客

            學習了  回復  更多評論   

            # re: GSensor的角度計算 2009-06-10 11:02 ytm

            有點看不懂  回復  更多評論   

            # re: GSensor的角度計算 2009-06-29 09:42 調試gsensor

            GSENSOR是重力加速好不  回復  更多評論   

            <2008年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            常用鏈接

            留言簿(10)

            隨筆檔案

            文章檔案

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            91性高湖久久久久| 99精品国产在热久久无毒不卡| 夜夜亚洲天天久久| 蜜桃麻豆www久久国产精品| 怡红院日本一道日本久久| 国产精品成人久久久久三级午夜电影 | 2020最新久久久视精品爱| 久久无码精品一区二区三区| 久久久国产精华液| 91久久成人免费| 无码伊人66久久大杳蕉网站谷歌 | 久久夜色精品国产亚洲| 狠狠色丁香婷婷综合久久来来去| 久久人人爽人人爽人人片av麻烦| 久久久久免费看成人影片| 四虎久久影院| 66精品综合久久久久久久| 亚洲AV无码久久精品狠狠爱浪潮| 99久久夜色精品国产网站| 精品综合久久久久久888蜜芽| 久久影院午夜理论片无码| 久久最近最新中文字幕大全| 久久久久亚洲精品天堂| 亚洲va久久久噜噜噜久久| 久久久免费观成人影院| 久久这里只精品国产99热| 亚洲欧美日韩中文久久| 久久精品人人做人人妻人人玩| 亚洲精品白浆高清久久久久久| 国产精品欧美久久久久无广告| 男女久久久国产一区二区三区 | 色综合色天天久久婷婷基地| 亚洲中文字幕无码久久综合网| 欧美午夜A∨大片久久 | 亚洲色大成网站www久久九| 亚洲国产成人久久一区WWW| yellow中文字幕久久网| 国产精品久久免费| 欧美精品一区二区精品久久| 久久99国产精品一区二区| 久久精品成人免费看|