• <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 迷宮の未來 閱讀(4089) 評論(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是重力加速好不  回復  更多評論   

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿(10)

            隨筆檔案

            文章檔案

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲成人精品久久| 国产精品狼人久久久久影院 | 久久香综合精品久久伊人| 久久精品综合一区二区三区| 欧美伊人久久大香线蕉综合| 久久久久亚洲av无码专区导航| 国产精品久久久久久一区二区三区 | 国产L精品国产亚洲区久久| 日韩欧美亚洲综合久久影院Ds | 亚洲午夜久久久久久噜噜噜| 亚洲精品高清久久| 青青草原综合久久大伊人| 国产人久久人人人人爽| 午夜视频久久久久一区| 久久精品国产亚洲av水果派| 久久综合九色综合久99| 国产V亚洲V天堂无码久久久| 久久久久久午夜精品| 精品久久久久久久久久中文字幕 | 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 97精品国产97久久久久久免费| 香蕉久久av一区二区三区| 亚洲精品国精品久久99热| 九九久久99综合一区二区| 亚洲中文久久精品无码| 婷婷久久精品国产| 久久久久亚洲av毛片大| 国产精品狼人久久久久影院 | 免费观看成人久久网免费观看| 亚洲av成人无码久久精品| 久久亚洲精品成人无码网站| 久久福利片| 久久久精品久久久久久| 国产真实乱对白精彩久久| 久久久久国产一级毛片高清版| 国产精品99久久久久久人| 久久99国产亚洲高清观看首页| 97精品国产91久久久久久| 国产成人精品久久二区二区 | 一本久久综合亚洲鲁鲁五月天| 久久人妻少妇嫩草AV无码蜜桃|