Android項目代碼編寫規范

jopen 9年前發布 | 12K 次閱讀 Android Android開發 移動開發

1、Android編碼規范

包命名規范

包(packages):采用反域名命名規則,全部使用小寫字母。一級包名為com,二級包名為xxx(可以是公司域名或者個人命名),三級包名根據應用進行命名,四級包名為模塊名或層級名。

包名

說明

com.xxx.應用名稱縮寫.activities

頁面用到的Activity類(activities層級用戶界面)

com.xxx.應用名稱縮寫.fragment

頁面用到的Fragment類

com.xxx.應用名稱縮寫.base

頁面中每個Activity類共享的可以寫成一個BaseActivity類(基礎共享的類)

com.xxx.應用名稱縮寫.adapter

頁面用到的Adapter類(適配器的類)

com.xxx.應用名稱縮寫.utils

此包中包含:公共工具方法類(包含日期、網絡、存儲、日志等工具類)

com.xxx.應用名稱縮寫.bean

(model/domain均可,個人喜好)

實體類

com.xxx.應用名稱縮寫.db

數據庫操作

com.xxx.應用名稱縮寫.view(或者.ui)

自定義的View類等

com.xxx.應用名稱縮寫.service

Service服務

com.xxx.應用名稱縮寫.broadcast

Broadcast服務

 

 

類命名規范

類(classes):名詞,采用大駝峰命名法,盡量避免縮寫,除非該縮寫是眾所周知的,比如HTML,URL,如果類名稱包含單詞縮寫,則單詞縮寫的每個字母均應大寫。

 

描述

例如

Application類

Application為后綴標識

XXXApplication

Activity類

Activity為后綴標識

閃屏頁面類

SplashActivity

解析類

Handler為后綴標識

 

公共方法類

Utils或Manager為后綴標識

線程池管理類:ThreadPoolManager

日志工具類:LogUtils

數據庫類

以DBHelper后綴標識

MySQLiteDBHelper

Service類

以Service為后綴標識

播放服務:PlayService

BroadcastReceiver類

以Broadcast為后綴標識

時間通知:

TimeBroadcast

ContentProvider類

以Provider為后綴標識

單詞內容提供者:DictProvider

直接寫的共享基礎類

以Base為前綴

BaseActivity,

BaseFragment

 

變量命名規范

變量(variables)采用小駝峰命名法。類中控件名稱必須與xml布局id保持一致。

公開的常量:定義為靜態final,名稱全部大寫。eg: public staticfinal String ACTION_MAIN=”android.intent.action.MAIN”;

靜態變量:名稱以s開頭 eg:private static long sInstanceCount = 0;

非靜態的私有變量、protected的變量:以m開頭,eg:private Intent mItent;

 

 

接口命名規范

接口(interface):命名規則與類一樣采用大駝峰命名法,多以able或ible結尾,eg:interface Runable; interface Accessible;

 

方法命名規范

方法(methods):動詞或動名詞,采用小駝峰命名法,eg:onCreate(),run();

方法

說明

initXX()

初始化相關方法,使用init為前綴標識,如初始化布局initView()

isXX()

checkXX()方法返回值為boolean型的請使用is或check為前綴標識

getXX()

返回某個值的方法,使用get為前綴標識

processXX()

對數據進行處理的方法,盡量使用process為前綴標識

displayXX()

彈出提示框和提示信息,使用display為前綴標識

saveXX()

與保存數據相關的,使用save為前綴標識

resetXX()

對數據重組的,使用reset前綴標識

clearXX()

清除數據相關的

removeXX()

清除數據相關的

drawXXX()

繪制數據或效果相關的,使用draw前綴標識

 

布局文件命名規范

 

 全部小寫,采用下劃線命名法

1).contentview命名, Activity默認布局,以去掉后綴的Activity類進行命名。不加后綴:

功能模塊.xml

eg:main.xml、more.xml、settings.xml

       或者:activity_功能模塊.xml

eg:activity_main.xml、activity_more.xml

2).Dialog命名:dialog_描述.xml

eg:dlg_hint.xml

3).PopupWindow命名:ppw_描述.xml

       eg:ppw_info.xml

4). 列表項命名listitem_描述.xml

eg:listitem_city.xml

5).包含項:include_模塊.xml

eg:include_head.xml、include_bottom.xml

6).adapter的子布局:功能模塊_item.xml

eg:main_item.xml、

 

資源id命名規范

 命名模式為:view縮寫_模塊名稱_view的邏輯名稱

view的縮寫詳情如下:

控件

縮寫

LayoutView

lv

RelativeView

rv

TextView

tv

Button

btn

ImageButton

imgBtn

ImageView         

iv

CheckBox           

cb

RadioButton        

rb

analogClock        

anaClk

DigtalClock        

dgtClk

DatePicker         

dtPk

EditText           

edtTxt

TimePicker         

tmPk

toggleButton       

tglBtn

ProgressBar 

proBar

SeekBar                            

skBar

AutoCompleteTextView

autoTxt

ZoomControls       

zmCtl

VideoView          

vdoVi

WdbView            

webVi

RantingBar         

ratBar

Tab                

tab

Spinner            

spn

Chronometer        

cmt

ScollView          

sclVi

TextSwitch         

txtSwt

ImageSwitch        

imgSwt

listView           

lVi 或則lv

ExpandableList     

epdLt

MapView            

mapVi

 

動畫文件命名

 動畫文件(anim文件夾下):全部小寫,采用下劃線命名法,加前綴區分。

 

//前面為動畫的類型,后面為方向

動畫命名例子

規范寫法

備注

fade_in

淡入

 

fade_out

淡出

 

push_down_in

從下方推入

 

push_down_out

從下方推出

 

push_left

推像左方

 

slide_in_from_top

從頭部滑動進入

 

zoom_enter

變形進入

 

slide_in

滑動進入

 

shrink_to_middle

中間縮小

 

 

 

圖片資源文件命名

命名

說明

bg_xxx

這種圖片一般那些比較大的圖片,比如作為某個Activity的背景等

btn_xxx

按鈕,一般用于按鈕,而且這種按鈕沒有其他狀態

ic_xxx

圖標,一般用于單個圖標,比如啟動圖片ic_launcher

bg_描述_狀態1[_狀態2]

用于控件上的不同狀態

btn_描述_狀態1[_狀態2]

用于按鈕上的不同狀態

chx_描述_狀態1[_狀態2]

選擇框,一般有2態和4態

 

 

 

 

 

一些常見的單詞縮寫

名稱

縮寫

icon  

ic (主要用在app的圖標)

color  

cl(主要用于顏色值)

divider

di(主要用于分隔線,不僅包括Listview中的divider,還包括普通布局中的線)

selector

sl(主要用于某一view多種狀態,不僅包括Listview中的selector,還包括按鈕的selector

average

avg

background  

Bg主要用于布局和子布局的背景

buffer

buf

control

ctrl

delete

del

document 

doc

error

err

escape

esc

increment

inc

infomation

info

initial 

init

image

img

Internationalization

I18N

length

len

library

lib

message

msg

password-

pwd

position

pos

server

srv

string

str

temp

tmp

window

wnd(win)


 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!