• <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
            久久成人国产精品免费软件| 久久人妻少妇嫩草AV无码蜜桃| 2021国产精品午夜久久| 狠狠色丁香久久婷婷综合图片| 亚洲va久久久噜噜噜久久狠狠| 人妻精品久久无码区| 久久国产免费观看精品| 久久av高潮av无码av喷吹| 久久久久久噜噜精品免费直播| 亚洲国产日韩欧美久久| 久久国产精品成人片免费| 久久久久久亚洲精品不卡 | 久久久久久久久久久久中文字幕| 久久国产热精品波多野结衣AV| 国内精品久久久久国产盗摄| 久久免费的精品国产V∧| 国产精品热久久无码av| 亚洲狠狠婷婷综合久久久久| 无码任你躁久久久久久久| 久久精品一本到99热免费| 久久综合九色欧美综合狠狠 | 91精品国产综合久久香蕉| 日本国产精品久久| 久久99国产精一区二区三区| 伊人久久大香线蕉AV色婷婷色 | 狠狠色婷婷久久综合频道日韩 | 久久91精品综合国产首页| 久久九九精品99国产精品| 欧美无乱码久久久免费午夜一区二区三区中文字幕| 一本色道久久88综合日韩精品| 一级做a爰片久久毛片16| 精品少妇人妻av无码久久| 97香蕉久久夜色精品国产| 久久强奷乱码老熟女| 久久国产综合精品五月天| 7国产欧美日韩综合天堂中文久久久久 | 久久永久免费人妻精品下载| 伊人久久大香线蕉综合Av| 久久精品日日躁夜夜躁欧美| 国产精品久久新婚兰兰| 久久久久人妻一区二区三区 |