• <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>

            Benjamin

            靜以修身,儉以養(yǎng)德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 397, 文章 - 0, 評論 - 196, 引用 - 0
            數(shù)據(jù)加載中……

            WM5.0下如何獲取基站信息(LAC、Cellid)

            在WM5.0下獲得CELLID、LAC的途徑有兩條:利用串口發(fā)送AT指令或是利用RIL來獲取。RIL(Radio Interface Layer)是微軟自己開發(fā)的一個庫,它的程序有固有的特點,在獲取CELLID上,它其實是對第一種方法的封裝,兩者本質(zhì)是一樣的。但要注意是:串口一旦打開,就難以關(guān)閉,除非重啟機器(可能涉及到底層的中斷),另外并不是所有的設(shè)備都可以取到CELLID。
            下面的這段代碼就是利用COM口來獲取CELLID,并不保證所有的設(shè)備都支持。

            typedef struct
            {
             char c[12];
             char    iLac[4];
             char s[4];
             char iId[4];
            } TCREG_DATA;

            void Get_Cellid(void)
            {
             char m_sTemp[12] = {0};
             strcat(m_sTemp,"COM");
             for(int i = 9; i > 0; -- i)
             {
              char ch1;
              _itoa(i,&ch1,10);
              strcat(m_sTemp,&ch1);
              strcat(m_sTemp,":");

              TCREG_DATA* pData = (TCREG_DATA*)GetCREG(m_sTemp);
              if(!pData)
               continue;

              char szNum1[8] = {0};
              char szNum2[8] = {0};

              strcpy(szNum1,pData->iLac);
              strcpy(szNum2,pData->iId);

              int iLac = (int)strtol(szNum1,NULL,16);
              int iId  = (int)strtol(szNum2,NULL,16);

              if (iLac && iId)
              {
               sprintf(m_sCell.LAC,"%06d",iLac);
               sprintf(m_sCell.ID,"%06d",iId);
               break;
              }
             }
            }
            char* GetCREG( char * comPort )
            {
             HANDLE hCom;
             int bufpos;
             DCB dcb;
             COMMTIMEOUTS to;
             DWORD nWritten;
             DWORD event;
             DWORD nRead;
             static char outbuf[20], buf[256];

             BYTE comdevcmd[2]= {0x84, 0x00};
             WCHAR m_sCom[12] = {0};
             mbstowcs(m_sCom,comPort,strlen(comPort));

             hCom= CreateFile( m_sCom ,GENERIC_READ|GENERIC_WRITE,0,0,OPEN_EXISTING,0,0);

             if (hCom==NULL || hCom==INVALID_HANDLE_VALUE)
             {
              hCom= NULL;
              return NULL;
             }

             if (!GetCommState(hCom, &dcb))
             {
              return "ERROR:GetCommState Failed";
             }

             dcb.BaudRate= CBR_115200;
             dcb.ByteSize= 8;
             dcb.fParity= false;
             dcb.StopBits= ONESTOPBIT;

             if (!SetCommState(hCom, &dcb))
             {
              return "ERROR:SetCommState Failed";
             }

             EscapeCommFunction(hCom, SETDTR);
             EscapeCommFunction(hCom, SETRTS);
             GetCommTimeouts(hCom, &to);
             //if (!EscapeCommFunction(hCom, SETDTR))
             //{
             //  return "-4";
             //}
             //if (!EscapeCommFunction(hCom, SETRTS))
             //{
             //  return "-5";
             //}   
             //if (!GetCommTimeouts(hCom, &to))
             //{
             //  return "-6";
             //}

             to.ReadIntervalTimeout= 0;
             to.ReadTotalTimeoutConstant= 200;
             to.ReadTotalTimeoutMultiplier= 0;
             to.WriteTotalTimeoutConstant= 20000;
             to.WriteTotalTimeoutMultiplier= 0;

             SetCommTimeouts(hCom, &to);
             //if (!SetCommTimeouts(hCom, &to))
             //{
             //  return "-7";
             //}

             if (!SetCommMask(hCom, EV_RXCHAR))
             {
              return "-8";
             }

             DWORD rildevresult=0,nReturned=0;


             if (!DeviceIoControl (hCom,0xAAAA5679L, comdevcmd, sizeof(comdevcmd),0,0,0,0))
             {
              return "-9";
             }

             bufpos = 0;

             strcpy(outbuf,"AT+creg=2\r");

             if (!WriteFile(hCom, outbuf, 10, &nWritten, NULL))   
             {
              return "-10";
             }

             if (nWritten != 10)
             {
              return "-11";
             }

             if (!WaitCommEvent(hCom, &event, NULL))
             {
              return "-12";
             }

             while(1)
             {
              if (!ReadFile(hCom, buf+bufpos, 256 - bufpos, &nRead, NULL))
              {
               return "-13";
              }

              if (nRead == 0)
               break;

              bufpos += nRead;


              if (bufpos >= 256)
               break;
             }

             strcpy(outbuf,"AT+creg?\r");

             if (!WriteFile(hCom, outbuf, 9, &nWritten, NULL))   
             {
              return "-14";
             }

             if (nWritten != 9)
             {
              return "-15";
             }

             if (!WaitCommEvent(hCom, &event, NULL))
             {
              return "-16";
             }

             while(1)
             {
              if (!ReadFile(hCom, buf+bufpos, 256 - bufpos, &nRead, NULL))
              {
               return "-17";
              }

              if (nRead == 0)
               break;

              bufpos += nRead;

              if (bufpos >= 256)
               break;
             }

             puts(buf);

             rildevresult = 0; 

             if (!EscapeCommFunction(hCom, CLRDTR))
             {
              return "-4";
             }

             if (hCom!=NULL)
             {
              CloseHandle(hCom);
              hCom= NULL;
             }

             char* cregResponse = strpbrk( buf, "CREG\0" );

             return cregResponse;
            }

            void Get_Cellid(void)
            {
             char m_sTemp[12] = {0};
             strcat(m_sTemp,"COM");
             for(int i = 9; i > 0; -- i)
             {
              char ch1;
              _itoa(i,&ch1,10);
              strcat(m_sTemp,&ch1);
              strcat(m_sTemp,":");

              TCREG_DATA* pData = (TCREG_DATA*)GetCREG(m_sTemp);
              if(!pData)
               continue;

              char szNum1[8] = {0};
              char szNum2[8] = {0};

              strcpy(szNum1,pData->iLac);
              strcpy(szNum2,pData->iId);

              int iLac = (int)strtol(szNum1,NULL,16);
              int iId  = (int)strtol(szNum2,NULL,16);

              if (iLac && iId)
              {
               sprintf(m_sCell.LAC,"%06d",iLac);
               sprintf(m_sCell.ID,"%06d",iId);
               break;
              }
             }
            }

            posted on 2009-02-04 22:48 Benjamin 閱讀(3799) 評論(5)  編輯 收藏 引用 所屬分類: PDA/PPC開發(fā)

            評論

            # re: WM5.0下如何獲取基站信息(LAC、Cellid)  回復(fù)  更多評論   

            你好,我不太懂手機內(nèi)部AT發(fā)送與接收流程。兩個模塊間的虛擬串口如何操作,如果獲取后對串口操作會有什么影響嗎?在windows mobile中不是一啟動ril就占用串口嗎?
            2009-08-11 09:58 | dane

            # re: WM5.0下如何獲取基站信息(LAC、Cellid)  回復(fù)  更多評論   

            獲取后串口的關(guān)閉是個難題,即使用了關(guān)閉了句柄也無濟于事,好像必須要重啟機器。如果獲取失敗,有的機器會死機,所以建議用RIL來獲取,RIL封裝的比較好,其底層實現(xiàn)和上述代碼機制是一樣。
            另外在每種型號的機器上,能使用的串口也不一樣,在注冊表中有些串口是不能用的,系統(tǒng)分配好的,但是每種機器都不同。
            模擬串口用軟件可以實現(xiàn),具體的可以在網(wǎng)上搜搜。
            2009-08-12 21:29 | Benjamin

            # re: WM5.0下如何獲取基站信息(LAC、Cellid)  回復(fù)  更多評論   

            @Benjamin
            你寫的這個程序是通過電腦發(fā)送到手機的嗎?
            我想知道如何獲取發(fā)送AT指令的串口;
            我通過程序獲取的都是我配置的一些串口;
            我使用的是仿真器,和真機在獲取串口時用什么區(qū)別嗎?
            那你知道如何獲取TXpower,相鄰小區(qū)的信息,c1,c2等信息嗎?
            2009-08-24 13:39 | dane

            # re: WM5.0下如何獲取基站信息(LAC、Cellid)  回復(fù)  更多評論   

            程序是直接運行在手機上,這個串口當時我是一個個的試的,在注冊表中沒找到。模擬器上我沒試過,應(yīng)該獲取不了吧。
            至于其他的信息,建議你在網(wǎng)上搜搜AT指令或微軟的RIL庫。
            2009-08-26 21:30 | Benjamin

            # re: WM5.0下如何獲取基站信息(LAC、Cellid)  回復(fù)  更多評論   

            你是用的是WM5.0?那不是當啟動啟動時device.exe加載了RIL Driver占用了能夠發(fā)送AT指令的串口。我試遍了所有的串口就是不能發(fā)送AT指令,有的不能打開,有的發(fā)送過去沒有反應(yīng)。。不知道問什么。網(wǎng)上的資料就是WM手機啟動時就占用了與通信模塊發(fā)送AT的串口所以不能做到。你是怎么解釋的。
            2009-10-21 14:08 | dane
            99久久国产亚洲综合精品| 久久99国产精品久久99果冻传媒| 久久er国产精品免费观看2| 久久久精品人妻一区二区三区蜜桃| 国产 亚洲 欧美 另类 久久| 91精品国产91久久久久福利| 97精品伊人久久大香线蕉app | 国产精品99久久久精品无码| 亚洲第一永久AV网站久久精品男人的天堂AV| 久久国产精品一区二区| 精品国产一区二区三区久久| 久久综合九色综合欧美狠狠| 国产成人久久精品麻豆一区 | 狠狠色丁香久久综合五月| 久久九九全国免费| 精品水蜜桃久久久久久久| 久久久精品人妻无码专区不卡 | 亚洲国产日韩欧美综合久久| 偷窥少妇久久久久久久久| 伊人久久大香线蕉av不卡| 精品无码久久久久国产| 欧美精品一本久久男人的天堂| 精品久久久久久无码人妻热| 久久综合鬼色88久久精品综合自在自线噜噜 | 欧美一区二区精品久久| 久久久网中文字幕| 狠狠综合久久综合88亚洲| 国产三级久久久精品麻豆三级| 精品久久综合1区2区3区激情| 日韩精品无码久久一区二区三| 一本色道久久88精品综合| 久久精品一区二区| 国产免费久久精品99re丫y| 久久精品男人影院| 亚洲综合伊人久久大杳蕉| 国产成人久久精品区一区二区| 亚洲а∨天堂久久精品| 国产一区二区三区久久| 久久亚洲精品国产精品婷婷| 中文字幕亚洲综合久久2| 国内精品久久久久久久久电影网|