【移動應(yīng)用開發(fā)技術(shù)】Android開發(fā)必備知識點有哪些_第1頁
【移動應(yīng)用開發(fā)技術(shù)】Android開發(fā)必備知識點有哪些_第2頁
【移動應(yīng)用開發(fā)技術(shù)】Android開發(fā)必備知識點有哪些_第3頁
【移動應(yīng)用開發(fā)技術(shù)】Android開發(fā)必備知識點有哪些_第4頁
【移動應(yīng)用開發(fā)技術(shù)】Android開發(fā)必備知識點有哪些_第5頁
已閱讀5頁,還剩3頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

【移動應(yīng)用開發(fā)技術(shù)】Android開發(fā)必備知識點有哪些

這篇文章主要介紹“Android開發(fā)必備知識點有哪些”,在日常操作中,相信很多人在Android開發(fā)必備知識點有哪些問題上存在疑惑,在下查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Android開發(fā)必備知識點有哪些”的疑惑有所幫助!接下來,請跟著在下一起來學習吧!1.使用ADB查看CPU溫度(debug版本)查看CPU命令如下:adb

shell

cat

/sys/class/thermal/thermal_zone*/temp2.查看CPU返回內(nèi)容對應(yīng)分類信息adb

shell

cat

/sys/class/thermal/thermal_zone*/typehttps://upload-images.jianshu.io/upload_images/3117364-912a19dd5cc4fe22?imageMogr2/auto-orient/stripCPU溫度查看命令方法由此查看的CPU溫度包含小數(shù)點后三位,小數(shù)點省去,此方法適用于MTK平臺。3.MTKlog中查看CPU溫度kernellog中搜索關(guān)鍵字T_AP查看CPU溫度。https://upload-images.jianshu.io/upload_images/3117364-f82df4a1578b9767?imageMogr2/auto-orient/strip1.debug版本跳過開機向?qū)Х桨?.點擊四次快捷操作連續(xù)點擊屏幕四角(左上-->右上-->右下-->左下),既可跳過開機向?qū)А?.adb命令disable開機向?qū)db

shell

settings

put

secure

user_setup_complete

1adb

shell

settings

put

global

device_provisioned

1adb

shell

pm

disable

com.google.android.setupwizard/.SetupWizardActivity2.debug重啟開機向?qū)Х桨柑^開機向?qū)Ш笥窒胫匦伦唛_機向?qū)В梢試L試以下命令。1.將開機向?qū)瓿珊笤O(shè)置的值復位命令如下:adb

shell

settings

put

secure

user_setup_complete

0adb

shell

settings

put

global

device_provisioned

02.設(shè)置開機向?qū)Э捎茫舆^完開機向?qū)Ш?,會設(shè)置開機向?qū)pk不可用。此時我們應(yīng)該設(shè)置開機向?qū)閑nble狀態(tài)。adb

shell

pm

enable

com.google.android.setupwizard/.SetupWizardActivityadb

shell

am

start

-n

com.google.android.setupwizard/.SetupWizardActivity3.開機向?qū)og調(diào)試打開開機向?qū)д{(diào)試Log方式如下:adb

shell

setprop

log.tag.SetupWizard

VERBOSE4.代碼中跳過開機向?qū)У姆椒ㄔ诖a中跳過開機向?qū)У姆椒ㄈ缦拢?/p>

private

void

SkipSetupwizard(){

ActivityManager

activityAanager

=

(ActivityManager)

mContext

.getSystemService(Context.ACTIVITY_SERVICE);

ComponentName

cn

=

activityAanager.getRunningTasks(1).get(0).topActivity;

String

pName

=

cn.getPackageName();

if("com.google.android.setupwizard".equals(pName))

{

Settings.Global.putInt(mContext.getContentResolver(),

Settings.Global.DEVICE_PROVISIONED,

1);

Settings.Secure.putInt(mContext.getContentResolver(),

Settings.Secure.USER_SETUP_COMPLETE,

1);

activityAanager.forceStopPackage("com.google.android.setupwizard");

Log.i("wjwj","skip

com.google.android.setupwizard");

}

}1.使用adb命令抓log查看adblogcat|findstrDisplayed或者直接抓取adbLog,然后搜索關(guān)鍵字Displayedhttps://upload-images.jianshu.io/upload_images/3117364-220378b7ed8c2635?imageMogr2/auto-orient/stripAPP冷啟動時間統(tǒng)計https://upload-images.jianshu.io/upload_images/3117364-eaf5c35a57a870c3?imageMogr2/auto-orient/stripadbLog中搜索關(guān)鍵字Display2.查看多次app冷啟動的方法測試10次Chrome冷啟動的方法如下:adbshellamstart-S-R10-Wcom.android.chrome/com.google.android.apps.chrome.Main測試結(jié)果如下:C:\Users\Administrator>adb

shell

am

start

-S

-R10

-W

com.android.chrome/com.google.android.apps.chrome.MainStopping:

com.android.chromeStarting:

Intent

{

act=ent.action.MAIN

cat=[ent.category.LAUNCHER]

cmp=com.android.chrome/com.google.android.apps.chrome.Main

}Status:

okActivity:

com.android.chrome/org.chromium.chrome.browser.firstrun.FirstRunActivityTotalTime:

1514WaitTime:

1525CompleteStopping:

com.android.chromeStarting:

Intent

{

act=ent.action.MAIN

cat=[ent.category.LAUNCHER]

flg=0x10000000

cmp=com.android.chrome/com.google.android.apps.chrome.Main

}Status:

okActivity:

com.android.chrome/org.chromium.chrome.browser.firstrun.FirstRunActivityTotalTime:

534WaitTime:

549Completeprivate

static

final

boolean

USER_BUILD

=

android.os.Build.IS_USER;查看Build.java發(fā)現(xiàn),這些是對外部apk隱藏的方法,只有系統(tǒng)平臺簽名的應(yīng)用才可以使用。

/**

{@hide}

*/

public

static

final

boolean

IS_ENG

=

"eng".equals(TYPE);

/**

{@hide}

*/

public

static

final

boolean

IS_USERDEBUG

=

"userdebug".equals(TYPE);

/**

{@hide}

*/

public

static

final

boolean

IS_USER

=

"user".equals(TYPE);/frameworks/base/packages/SystemUI/src/com/android/systemui/screenshot/GlobalScreenshot.java

//

import

com.mediatek.storage.StorageManagerEx;

String

defaultWritePath

=

StorageManagerEx.getDefaultPath()+File.separator+"Pictures";

mScreenshotDir

=

new

File(defaultWritePath,

SCREENSHOTS_DIR_NAME);1.將所有的systemdump文件追加到一個文件中首先我們需要抓到dumpsyslog,然后將所有的systemcore*文件追加到一個文件中。cat

systemcore*

>

allhttps://upload-images.jianshu.io/upload_images/3117364-e621d2e877e128bb?imageMogr2/auto-orient/strip將sysdump所有文件追加到一個文件中2.使用對應(yīng)版本的vmlinux解析dump文件使用crash_arm命令對dump文件進行解析32位系統(tǒng)使用如下:./crash_armvmlinuxall-mphys_base=0x8000000064位系統(tǒng)使用如下命令:./crash_arm64vmlinuxall-mphys_offset=0x800000003.解析成功后進行調(diào)試成功解析dump后解析log方法log>log.txthttps://upload-images.jianshu.io/upload_images/3117364-af209775c7779c07?imageMogr2/auto-orient/strip使用log命令讀取log到指定文件修改

device\sprd\xxxx\common\rootdir\root\mon.rc在onpost-fs-data

中添加如下內(nèi)容:on

post-fs-data

setprop

persist.ylog.enabled

1//增加這一句用于打開ylog

setprop

debug.sysdump.enabled

true

//增加這一句用于打開sysdump

setprop

persist.sys.eng.reset

1

//再增加這一句

start

ylog

public

boolean

isMonkeyRunning()

{

return

ActivityManager.isUserAMonkey();

}修改以下路徑下配置的屬性值既可alps\device\mediatek\common\mtklog將false

改為true就可以打開對應(yīng)的logmtklog_path

=

internal_sdcom.mediatek.log.mobile.enabled

=

falsecom.mediatek.log.mobile.maxsize

=

500com.mediatek.log.mobile.totalmaxsize

=

1000com.mediatek.log.modem.enabled

=

falsecom.mediatek.log.modem.maxsize

=

2000.enabled

=

.maxsize

=

600com.mediatek.log.gps.enabled

=

false輸入暗碼

*#*#3646633#*#*,進入MTKLogger

界面,右上角打開LoggerSetting,手動關(guān)閉除MoblieLog之外的開關(guān)。關(guān)閉方法請看下圖:https://upload-images.jianshu.io/upload_images/3117364-5fe27fda34c7b622?imageMogr2/auto-orient/stripmtk平臺開啟Mobilelog參考圖輸入暗碼

*#*#83781#*#*,進入SPRDLogger

界面,右上角打開Settings,點擊Customscene,關(guān)閉除Androidlog之外的開關(guān),關(guān)閉方法請看下圖。https://upload-images.jianshu.io/upload_images/3117364-4c4cc374d73c1516?imageMogr2/auto-orient/stripSPRD平臺開啟Androidlog參考圖只開AndroidLog(參考十一、SPRD平臺只開Androidlog方法)進入DEBUG&Log界面,systeminfo->

PowerLog;打開PowerGurulog和wakelocklog;重啟設(shè)備。使用下面命令,復位一下batteryhistoryadb

shell

dumpsys

batterystats

--enable

full-wake-historyadb

shell

dumpsys

batterystats

--reset測試完成后,使用下面命令,抓取bugreportadb

rootadb

bugreport

>

bugreport.zip最后將andoridlog和bugreport.zip

都提供出來。獲取ActivityTop的方法如下://import

android.app.ActivityManager;//import

android.app.ActivityManager.RunningTaskInfo;//import

android.content.ComponentName;//import

java.util.List;//

獲取top

Activity

apk

public

String

getTopActivityPackageName(Context

context)

{

String

topActivityPackage

=

null;

ActivityManager

activityManager

=

(ActivityManager)

(context

.getSystemService(android.content.Context.ACTIVITY_SERVICE));

List<RunningTaskInfo>

runningTaskInfos

=

activityManager

.getRunningTasks(1);

if

(runningTaskInfos

!=

null)

{

ComponentName

f

=

runningTaskInfos.get(0).topActivity;

topActivityPackage

=

f.getPackageName();

//Slog.e("wangjie",

"topActivityPackage"+topActivityPackage);

}

return

topActivityPackage;

}孟加拉語開機向?qū)g迎語不對,客戶要求去掉開機向?qū)Ы缑鏆g迎語方法。idh.code/frameworks/base/core/java/android/widget/TextView.javapublic

class

TextView

extends

View

implements

ViewTreeObserver.OnPreDrawListener

{...

...

public

void

setTextLocale(@NonNull

Locale

locale)

{+

//

add

for

Bangla

language+

if

(getContext().getClass().getName().equals("com.google.android.setupwizard.user.WelcomeActivity")

&&+

locale.getLanguage().equals("bn")

&&

locale.getCountry().equals("BD"))+

{+

Log.i(LOG_TAG,

"find

text:"

+

getText());+

if

(!getText().equals("")

&&

!getText().toString().contains("("))+

Log.i(LOG_TAG,

"set

text:"

+

getText());+

setText("");+

}+

//

add

for

Bangla

language

mLocalesChanged

=

true;

mTextPaint.setTextLocale(locale);

...

...

}...

...}展訊平臺修改狀態(tài)欄時間顯示秒方法如下adb

shell

pm

enable

com.android.systemui/com.android.systemui.tuner.TunerActivityadb

shell

am

start

-n

com.android.systemui/com.android.systemui.tuner.TunerActivity進入設(shè)置--系統(tǒng)--界面界面調(diào)諧器--狀態(tài)欄--時間--顯示時分秒。判斷多用戶方法如下://

import

android.os.UserHandle;if(UserHandle.myUserId()

!=

UserHandle.USER_OWNER){

//

給管理員用戶

進行操作}AndroidGO版本下,為了兼容系統(tǒng)性能,犧牲部分UI體驗,比如最近任務(wù)列表模糊,Settings界面加載由模糊到清晰,Launcher圖標加載由模糊到清晰,但是這個很影響用戶體驗,個人認為不太好,去掉模糊效果的方案如下:1.需要修改的文件如下:

frameworks/base/services/core/java/com/android/server/wm/AppWindowContainerController.java

frameworks/base/services/core/java/com/android/server/wm/TaskSnapshotController.java

frameworks/base/services/core/java/com/android/server/wm/TaskSnapshotPersister.java1.AppWindowContainerController修改方法在AppWindowContainerController.java類中,請注釋掉scheduleAddStartingWindow方法實現(xiàn)。public

class

AppWindowContainerController

extends

WindowContainerController<AppWindowToken,

AppWindowContainerListener>

{...

...//

注釋掉該方法

void

scheduleAddStartingWindow()

{

//

Note:

we

really

want

to

do

sendMessageAtFrontOfQueue()

because

we

//

want

to

process

the

message

ASAP,

before

any

other

queued

//

messages.

/***

if

(!mService.mAnimationHandler.hasCallbacks(mAddStartingWindow))

{

mContainer.startingAdding

=

true;

if

(DEBUG_STARTING_WINDOW)

Slog.v(TAG_WM,

"Enqueueing

ADD_STARTING");

mService.mAnimationHandler.postAtFrontOfQueue(mAddStartingWindow);

}

***/

}...

...}2.TaskSnapshotController修改方法將系統(tǒng)手動設(shè)置為非低內(nèi)存設(shè)備,比如將isLowRamDevice=false狀態(tài)。class

TaskSnapshotController

{...

...//

將系統(tǒng)手動設(shè)置為非低

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論