自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

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

如今,幾乎所有現(xiàn)代的移動平臺都提供面向?qū)ο蟮腁PI。因而,沒有理由不開發(fā)跨平臺的應用程序。我們在本教程中將逐步介紹跨平臺開發(fā)的基礎(chǔ)知識。我們將使用來自Appcelerator的Titanium SDK作為一種跨平臺SDK(軟件開發(fā)工具包)。

我們需要哪些東西?

•了解Java

•PC

•安卓SDK

•Titanium SDK

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

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

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

•Oracle Java JDK 6或7

•Node.js

•安卓SDK和安卓NDK

•至少2 GB內(nèi)存

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

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

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

下一步進入到終端,設(shè)置路徑。

$ 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建立一個構(gòu)建目錄(build directory)。通常我在/home目錄中有一個名為“builds”的文件夾(下面另有子文件夾),存放著我的所有項目。不妨先建立一個構(gòu)建目錄。

$ mkdir ~/builds

構(gòu)建目錄建立完畢后,啟動Titanium。

$ TitaniumStudio

[[126212]]

用你在下載Titanium過程中創(chuàng)建的那個用戶帳戶登錄上去,瀏覽至你的構(gòu)建目錄。

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

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

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

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

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

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

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

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

構(gòu)建簡單的應用程序

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

 

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

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

 

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

現(xiàn)在使用函數(shù)Titanium.UI.createWindow,我們就能構(gòu)建***批窗口,稍微詳細地闡述一下。

 

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

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

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

 

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

現(xiàn)在,不妨創(chuàng)建一些窗口和標記。

 

  1. // 創(chuàng)建基本的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(); 

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

 

  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. // 創(chuàng)建標記組 
  2.  
  3. var tabGroup = Titanium.UI.createTabGroup(); 
  4.  
  5. // 創(chuàng)建基本的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(); 

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

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

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

布加迪編譯

責任編輯:閆佳明 來源: 51CTO譯文
相關(guān)推薦

2019-08-13 15:39:27

Linux應用程序

2018-03-28 08:30:01

Linux倉庫應用程序

2016-08-02 10:34:17

LinuxWindows雙啟動

2015-01-06 13:42:45

跨平臺開發(fā)APP工具

2013-08-28 15:50:36

Linux桌面Mac

2011-01-28 09:12:53

jQuery Mobi

2019-01-04 10:45:31

Windows 10Android應用程序

2013-02-22 09:28:45

MEAP軟件移動應用開發(fā)HTML5

2010-10-15 09:39:22

MeeGoQt

2020-09-23 14:33:01

Golang桌面開發(fā)GUI

2011-02-22 10:23:43

2011-12-06 10:10:59

云計算移動應用

2013-09-30 10:19:46

SAP

2023-03-13 00:16:28

2021-10-21 07:08:02

Windows 11操作系統(tǒng)微軟

2014-05-31 22:54:37

Azure移動服務(wù)應用程序

2023-09-23 15:52:21

Linux白板應用程序

2010-11-11 09:04:05

跨平臺移動開發(fā)

2022-01-20 15:33:30

區(qū)塊鏈創(chuàng)新初創(chuàng)公司

2010-08-11 09:45:03

點贊
收藏

51CTO技術(shù)棧公眾號