国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

如何在Linux上開發跨平臺的移動應用程序?

譯文
移動開發 移動應用
過去這幾年見證了移動市場的迅猛發展,推動這個市場發展的主要是一大批應用程序。作為消費者,我們都討厭看到任何一種平臺造成的某種市場壟斷局面。畢竟,競爭越激烈,創新越多。作為開發人員,我們對跨平臺開發懷有復雜的心情。跨平臺開發存在幾個缺點,比如糟糕的平臺集成和欠靈活的設計等等。可是另一方面,我們又能夠接觸擁有更多消費者的更廣闊市場,能夠為我們開發的應用程序在眾多平臺上提供統一的外觀和感覺。

【51CTO譯文】過去這幾年見證了移動市場的迅猛發展,推動這個市場發展的主要是一大批應用程序。作為消費者,我們都討厭看到任何一種平臺造成的某種市場壟斷局面。畢竟,競爭越激烈,創新越多。作為開發人員,我們對跨平臺開發懷有復雜的心情。跨平臺開發存在幾個缺點,比如糟糕的平臺集成和欠靈活的設計等等。可是另一方面,我們又能夠接觸擁有更多消費者的更廣闊市場,能夠為我們開發的應用程序在眾多平臺上提供統一的外觀和感覺。

如今,幾乎所有現代的移動平臺都提供面向對象的API。因而,沒有理由不開發跨平臺的應用程序。我們在本教程中將逐步介紹跨平臺開發的基礎知識。我們將使用來自Appcelerator的Titanium SDK作為一種跨平臺SDK(軟件開發工具包)。

我們需要哪些東西?

•了解Java

•PC

•安卓SDK

•Titanium SDK

作為一種開發平臺,Titanium讓你可以通過單一源代碼為谷歌安卓以及蘋果iOS開發原生應用程序。它使用Java作為主語言,還能夠與HTML和JavaScript協同運行。它并不依賴WebUI,而且具有擴展性。模塊可以用Objective-C編寫而成。

對于通曉Java和HTML的那些人來說,Titanium是切入移動開發的一個很好的起點。想開發安卓應用程序,你就需要安卓SDK;如果想開發iOS應用程序,則需要Mac。幸好對我們來說,一旦你有了代碼,就可以將代碼導入到Mac上的Titanium,然后針對iOS編譯代碼。

想讓Titanium SDK正常使用,我們就需要下列:

•Oracle Java JDK 6或7

•Node.js

•安卓SDK和安卓NDK

•至少2 GB內存

在此下載Titanium SDK(需要注冊):https://my.appcelerator.com/auth/signup。

Titanium下載完畢后,進入到下載目錄,將它解壓縮到/opt。

$ sudo unzip titanium.linux.gtk.x86_64.zip -d /opt

下一步進入到終端,設置路徑。

$ echo 'export MOZILLA_FIVE_HOME=/usr/lib/mozilla' >> ~/.bashrc

$ source ~/.bashrc

接下來,我們要為Titanium SDK安裝所有依賴項。

在Ubuntu或Debian上,我們將使用apt-get:

$ sudo apt-get install libjpeg62 libwebkitgtk-1.0-0 lib32z1 lib32ncurses5 lib32bz2-1.0

在Fedora,使用yum:

$ sudo yum install libjpeg62 libwebkitgtk-1.0-0 lib32z1 lib32ncurses5 lib32bz2-1.0

依賴項安裝完畢后,我們要重新安置Titanium,具體如下所示。

$ sudo ln -s /opt/Titanium_Studio/TitaniumStudio /usr/local/bin/TitaniumStudio

在我們頭一次運行Titanium SDK之前,必須為Titanium建立一個構建目錄(build directory)。通常我在/home目錄中有一個名為“builds”的文件夾(下面另有子文件夾),存放著我的所有項目。不妨先建立一個構建目錄。

$ mkdir ~/builds

構建目錄建立完畢后,啟動Titanium。

$ TitaniumStudio

[[126212]]

用你在下載Titanium過程中創建的那個用戶帳戶登錄上去,瀏覽至你的構建目錄。

Titanium SDK的工作窗口連接到你之前創建的帳戶。它提供了豐富的信息和大量的幫助。在左邊,我們可以選擇是創建一個新項目還是導入舊項目。就該教程而言,我們將創建一個新項目,于是選擇“Create Project”(創建項目)選項卡。

在新項目窗口中,我們可以在多個模板之間進行選擇。我們將為本教程選擇默認的項目模板。

之后,我們就要為項目命名了。輸入應用程序編號(app id)和公司URL。應用程序編號與公司URL正好反過來,以.appname結尾。我們網站的URL是http://xmodulo.com,應用程序名為“firstapp”。這樣一來,我們的應用程序編號是“com.xmodulo.firstapp”。

就命名的項目而言,我們需要選擇安卓組件。我通常選擇所有安卓組件。

Titanium會下載和配置所有需要的組件,另外還會更新舊的組件。下載和安裝安卓組件后,Titanium會為我們的項目自動打開一個工作窗口。

工作窗口包括兩個選項卡:app.js和應用程序編輯器。app.js用于編寫代碼,應用程序編輯器窗口則用于提供應用程序信息。

Titanium建立起來后,我們不妨在app.js窗口中創建一些簡單的代碼,了解Titanium的基本元素。

Titanium中最重要的元素就是窗口元素。窗口其實一點也不復雜。你可以把窗口視作開發成果的容器。就某一個應用程序而言,你可以添加一個或多個窗口。下一個重要元素就是視圖元素,這個長方形可容納其他元素,比如HTML中的標記。重要元素還有標記組和標記。它們又是如何工作的呢?每個標記組都含有一個或多個標記,而每個標記控制多個窗口。

構建簡單的應用程序

在教程的這個部分,我們將構建一個簡單的應用程序,它只有主要的元素。首先,不妨指定一些基本方面,比如像素。像素大小并不采用標準的px標注,而是采用百分比,而且需要寫成字符串。

 

  1. top,20
  2.  
  3. width:"50%"

至于顏色,我們并不使用名稱,因為它們采用十六進制RGB顏色碼。

 

  1. backgroundColor:"#f00", 
  2.  
  3. borderColor:"#87C8FF" 

現在使用函數Titanium.UI.createWindow,我們就能構建***批窗口,稍微詳細地闡述一下。

 

  1. var win1 = Titanium.UI.createWindow({  
  2.  
  3. title:'Tab 1'
  4.  
  5. backgroundColor:'#fff' 
  6.  
  7. }); 

這個代碼意味著什么?它表明,我們將含有所有屬性的一個變量傳遞給createWindows函數。那些元素背后的邏輯很簡單。

tagGroup是應用程序的根,不能包含在其他一些元素中。它含有標記,每個標記又含有自己的窗口。不妨把這一切都結合起來,構建成一個演示窗口、標記和視圖的簡單應用程序。

 

  1. // 創建標記組 
  2.  
  3. var tabGroup = Titanium.UI.createTabGroup(); 

現在,不妨創建一些窗口和標記。

 

  1. // 創建基本的UI標記和窗口 
  2. var win1 = Titanium.UI.createWindow({  
  3.  
  4. title:'I am Window 1.'
  5.  
  6. backgroundColor:'#fff' 
  7.  
  8. }); 
  9.  
  10. var tab1 = Titanium.UI.createTab({  
  11.  
  12. icon:'KS_nav_views.png'
  13.  
  14.     title:'Tab 1'
  15.  
  16. window:win1 
  17.  
  18. }); 
  19.  
  20. var win2 = Titanium.UI.createWindow({  
  21.  
  22. title:'I am Window 2'
  23.  
  24. backgroundColor:'#fff' 
  25.  
  26. }); 
  27.  
  28. var tab2 = Titanium.UI.createTab({  
  29.  
  30. icon:'KS_nav_views.png'
  31.  
  32. title:'Tab 2'
  33.  
  34. window:win2 
  35.  
  36. }); 

之后,我們不妨將所有這些連接成一個整體。

 

  1. // 添加標記 
  2.  
  3. tabGroup.addTab(tab1);  
  4.  
  5. tabGroup.addTab(tab2); 
  6.  
  7. // 打開標記組 
  8.  
  9. tabGroup.open(); 

我們編寫好代碼后,就需要定義其外觀。為此,我們要使用標簽元素。有了這個標簽元素,我們就可以為應用程序添加背景墻紙,定義原生字體和顏色。另外,它還允許定義其他元素的外觀。我們將為開發的這個應用程序定義窗口元素的外觀。不妨為我們的應用程序構建一個簡單的標簽元素。

 

  1. var label1 = Titanium.UI.createLabel({ 
  2.  
  3.    color:'#999'
  4.  
  5.    text:'I am Window 1'
  6.  
  7.    font:{fontSize:20,fontFamily:'Helvetica Neue'}, 
  8.  
  9.    textAlign:'center'
  10.  
  11.    width:'auto' 
  12.  
  13. }); 

整個源代碼又是什么樣子呢?

 

  1. // 創建標記組 
  2.  
  3. var tabGroup = Titanium.UI.createTabGroup(); 
  4.  
  5. // 創建基本的UI標記和根窗口 
  6.  
  7. var win1 = Titanium.UI.createWindow({  
  8.  
  9. title:'Tab 1'
  10.  
  11. backgroundColor:'#fff' 
  12.  
  13. }); 
  14.  
  15. var tab1 = Titanium.UI.createTab({  
  16.  
  17. icon:'KS_nav_views.png'
  18.  
  19. title:'Tab 1'
  20.  
  21. window:win1 
  22.  
  23. }); 
  24.  
  25. var label1 = Titanium.UI.createLabel({ 
  26.  
  27.    color:'#999'
  28.  
  29.    text:'I am Window 1'
  30.  
  31.    font:{fontSize:20,fontFamily:'Helvetica Neue'}, 
  32.  
  33.    textAlign:'center'
  34.  
  35.    width:'auto' 
  36.  
  37. }); 
  38.  
  39. win1.add(label1); 
  40.  
  41. var win2 = Titanium.UI.createWindow({  
  42.  
  43. title:'Tab 2'
  44.  
  45. backgroundColor:'#fff' 
  46.  
  47. }); 
  48.  
  49. var tab2 = Titanium.UI.createTab({  
  50.  
  51. icon:'KS_nav_views.png'
  52.  
  53. title:'Tab 2'
  54.  
  55. window:win2 
  56.  
  57. }); 
  58.  
  59. var label2 = Titanium.UI.createLabel({ 
  60.  
  61.    color:'#999'
  62.  
  63.    text:'I am Window 2'
  64.  
  65.    font:{fontSize:20,fontFamily:'Helvetica Neue'}, 
  66.  
  67.    textAlign:'center'
  68.  
  69.    width:'auto' 
  70.  
  71. }); 
  72.  
  73. win2.add(label2); 
  74.  
  75. // 添加標記 
  76.  
  77. tabGroup.addTab(tab1); 
  78.  
  79. tabGroup.addTab(tab2);  
  80.  
  81. // 打開標記組 
  82.  
  83. tabGroup.open(); 

這就是我們這個簡單的應用程序在安卓模擬器中運行時呈現的樣子。

這段代碼短小又簡單,卻是一個很好的起點,可以趁機開始體驗跨平臺開發。

英文原文:http://xmodulo.com/develop-cross-platform-mobile-apps-linux.html

布加迪編譯

責任編輯:閆佳明 來源: 51CTO譯文
相關推薦

2018-03-28 08:30:01

Linux倉庫應用程序

2019-08-13 15:39:27

Linux應用程序

2016-08-02 10:34:17

LinuxWindows雙啟動

2015-01-06 13:42:45

跨平臺開發APP工具

2011-01-28 09:12:53

jQuery Mobi

2013-08-28 15:50:36

Linux桌面Mac

2019-01-04 10:45:31

Windows 10Android應用程序

2013-02-22 09:28:45

MEAP軟件移動應用開發HTML5

2023-03-13 00:16:28

2010-10-15 09:39:22

MeeGoQt

2020-09-23 14:33:01

Golang桌面開發GUI

2011-12-06 10:10:59

云計算移動應用

2011-02-22 10:23:43

2021-10-21 07:08:02

Windows 11操作系統微軟

2013-09-30 10:19:46

SAP

2022-01-20 15:33:30

區塊鏈創新初創公司

2010-11-11 09:04:05

跨平臺移動開發

2014-05-31 22:54:37

Azure移動服務應用程序

2023-09-23 15:52:21

Linux白板應用程序

2010-08-11 09:45:03

點贊
收藏

51CTO技術棧公眾號

影音先锋国产精品| 欧美日韩中字| 国产精品久久久99| 欧美一区免费视频| 欧美做受69| 日韩视频一区在线观看| 网站一区二区三区| 日韩激情视频在线观看| 欧美激情手机在线视频 | 欧美精品久久久久久久久25p| 红桃视频国产精品| 国产91|九色| 免费成人高清在线视频| 91麻豆精品国产91久久久更新时间| 777.av| 久久综合色播五月| 四虎影院一区二区| 精品91久久久久| 国产成人鲁鲁免费视频a| 99久久伊人| 日韩精品免费视频| 永久免费av在线| 动漫精品一区二区| 热国产热中文视频二区| 国产亚洲欧美日韩在线一区| 一区二区三视频| 亚洲欧美日韩国产| 国产精品美女诱惑| 欧美日韩成人| 91久久嫩草影院一区二区| 台湾亚洲精品一区二区tv| 欧美成人午夜激情视频| 成人不卡视频| 亚洲香蕉av在线一区二区三区| 成全电影大全在线观看| 在线观看91av| 午夜免费播放观看在线视频| 色婷婷综合久久久中文一区二区| 作爱视频免费观看视频在线播放激情网| 亚洲国产激情av| 综合激情丁香| 亚洲美女一区二区三区| free性欧美1819hd| 伊人性伊人情综合网| 99不卡视频| 亚洲精品日产精品乱码不卡| 久草在线在线视频| 亚洲激情五月婷婷| 国产超碰在线| 欧美小视频在线观看| 青青草免费在线| 欧美日韩免费一区二区三区| av在线网址观看| 精品国产青草久久久久福利| 色www永久免费视频首页在线| 精品国产免费久久| 欲香欲色天天天综合和网| 亚洲图片欧洲图片av| 欧美午夜三级| 51色欧美片视频在线观看| 亚洲综合图色| 91传媒在线免费观看| 激情丁香综合| 亚洲小视频在线播放| 26uuu亚洲综合色欧美| 日韩av手机版| 欧美性猛xxx| free性m.freesex欧美| www国产精品视频| 欧美日韩爱爱| 久久精品日产第一区二区三区| 麻豆国产91在线播放| 成年人黄色片视频| 疯狂欧美牲乱大交777| 国产精品一卡二卡三卡| 亚洲一级免费视频| 国产精品一区二区av交换| 成人综合电影| 国产91精品一区二区麻豆网站| 少妇激情一区二区三区| 精品欧美激情精品一区| 蜜桃视频m3u8在线观看| 久久久久久久久爱| 最新精品国产| 免费特级黄色片| 亚洲v精品v日韩v欧美v专区| 成年视频在线观看| 欧美激情久久久| 亚洲少妇在线| a在线观看免费视频| 日本乱人伦一区| 在线观看欧美| 91九色视频导航| 国产成a人亚洲精品| 男女羞羞网站| 精品999在线播放| 在线观看欧美理论a影院| 欧美精品一区二区三区在线四季| 久久青草欧美一区二区三区| 国产永久免费高清在线观看 | 国产伦精品一区二区三| va亚洲va日韩不卡在线观看| 中文字幕在线视频不卡| 亚洲欧美国产制服动漫| 国产精品99久久| 国产综合av在线| 欧美精品在线一区二区三区| 久久这里只有精品一区二区| 性刺激综合网| 亚洲成av人在线观看| 中文字幕系列一区| 国产视色精品亚洲一区二区| 国产欧美视频一区二区| 成人福利电影| 2014国产精品| 中文字幕一区二区三区在线播放 | 日韩欧美一二三| 欧美freesex8一10精品| 亚洲国产精品毛片| 午夜视频一区在线观看| 国产精品99久久久久久董美香 | 亚洲精品老司机| 日韩av免费| 欧美在线播放一区二区| 亚洲一区二区视频在线| 国产精品一区二区美女视频免费看| 国产精品久久久久久久小唯西川| 国产精品国产三级国产有无不卡 | 国产精品亚洲视频| 国产精品毛片一区二区三区四区| 欧美国产极速在线| 国产+成+人+亚洲欧洲自线| 黄色片网站在线| 3d动漫啪啪精品一区二区免费 | 久久久久久久激情| 亚洲黄色在线看| 影院欧美亚洲| 中文字幕在线影视资源| 91豆花精品一区| 91亚洲精品久久久蜜桃网站| 99热99re6国产在线播放| 丁香婷婷久久久综合精品国产| 亚洲黄色性网站| 欧美国产极品| 亚洲这里只有精品| 欧美高清视频在线| 久久伊人中文字幕| 国产黄色一区| 九一国产精品视频| 亚洲性xxxx| 国产乱色国产精品免费视频| 午夜小视频福利在线观看| 久久久久久久久久久久久9999| 日韩欧美黄色动漫| 伊人成综合网| 成人在线免费视频| 国产精品视频入口| 欧美日韩免费不卡视频一区二区三区 | 久久国产日本精品| 超碰caoporn久久| 欧洲在线视频一区| 精品日本一线二线三线不卡| 欧美专区一区二区三区| 国产cdts系列另类在线观看| 免费亚洲一区二区| 亚洲成人精品久久| 国产成人在线电影| 亚洲一区导航| 三级短视频在线| 国产精品免费一区二区三区都可以| 亚洲欧美一区二区视频| 中文字幕伦av一区二区邻居| 91美女在线| 91精品免费| 欧美刺激脚交jootjob| 国产高清精品久久久久| av在线亚洲一区| 天堂社区日本电影超碰| 99理论电影网| 精品国产乱码久久久久久久| 国产精品一二三区| av日韩精品| 视频在线不卡| 日韩欧美第二区在线观看| 亚洲图片在线综合| 1000精品久久久久久久久| 亚洲免费二区| 美女日批视频在线观看| 男人的天堂avav| 91精品国产高清久久久久久91| 精品美女国产在线| 麻豆久久久久久| 国产伦精品一区二区三区在线播放| 国产三级av在线| 丝袜足脚交91精品| 久久伊人精品视频| 午夜精品福利一区二区蜜股av | 日本福利小视频| 精品无人乱码一区二区三区的优势| 日韩精品极品视频免费观看|