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

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

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

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

            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開發

            評論

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

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

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

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

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

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

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

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

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

            你是用的是WM5.0?那不是當啟動啟動時device.exe加載了RIL Driver占用了能夠發送AT指令的串口。我試遍了所有的串口就是不能發送AT指令,有的不能打開,有的發送過去沒有反應。。不知道問什么。網上的資料就是WM手機啟動時就占用了與通信模塊發送AT的串口所以不能做到。你是怎么解釋的。
            2009-10-21 14:08 | dane
            久久涩综合| 久久亚洲国产成人精品无码区| 亚洲精品乱码久久久久久中文字幕 | 亚洲国产成人久久一区久久| 一本色道久久88精品综合| 婷婷综合久久狠狠色99h| 亚洲精品乱码久久久久久蜜桃 | 久久99精品久久久久久久久久| 国产成人久久精品二区三区| 久久午夜免费视频| 久久国产成人精品麻豆| 四虎国产精品成人免费久久| 国产精品久久久久9999| 久久人人爽人人爽人人片AV麻烦| 99久久精品免费看国产一区二区三区| 精品熟女少妇AV免费久久| 国产精品99久久久久久宅男| 狠狠色丁香久久婷婷综合五月 | 久久久免费精品re6| 色综合久久88色综合天天 | 天天综合久久久网| 国产精品久久久久久吹潮| 国内精品人妻无码久久久影院导航| 精品久久久久久久中文字幕| 久久久噜噜噜久久中文福利| 97精品国产97久久久久久免费| 欧美亚洲日本久久精品| 久久99精品国产麻豆蜜芽| 亚洲午夜精品久久久久久人妖| 久久精品国产精品青草| 99久久国产综合精品麻豆| 97久久超碰国产精品旧版| 久久精品九九亚洲精品| 亚洲AV无码成人网站久久精品大| 一本一本久久a久久综合精品蜜桃| 久久久久人妻一区二区三区| 久久久久久午夜精品| 亚洲av日韩精品久久久久久a| 久久综合噜噜激激的五月天| 久久久久亚洲AV无码永不| 99久久精品国产高清一区二区 |