• <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)德,非澹薄無以明志,非寧靜無以致遠(yuǎn)。
            隨筆 - 397, 文章 - 0, 評(píng)論 - 196, 引用 - 0
            數(shù)據(jù)加載中……

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

            在WM5.0下獲得CELLID、LAC的途徑有兩條:利用串口發(fā)送AT指令或是利用RIL來獲取。RIL(Radio Interface Layer)是微軟自己開發(fā)的一個(gè)庫,它的程序有固有的特點(diǎn),在獲取CELLID上,它其實(shí)是對(duì)第一種方法的封裝,兩者本質(zhì)是一樣的。但要注意是:串口一旦打開,就難以關(guān)閉,除非重啟機(jī)器(可能涉及到底層的中斷),另外并不是所有的設(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 閱讀(3798) 評(píng)論(5)  編輯 收藏 引用 所屬分類: PDA/PPC開發(fā)

            評(píng)論

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

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

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

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

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

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

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

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

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

            你是用的是WM5.0?那不是當(dāng)啟動(dòng)啟動(dòng)時(shí)device.exe加載了RIL Driver占用了能夠發(fā)送AT指令的串口。我試遍了所有的串口就是不能發(fā)送AT指令,有的不能打開,有的發(fā)送過去沒有反應(yīng)。。不知道問什么。網(wǎng)上的資料就是WM手機(jī)啟動(dòng)時(shí)就占用了與通信模塊發(fā)送AT的串口所以不能做到。你是怎么解釋的。
            2009-10-21 14:08 | dane
            久久91亚洲人成电影网站| 人妻中文久久久久| 国产 亚洲 欧美 另类 久久| 久久精品无码免费不卡| 久久人人爽人人爽人人片av麻烦| 日韩精品久久无码中文字幕| 99久久精品免费看国产| 久久久久久精品成人免费图片| 久久96国产精品久久久| 国产精品美女久久福利网站| 色综合久久天天综合| 亚洲香蕉网久久综合影视| 久久久久久青草大香综合精品| 久久天天躁狠狠躁夜夜躁2O2O| 久久久久亚洲AV成人网人人网站 | 国产精品久久免费| 久久热这里只有精品在线观看| 国产精品免费久久久久久久久| 久久婷婷五月综合97色| 久久天天躁狠狠躁夜夜不卡| 久久免费观看视频| 亚洲国产成人久久综合碰碰动漫3d| 久久国产免费直播| 久久久久久久女国产乱让韩| 久久久久女教师免费一区| 久久精品国产亚洲AV无码偷窥| 久久精品国产日本波多野结衣| 欧美久久一区二区三区| 精品国产乱码久久久久久浪潮| 精品久久久久香蕉网| 国产偷久久久精品专区 | 亚洲一级Av无码毛片久久精品| 99国产精品久久久久久久成人热| 亚洲精品乱码久久久久66| 久久AV无码精品人妻糸列| 性做久久久久久免费观看| 久久精品亚洲欧美日韩久久| 国产综合成人久久大片91| 国产午夜精品久久久久九九电影| 94久久国产乱子伦精品免费| 秋霞久久国产精品电影院|