`
luckliu521
  • 浏览: 252516 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Android初学者常见问题解析

阅读更多
1.  在cmd命令行中输入android list target出现android不是内部或外部命令

   新建一个环境变量ANDROID_HOME=你的sdk所在目录

然后在 path 中加入 %ANDROID_HOME%\tools


2. 移除程式

我們已經順利地啟動了虛擬機器,那麼,該怎麼移除安裝到虛擬機器上的程式哩?

Android SDK 中提供一個 adb (Android Debugger) 命令行工具 (在 android-sdk/tools 中),我們可以用裡面的 shell 工具連上虛擬機器來移除應用程式。在某些平台上,這些動作可能需要擁有 root 權限才能執行。

首先打開命令列,啟動 adb shell

    $ adb shell

接著切換到 data/app 目錄中

    $ cd data/app/

使用 ls 命令(等同 windows 上命令行的 dir 命令)來檢視檔案列表

    # ls

    com.example.android.apis.apk

接著使用 rm 命令來刪除 ApiDemos 應用程式

    # rm com.example.android.apis.apk

    # ls

移除虛擬機器

我們可以使用「android list avd」命令來列出所有的虛擬機器

$ android list avd

Available Android Virtual Devices:

    Name: eclair

    Path: /Users/mac/.android/avd/cupcake.avd

  Target: Android 2.0 (API level 5)

    Skin: HVGA

表示現在系統中有一個名為 eclair 的虛擬機器。 我們可以使用「android delete avd --name eclair」命令來刪除名稱為「eclair」的虛擬機器。

$ android delete avd --name eclair

AVD 'eclair' deleted.

刪除後再次執行「android list avd」命令,得到的結果為

$ android list avd

Available Android Virtual Devices:

表示系統中已經不存在任何模擬器,我們真的已經將虛擬機器刪除了。



3. 出现“Project has no target set. Edit the project properties to set one.”的错误

Eclipse导入步骤:
1. File.../Import.../General/Existing Projects into Workspace
2. 点Browse按钮,选择要导入的项目所在目录,点Finish
3. 如果出现“Project has no target set. Edit the project properties to set one.”的错误,则需要在该项目的属性里选中Project Build Target的Android版本
4. 文件夹中会自动追加一个gen的小目录,里面是自动生成的R.java文件,如果导入的文件中已有R.java,则会报错,此时只要将原来的R.java文件删掉即可。

如果有提示关于AndroidManifest.xml的错误,请选中此项目,并右键选择Android Tools->Fix Project,将会自动帮你修复错
误。





4. Could not find *.apk

1) 选择工程的Properties->Java Build Path->Libraries,去掉默认的Android包;

2) 点击左侧的Android标签,在右边的Project Build Target中选择Android 2.0;

3) 右键单击工程,选择Android Tools->Fix Project Properties.

有时候也可能是jdk版本的问题,改了jdk版本后,重启下eclipse



5、emulator: ERROR: the user data image is used by another emulator. Aborting

没有正常关闭导致的,删除android-sdk-windows\.android\avd\对于版本\下的以.lock结尾的文件夹就行


6. qemu: could not open disk image E:\Android\sdcard.img

  待解决



7. music player时需要在sdcard中加入文件

今天试用一下android的music player.运行music player,点击songs,显示如图:
 



原来,默认android没有加载sdcard,为了播放歌曲我们需要让android模拟张sdcard,具体操作如下:

D:\Tools\Android\android-sdk-windows-1.5_r1\tools>mksdcard.exe -l sdcard 256M E:
\study\android\sdcard.img

启动android时,需要指定sdcard,操作如下:

D:\Tools\Android\android-sdk-windows-1.5_r1\tools>emulator.exe -avd myroid -sdca
rd e:\study\android\sdcard.img

接下来,还需要在卡里放几首歌曲。需要使用到另一个工具ddms.bat,如下图:



点击Device—>FileExplorer,可以看到android系统的所有目录及文件,包括新创建的sdcard:



选中sdcard,点击toolbar上的push file onto Device,选择你要上传的音乐:



文件传好,就可以看到sdcard上显示的音乐了:





这时重新启动android,再运行music player点击songs,就可以看到sdcard里放入的音乐了:


选择歌曲就开始播放了:



回到桌面,可以看到music player的widget显示正在播放的歌曲:




怎么样,android还是挺有趣的吧,不过这里暂且报告几个使用过程中的android的bug(也许不是bug,只是我

还不会玩,:))

1.使用ddms的file explorer传输中文名称的文件不行,控制台显示如下错误:

55:41 E/ddms: transfer error: Invalid argument
Failed to push 水木年华-启程.wma on emulator-5554: Invalid argument

2.使用file explorer上传文件到sdcard上,需要重启android,music player才能看到sdcard上的媒体文件。

3.android的music player对mp3的id3 tag信息中文还是有乱码,如下图:


 

今天就到这里吧,下回要学习一下怎么开发个android的widget了。


8. 程序启动处错误the application 。。。source not find

解决:F11 调试 ,F6单步调试(加上断点),可以发现 “source not find ”的错误,

看了一下 问题出在了 Acitvity这里 到 文档里面 包:android.app.Activity里面看了下

如下:我标上了黄色的底纹的地方,问题就出在这里了,我虽然新建了一个活动但是我没有把这个活动注册到  AndroidManifest.xml. 这个文件里面。

下面是关于Activity的简单的介绍,很容易看懂,大概就是 ,活动是什么,子类可以实现 onCreate(Bundle) 、onPause()  方法,还介绍了 一下生命周期等。



9. Failed to push Angels.mp3 on emulator-5554: Read-only file system

打开cmd 运行如下命令

mksdcard -l sdcard 256M E:\Android\test\sdcard.img

emulator -avd tm -sdcard E:\Android\test\sdcard.img




再打开cdm 运行

adb push F:\MP3\EnglishSong\Angels.mp3 sdcard

(如果是用MediaStore获取歌曲列表,添加完后,进入模拟器,进入Dev Tools,里面有个Media Scanner.运行一下。ok现在进入应用就能看到歌曲列表了)

后查看sdcard 如下图:



10. Console

[2010-03-26 10:18:34 - TestMediaPlayer]Installation failed due to invalid APK file!

[2010-03-26 10:18:34 - TestMediaPlayer]Please check logcat output for more details.

[2010-03-26 10:18:34 - TestMediaPlayer]Launch canceled!

LogCat

03-26 02:18:33.950: DEBUG/asset(59): failed to open Zip archive '/data/app/vmdl10030.tmp'

03-26 02:18:33.959: WARN/PackageParser(59): Unable to read AndroidManifest.xml of /data/app/vmdl10030.tmp

03-26 02:18:33.959: WARN/PackageParser(59): java.io.FileNotFoundException: AndroidManifest.xml

03-26 02:18:33.959: WARN/PackageParser(59):     at android.content.res.AssetManager.openXmlAssetNative(Native Method)

03-26 02:18:33.959: WARN/PackageParser(59):     at android.content.res.AssetManager.openXmlBlockAsset(AssetManager.java:469)

03-26 02:18:33.959: WARN/PackageParser(59):     at android.content.res.AssetManager.openXmlResourceParser(AssetManager.java:437)

03-26 02:18:33.959: WARN/PackageParser(59):     at android.content.pm.PackageParser.parsePackageName(PackageParser.java:560)

03-26 02:18:33.959: WARN/PackageParser(59):     at com.android.server.PackageManagerService.installPackageLI(PackageManagerService.java:4237)

03-26 02:18:33.959: WARN/PackageParser(59):     at com.android.server.PackageManagerService.access$1600(PackageManagerService.java:109)

03-26 02:18:33.959: WARN/PackageParser(59):     at com.android.server.PackageManagerService$5.run(PackageManagerService.java:3768)

03-26 02:18:33.959: WARN/PackageParser(59):     at android.os.Handler.handleCallback(Handler.java:587)

03-26 02:18:33.959: WARN/PackageParser(59):     at android.os.Handler.dispatchMessage(Handler.java:92)

03-26 02:18:33.959: WARN/PackageParser(59):     at android.os.Looper.loop(Looper.java:123)

03-26 02:18:33.959: WARN/PackageParser(59):     at android.os.HandlerThread.run(HandlerThread.java:60)

03-26 02:18:33.959: ERROR/PackageManager(59): Couldn't find a package name in : /data/app/vmdl10030.tmp

根据以上提示找不到AndroidManifest.xml文件,将R.Java删除,重新运行就可以了



11. java.net.SocketException: Permission denied (maybe missing INTERNET permission)

这是一个经典错误, Socket不能对外连接,错误不会被报出,调试的时候,能看到Exception, 这个Exception会有很多变体, 所以不一一举例,只要存在网络互联,
该东东挺身而出,让你的程序不得运行。

原因是: 需要访问到网络,所以,在AndroidManifest.xml中,需要进行如下配置:

<uses-permission android:name="android.permission.INTERNET" />

or

<uses-permission xmlns:android="http://schemas.android.com/apk/res/android" android:name="android.permission.INTERNET"></uses-permission>
  • 大小: 41.4 KB
  • 大小: 84.8 KB
  • 大小: 21.9 KB
  • 大小: 128.9 KB
  • 大小: 66.4 KB
  • 大小: 175.1 KB
  • 大小: 29.3 KB
  • 大小: 33.1 KB
分享到:
评论
1 楼 bn922 2011-01-26  
文章有点乱 请博主整理...

相关推荐

Global site tag (gtag.js) - Google Analytics