• <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 閱讀(3800) 評論(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
            久久99精品国产一区二区三区| 亚洲成色www久久网站夜月| 99国产欧美久久久精品蜜芽| 久久国产精品无码HDAV | 久久人人爽人人爽人人片AV不| 日韩久久无码免费毛片软件 | 久久久久成人精品无码 | 久久精品国产亚洲一区二区| 久久精品国产精品亚洲| 国内精品久久久久久久久电影网| 狠狠久久亚洲欧美专区| 久久人人爽人人人人爽AV| 久久久国产精品福利免费| 精品久久久久久无码不卡| 久久91精品久久91综合| 奇米影视7777久久精品人人爽| 久久99精品久久久久久久不卡| 欧美亚洲另类久久综合婷婷| 国产成人精品久久免费动漫 | 天天影视色香欲综合久久| 国产午夜福利精品久久2021| 久久AAAA片一区二区| 精品人妻久久久久久888| 色老头网站久久网| 精品久久久久久国产牛牛app| 日韩av无码久久精品免费| 思思久久99热只有频精品66| 久久精品中文字幕有码| 2021国产成人精品久久| 成人久久久观看免费毛片| 国产精品女同久久久久电影院| 久久午夜无码鲁丝片秋霞| 一本综合久久国产二区| 久久精品国产亚洲av瑜伽| 99久久国产亚洲高清观看2024 | 嫩草伊人久久精品少妇AV| 久久天天躁狠狠躁夜夜avapp| 久久精品免费网站网| 久久播电影网| 亚洲国产精品无码久久九九 | 久久精品综合网|