亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統(tǒng) > Android > 正文

跨平臺移動WEB應用開發(fā)框架iMAG入門教程

2020-04-11 11:49:08
字體:
來源:轉載
供稿:網(wǎng)友

iMAG是一個非常簡潔高效的移動跨平臺開發(fā)框架,開發(fā)一次可以同時兼容Android和iOS平臺,有點兒Web開發(fā)基礎就能很快上手。當前移動端跨平臺開發(fā)的框架有很多,但用iMAG還有一個好處,就是用iMAG開發(fā)出的App是原生的。iMAG采用XML + JavaScript(配置 + 腳本)的開發(fā)方式,它的原理是將符合iMAG開發(fā)規(guī)范的XML文件解釋成對應的原生應用代碼來執(zhí)行。原生跨平臺開發(fā),iMAG App具有和Native App相同的性能和用戶體驗,因此相比PhoneGap、JQuery Mobile等Web開發(fā)框架iMAG適用于對性能要求較高的情況。

雖然是原生又跨平臺,iMAG的開發(fā)環(huán)境卻很簡單,不需要在本地電腦上安裝或部署,在iMAG的官網(wǎng)平臺注冊一個免費帳號,馬上就可以開始開發(fā)了。注冊完登錄,安裝網(wǎng)站提示先在手機上安裝iMAG開發(fā)版的客戶端,然后打開iMAG的在線開發(fā)工具開始開發(fā)。


登錄iMAG開發(fā)版客戶端,在iMAG在線開發(fā)工具里編輯XML文件并保存,在手機上刷新頁面就能看到效果。

Hello World

下面來看這個hello world的例子。iMAG框架使用的XML格式的文件來描述UI,因此代碼必須符合XML格式的規(guī)范,一套代碼在Android和iOS平臺都能運行,而且展現(xiàn)出來的是原生UI效果。


<?xml version="1.0" encoding="utf-8"?><imag>  <page>    <title style="background:#6495ED">      <center><label>測試App</label></center>    </title>    <content>      <list type="group">        <item>          <label>Hello World!</label>        </item>      </list>    </content>  </page></imag>

其中<imag>是XML文檔的根節(jié)點,<page>包含整個頁面的內容,是對頁面的抽象和封裝。上面的代碼中<page>包括<title>和<content>兩個部分,分別是頁面的標題和內容。<title>是頁面標題導航欄,有<center>、<left>、<right>三個子節(jié)點,分別用來在title上居中、居左和居右來擺放文本和按鈕。<content>里有個<list>控件,用來展示“Hello World!”文本內容,list的type屬性是"group",表示是一個分組列表。

iMAG在Android和iOS系統(tǒng)上會將XML解釋成各自的本地代碼,比如在Android上<label>會解釋成原生的TextView,而在iOS上則會解釋成對應的UILabel。因此不同于HTML,在iMAG框架里文本內容只能在放在label標簽里,而不能任意放置。

基本頁面布局

單個頁面通常由title, header, content, footer組成:

<?xml version="1.0" encoding="utf-8"?>  <imag>    <page>      <title style="background:#999999">        <center><label>標題</label></center>      </title>      <header style="background:#cccccc;padding:10">        <label>置頂</label>      </header>      <content style="background:white">        <label>內容</label>      </content>      <footer style="background:#cccccc;padding:10">        <label>置底</label>      </footer>    </page>  </imag>  

<header>中的內容會始終顯示在屏幕上頂部,<content>是頁面的主要內容,<footer>的內容在屏幕中置底顯示。

列表布局

通常頁面內容的布局可以通過列表控件list來實現(xiàn),如下面的例子:

其中<item>是列表項,每個item的都可以有自己的布局,在<item>中,<col>表示一列,<row>表示一行。這里list有點兒類似于HTML里的table,不同的是table是先有行(tr)再有列(td),而list是先有列(col)再有行(row)。col-width樣式用來設置多列的跨度,多個用逗號“,”分割,星號“*”表示寬度自適應。

用list控件可以實現(xiàn)更復雜和細致的布局效果,下面是用iMAG框架開發(fā)的微博App頁面:

UI控件分類

UI控件分類iMAG框架的UI控件可以分為三類:內容控件、表單控件、布局控件。
內容控件:用來展示文字、圖片等內容信息。
表單控件:用來接收用戶輸入的表單信息。
布局控件:用來控制頁面內容的布局和擺放。

iMAG框架的UI控件列表:

分類 名稱 標簽 描述
內容控件 文本控件 label 用來顯示文本內容
網(wǎng)頁控件 web 用來顯示網(wǎng)頁內容
按鈕控件 button 用來顯示按鈕
圖標控件 icon 用來顯示資源圖片或手機本地圖片
圖片控件 image 用來顯示網(wǎng)絡圖片
圖組控件 slideimage 用來顯示一組圖片
進度條控件 progress 用來顯示進度條
日歷控件 calendar 用來顯示日歷,可以用于開發(fā)日程管理功能
地圖控件 bmap 用來顯示地圖,可以在地圖上標注地理位置信息。
表單控件 表單控件 form 用來表示表單,表單項都包含在form標簽內
隱藏域控件 input-hidden 用來表示表單隱藏域
文本輸入框控件 input-text 用來輸入單行文本內容
密碼輸入框控件 input-password 用來輸入密碼
數(shù)字輸入框控件 input-number 用來輸入數(shù)字
郵件地址輸入框控件 input-email 用來輸入郵件地址
日期輸入框控件 input-date 用來輸入日期
時間輸入框控件 input-time 用來輸入時間
搜索框控件 input-search 用來輸入搜索內容
文件選擇框控件 input-file 用來選擇文件
表單提交按鈕 input-submit 用來點擊提交表單
文本域控件 textarea 用來輸入多行文本
單選框控件 select 用來選取單個值
單選按鈕控件 radio 用來選取單個值
單選按鈕組控件 radios 用來選取單個值
多選按鈕控件 checkbox 用來選取多個值
表單驗證控件 validation 用來驗證表單數(shù)據(jù)
布局控件 頁面控件 page 包含當前頁面的所有內容
標題控件 title 用來顯示頁面標題欄
置頂控件 header 內容在屏幕上置頂
置底控件 footer 內容在屏幕上置底
內容控件 content 包含頁面的內容部分
內容組控件 contents 多個content的組
標簽欄控件 tabbar 標簽欄主要用于content內容的切換
標簽頁控件 tabs 以標簽頁的形式來顯示內容
單行控件 row 用來顯示一行控件內容
列表控件 list 以列表的形式來顯示內容
網(wǎng)格控件 grid 以網(wǎng)格的形式來顯示內容
多屏幕控件 screens 以多個屏幕的形式來顯示內容
系統(tǒng)菜單控件 menu 用來顯示系統(tǒng)菜單
彈出菜單控件 actionmenu 用來顯示彈出菜單
導航菜單控件 navmenu 用來顯示導航菜單
彈跳菜單控件 pathmenu 用來顯示彈跳菜單
側滑菜單控件 slidingmenu 用來顯示側滑菜單

動態(tài)腳本

iMAG框架支持通過標準的Javascript語言來操作UI控件對象,完成動態(tài)交互功能,比如:

<?xml version="1.0" encoding="utf-8"?><imag> <script> <![CDATA[  $page.onload = function() {    alert('hello world!');  } ]]> </script> <page> </page></imag>

上面的代碼會在頁面初始化時觸發(fā)onload事件,調用JavaScript方法彈出一個alert對話框。

這里有必要解釋一下Javascript的概念,完整的JavaScript實現(xiàn)是由以下3個不同部分組成的:核心(ECMAScript)、文檔對象模型(Document Object Model,簡稱DOM)、瀏覽器對象模型(Browser Object Model,簡稱BOM)。對于iMAG而言實際上只用到了ECMAScript,因為iMAG并不支持DOM和BOM。這是因為移動UI往往頁面簡潔元素較少,沒有必要引入復雜的DOM操作,而且DOM API本身設計糟糕,對開發(fā)人員不夠友好。而BOM里的Window, Navigator, History這些對象對于移動應用也不再適用,iMAG有自己的MOM(Mobile Object Model)。

 iMAG中定義的MOM對象:

● $page:封裝了頁面UI相關的屬性和方法。
● $http:封裝了http操作相關的方法。
● $phone:封裝了手機本地功能調用相關的方法。
● $util:封裝了一些實用工具方法。

通過這些內置的JavaScript對象和方法,iMAG框架可以輕松調用手機本地功能,比如GPS定位。

$phone.locate({  provider: 'gps',  success: function(location) {    alert('GPS定位成功,經(jīng)緯度:' + location.latitude + ', ' + location.longitude);  },  error: function() {    alert('GPS定位失?。?);  }});

上面的$phone.locate()方法會啟動手機GPS定位功能,定位成功之后回調success方法,顯示出經(jīng)緯度信息。

iMAG框架支持動態(tài)創(chuàng)建UI控件,要用到$C()方法,參數(shù)是XML格式的文檔,如:

復制代碼 代碼如下:

var button = $C('<button id="test_button">按鈕</button>');
$('content').add(button);

上面的方法通過XML動態(tài)創(chuàng)建了一個button控件,并在頁面的content里顯示。

iMAG框架還可以使用Ajax請求來獲取數(shù)據(jù),如:

復制代碼 代碼如下:

$http.get('//www.49028c.com/download/data/http_json_ret.jsp', function(json) {
    var obj = JSON.parse(json);
    $('test_label').text = obj.text;
});

$http.get()方法會發(fā)起一個異步調用的Ajax請求,服務器返回的JSON數(shù)據(jù)格式如下:
復制代碼 代碼如下:

{text:'<font color="blue">JSON數(shù)據(jù)</font>'}

從服務器端動態(tài)獲取的JSON數(shù)據(jù)用JSON.parse()方法解析,然后進行處理和顯示。因為iMAG底層是原生代碼非瀏覽器環(huán)境,因此在iMAG框架里調用Ajax請求沒有跨域問題。

使用HMTL5

雖然使用HTML5不是iMAG開發(fā)所必須的,但iMAG通過web控件的方式對HTML5進行了很好的支持和兼容,并且提供了腳本機制使得web可以同原生控件進行內外交互相互調用,這在開發(fā)網(wǎng)站類應用的時候會比較有用。

使用Web控件顯示HTML網(wǎng)頁的例子:

<?xml version="1.0" encoding="utf-8"?><imag>  <page style="background:white">    <title>      <center>        <label>網(wǎng)頁控件</label>      </center>    </title>    <content>		<web>		<![CDATA[		 <style type="text/css">		 table.altrowstable {		   font-family: verdana,arial,sans-serif;		   font-size:11px;		   color:#333333;		   border-width: 1px;		   border-color: #a9c6c9;		   border-collapse: collapse;		 }		  		 table.altrowstable th {		   border-width: 1px;		   padding: 8px;		   border-style: solid;		   border-color: #a9c6c9;		 }		  		 table.altrowstable td {		   border-width: 1px;		   padding: 8px;		   border-style: solid;		   border-color: #a9c6c9;		 }		  		 .oddrowcolor {		   background-color:#d4e3e5;		 }		  		 .evenrowcolor {		   background-color:#c3dde0;		 }		 </style>		 <table class="altrowstable" id="alternatecolor">		   <tr class="evenrowcolor">		     <th>Info Header 1</th><th>Info Header 2</th><th>Info Header 3</th>		   </tr>		   <tr class="oddrowcolor">		     <td<Text 1A</td><td>Text 1B</td><td>Text 1C</td>		   </tr>		   <tr class="evenrowcolor">		     <td>Text 2A</td><td>Text 2B</td><td>Text 2C</td>		   </tr>		   <tr class="oddrowcolor">		     <td<Text 3A</td><td>Text 3B</td><td>Text 3C</td>		   </tr>		   <tr class="evenrowcolor">		     <td>Text 4A</td><td>Text 4B</td><td>Text 4C</td>		   </tr>		   <tr class="oddrowcolor">		     <td>Text 5A</td><td>Text 5B</td><td>Text 5C</td>		   </tr>		 </table>		]]>		</web>    </content>  </page></imag>

這里顯示的table表格是標準的HTML,因為內嵌的是HTML標簽,所以這里必須使用CDATA來進行標記。

適配不同屏幕

iMAG已經(jīng)屏蔽了不同平臺不同分辨率手機之間的差異,按照iMAG規(guī)范開發(fā)出的移動應用自動適配不同手機。對于不同平臺不同分辨率的屏幕,也需要使用多套不同大小的圖片去適配,這些圖片只需要按照規(guī)則放到相應的服務器目錄下即可,手機客戶端會自動下載與之相適配的圖片。

服務器端圖片資源目錄結構如下:

Android圖片資源目錄是以屏幕密度(density)來區(qū)分,而iOS是以屏幕分辨率來區(qū)分。anroid和ios目錄下分別有一個default目錄,當具體屏幕分辨率或屏幕密度的圖片找不到時會讀取這個default目錄中的相應的圖片。

比如:<page>對于Android屏幕分辨率為800x480的手機bg.png圖片的目錄查找順序是:

復制代碼 代碼如下:
/res/android/hdpi
/res/android/default
/res/default

對于iPhone5手機目錄查找順序是:

復制代碼 代碼如下:
/res/ios/640x1136
/res/ios/default
/res/default

可以看到這個查找順序是由內向外的。
Android各個屏幕密度的取值如下:

密度 ldpi mdpi hdpi xhdpi xxhdpi
密度值 dip<140 140<=dip<190 190<=dip<280 280<=dip<400 400<=dip
分辨率 240x320 320x480 480x800
480x854
720x1280 1080x1920
比例 3 4 6 8 12

可以根據(jù)比例來設計各種屏幕圖片的大小:比如一個圖片在hdpi上大小為48×48,那么在xhdpi上為64x64,在xxhdpi上為96x96(6:8:12)。

打包發(fā)布

App開發(fā)完成之后就是打包和發(fā)布,打包之前要先上傳自己的應用圖標和App啟動加載圖片,因為要適配不同分辨率的手機,圖片要上傳多套。iOS打包時還要上傳證書,這樣打包出來的App才能夠上傳到AppStore。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
午夜精品久久久久久久久久久久| 亚洲一区二区免费视频| 欧美性xxxx极品hd欧美风情| 一区二区三区福利| www成人免费观看网站| 国产一区二区三区黄网站| 57pao国产一区二区| 国产在线视频在线| 在线观看免费亚洲| 国产精品久久久久久久久免费高清| a级影片在线| 男女曰b免费视频| 波多野结衣一本一道| 综合久久国产| 久久视频精品在线| 亚洲欧美中文日韩在线v日本| 一区二区三区国产豹纹内裤在线| 国内精品一区二区三区四区| 一线天粉嫩在线播放| 国产精品午夜电影| 九色porny丨国产精品| 国产又爽又黄又嫩又猛又粗| 中文字幕jux大岛优香| 一二三四国产精品| www日本高清| 成人免费淫片在线费观看| 91中文精品字幕在线视频| 久久久成人影院| 免费久久99精品国产自在现线| 亚洲欧美成人综合| 黄色a一级视频| 亚洲精品日韩综合观看成人91| 被黑人猛躁10次高潮视频| 懂色中文一区二区三区在线视频| 成人h版在线观看| 欧洲三级视频| 性xx无遮挡| 亚洲欧美二区三区| 日韩中文字幕有码| 欧美国产亚洲视频| 欧洲美女亚洲激情| 久久黄色网页| 91免费视频黄| 伊人久久中文字幕| 98精品国产高清在线xxxx天堂| 欧美黑人一区| 欧美日韩第一页| 欧美性猛片xxxx免费看久爱| 精品人妻一区二区三区视频| 中文字幕在线看高清电影| 国产精品一区二区午夜嘿嘿嘿小说| caopeng视频| 老司机午夜激情| 一区二区三区欧美在线观看| 久久成年人视频| 粉嫩老牛aⅴ一区二区三区| 亚洲欧美日韩网| 欧美hd在线| 亚洲三级在线看| 成人网站免费观看入口| 国产浮力第一页| 免费观看特级毛片| 国产精品精品久久久| 国产又黄又猛又爽| www.99久久热国产日韩欧美.com| 91女神在线视频| 日本精品在线观看视频| 777奇米成人网| 欧美v亚洲v| 精品中文字幕在线观看| 日韩中文字幕有码| 91社在线播放| 日韩av手机在线观看| 欧美日韩国产色综合一二三四| 日本午夜精品一区二区三区| 337p日本欧洲亚洲大胆精品| 国产伦精品一区二区三区免费| 在线免费观看一区| 麻豆av电影| 日本一区二区三区dvd视频在线| 欧美久久亚洲| 亚洲伊人久久大香线蕉av| 亚洲国产婷婷香蕉久久久久久| 熟女丰满老熟女熟妇| 欧美一级bbbbb性bbbb喷潮片| 亚洲综合爱爱久久网| 国语自产偷拍精品视频偷| 久久av免费看| 亚洲午夜精品久久| 午夜美女福利视频| 日本精品网站| 久久成人免费日本黄色| 五月天激情丁香| 亚洲精品久久久久久久久| 亚洲国产精品人人爽夜夜爽| 美女免费久久| 国产高清不卡无码视频| 美女搞黄视频在线观看| 国产精品麻豆99久久久久久| 中文字幕国产一区二区| 麻豆freexxxx性91精品| 西游记1978| а√天堂8资源中文在线| 欧美性生活影院| 不要播放器的av网站| 免费观看黄色一级视频| 激情婷婷丁香| 国产精品夫妻激情| 国产a级毛片一区| 国产女人18毛片水18精品| 日韩中文字幕久久久经典网| 欧美一级免费大片| 美女网站在线看| 亚洲高清av在线| 国产亚洲高清一区| 69视频免费在线观看| 国产成人av网址| 亚洲女人天堂a在线播放| 一道本无吗dⅴd在线播放一区| 欧美激情 一区| 尤物视频在线观看国产| 国产三级国产精品| 久久久久久久久久久久久久| 国产日韩一区二区三区| 亚洲手机成人高清视频| 亚洲国内精品在线| 伊人网站在线| 亚洲日本无吗高清不卡| 久久久电影免费观看完整版| 两女双腿交缠激烈磨豆腐| 综合av色偷偷网| 日韩国产一级片| 欧美黄色一级| 亚洲一级淫片| 亚洲最大成人在线观看| 国产精品1024久久| 91麻豆精品国产91久久久久推荐资源| 久久精品午夜福利| 亚洲成人999| 蜜桃日韩视频| 国产精品v欧美精品v日韩| 亚洲AV无码片久久精品| 日本三日本三级少妇三级66| 性网站在线免费观看| 久久丁香综合五月国产三级网站| 欧美一级二级在线观看| 日韩av影视| 国产精品1区在线| 亚洲第一网站在线观看| 在线视频中文字幕久| 国产成人免费在线| 性欧美大战久久久久久久久| 日韩美女福利视频| 亚洲精品在线影院| 亚洲综合日韩中文字幕v在线| 另类尿喷潮videofree| 91精品啪在线观看国产爱臀| 在线国产视频| 久久久人成影片一区二区三区| 日韩三级高清在线| 日本亚洲三级在线| 国产免费毛卡片| 日韩在线影视| 性感美女一区二区在线观看| 中文字幕久热精品视频免费| 亚洲热av色在线播放| 亚洲制服一区| 在线观看国产麻豆| 大香伊人久久精品一区二区| 国产美女精品人人做人人爽| 亚洲综合国产激情另类一区| 在线播放一区二区三区| 中文字幕一区图| 欧美图片欧美激情欧美精品| 免费国产阿v视频在线观看| 亚洲免费激情| 久久精品国产91精品亚洲| 四虎影视成人永久免费观看视频| 91福利区在线观看| 2018国产精品视频| 欧美国产视频一区二区| 日韩免费在线视频| 偷拍精品精品一区二区三区| 亚洲成人一区在线观看| av福利网址网站| 超碰中文在线| 欧美亚洲不卡| 国产精品中文久久久久久| 奇米狠狠一区二区三区| 精品久久精品久久| 亚洲国产小视频| 浮生影视网在线观看免费| 影音先锋日韩有码| 久热中文字幕| 黑人精品一区二区| 午夜成人免费视频| 自拍另类欧美| 亚洲成人二区| 欧美zozozo| 三级黄在线播放| 精品国产精品三级精品av网址| 国产精品不卡在线观看| 亚洲最大成人免费视频| 日本韩国一区二区三区视频| 视频在线观看一区二区三区| 久热国产精品视频一区二区三区| 俄罗斯男人又粗又大| 国产尤物一区二区在线| 欧美日韩综合一区二区| 国产精品无码午夜福利| 亚洲AV无码成人精品区明星换面| 亚洲精品88| 国产中文伊人| 色综合久久久| 久久精品夜色噜噜亚洲a∨| 激情懂色av一区av二区av| 波多野结衣在线观看一区二区| 婷婷国产成人精品视频| 欧美一区二区三区图| 国产私人尤物无码不卡| www.亚洲人.com| 粗大的内捧猛烈进出视频| 在线手机中文字幕| 成人av在线网站| 久久综合福利| 亚洲欧洲日韩| 午夜小视频在线观看| 99精品国产一区二区三区2021| 污网站视频在线观看| 亚洲精品中文字幕乱码三区91| 日韩中文一区二区三区| 成人av影视| 亚洲精品2区| 欧美国产在线观看| 97成人在线观看| 欧美自拍偷拍一区二区| 一区二区三区中文在线| 韩剧1988在线观看免费完整版| 久久精品视频中文字幕| 亚洲伦片免费看| 日韩护士脚交太爽了| av在线影音| 中文精品电影| 日韩av有码| 日本精品另类| 亚洲国产中文字幕在线视频综合| 人人天天夜夜| 婷婷伊人综合中文字幕| 国产一区二区三区朝在线观看| 久久久青草婷婷精品综合日韩| 日本精品国产| www.五月激情| 国产精品色婷婷在线观看| 国产区在线观看成人精品| 中文字幕一区综合| 精品人妻午夜一区二区三区四区| 又大又长粗又爽又黄少妇视频| 成 人 免费 黄 色| 成人做爰视频www网站小优视频| 亚洲第一av| 精品视频一区二区三区四区五区| 日韩成人手机在线| 日韩欧美中文字幕在线观看| 精品少妇一二三区| 欧洲一级视频| 国产人与zoxxxx另类91| 欧美日韩在线观看一区二区| 久久女人天堂| 日本色护士高潮视频在线观看| 快灬快灬一下爽蜜桃在线观看| av在线亚洲色图| 宅男在线观看免费高清网站| 成人av在线一区二区| 欧美日韩精品一二三区| 欧美videos巨大粗暴| 玛丽玛丽电影原版免费观看1977| 九九九免费视频| 国产一区二区三区18| 高清一区二区三区视频| 久久精品最新地址| 国产视频三区四区| 在线观看视频你懂的| 久久久精品网站| 无遮挡亚洲一区| 91色琪琪电影亚洲精品久久| 日韩精品中文字幕在线观看| 亚洲人成影院77777| 日韩五码在线观看| 91福利电影| 蜜桃av噜噜一区二区三区小说| 亚洲字幕成人中文在线观看| 99久久综合国产精品二区| 不卡的在线视频| 成人午夜精品久久久久久久蜜臀| 日韩精品一区二区三区久久| a天堂在线资源| 国产精品23p| 欧美成人一区二免费视频软件| 国产午夜精品一区理论片飘花| 国产一区免费观看| 欧美成人一区在线观看| 欧美色片在线观看| 国产三级国产精品国产国在线观看| 在线成人午夜影院| 亚洲成人午夜影院| 黄色一级视频网站| 国产视频亚洲视频| 国产精品国产自产拍高清av| 亚洲污视频在线观看| 午夜精品在线视频一区| 91视频观看免费| 日日干夜夜操| 日韩男人天堂| 国内少妇毛片视频| 色婷婷av一区二区三区之一色屋| 天天摸天天干| 黄色片视频在线观看| 国产成人在线免费看| 91九色偷拍| 久久久精品日韩欧美| 中文在线观看视频| 成人看片毛片免费播放器| 综合久草视频| 最新国产乱人伦偷精品免费网站| 在线看av网址| 麻豆精品蜜桃一区二区三区| 乱子伦视频在线看| www.日本在线观看|