Android使用Service播放音乐实例代码

 更新时间:2016年9月20日 19:59  点击:1571
今天我来介绍在android手机开发中我们利用Service播放音乐实例,这里需要有一个xml文档列表来存储音乐的地址,然后通过下面的程序读取音乐文件进行播放了。

Android Service 的使用:

我们可以创建一个Android程序,在src目录下创建一个Activity,一个继承自Service类的服务类;同时在资源文件夹res目录下创建一个raw的文件夹存放音频文件,如把music.mp3音乐文件放在该目录下。该程序的主界面如下:

xml布局

 代码如下 复制代码

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <TextView 
       android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:text="Welcome to Andy's blog!"
       android:textSize="16sp"/>  
    <TextView 
       android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:text="音乐播放服务"/>
    <Button
       android:id="@+id/startMusic"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="开启音乐播放服务"/>
    <Button
       android:id="@+id/stopMusic"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="停止音乐播放服务"/>
   <Button
      android:id="@+id/bindMusic"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="绑定音乐播放服务"/>
   <Button
      android:id="@+id/unbindMusic"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="解除 ——绑定音乐播放服务"/>
</LinearLayout>

java代码

 代码如下 复制代码

MusicService.java

package com.zeph.android.service;

import android.app.Service;
import android.content.Intent;
import android.media.MediaPlayer;
import android.os.IBinder;

public class MusicService extends Service {
 private MediaPlayer mMediaPlayer;

 @Override
 public IBinder onBind(Intent arg0) {
  return null;
 }

 @Override
 public void onCreate() {
  super.onCreate();
  mMediaPlayer = MediaPlayer.create(this, R.raw.music01);
 }

 @Override
 public void onDestroy() {
  super.onDestroy();
  mMediaPlayer.stop();
  mMediaPlayer.release();
 }

 @Override
 public void onStart(Intent intent, int startId) {
  super.onStart(intent, startId);
  int operate = intent.getIntExtra("operate", 3);
  switch (operate) {
  case 0:
   if (!mMediaPlayer.isPlaying()) {
    mMediaPlayer.start();
   }
   break;
  case 1:
   if (mMediaPlayer.isPlaying()) {
    mMediaPlayer.pause();
   }
   break;
  case 2:
   if (mMediaPlayer.isPlaying()) {
    mMediaPlayer.stop();
    mMediaPlayer = MediaPlayer.create(this, R.raw.music01);
   }
   break;
  default:
   break;
  }
 }
}
ServiceTestActivity.java

package com.zeph.android.service;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class ServiceTestActivity extends Activity {
 private Button playButton;
 private Button pauseButton;
 private Button stopButton;
 private Button stopService;

 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  playButton = (Button) findViewById(R.id.playButton);
  pauseButton = (Button) findViewById(R.id.pauseButton);
  stopButton = (Button) findViewById(R.id.stopButton);
  stopService = (Button) findViewById(R.id.stopService);

  playButton.setOnClickListener(new ButtonOnClickListener());
  pauseButton.setOnClickListener(new ButtonOnClickListener());
  stopButton.setOnClickListener(new ButtonOnClickListener());
  stopService.setOnClickListener(new ButtonOnClickListener());
 }

 public class ButtonOnClickListener implements OnClickListener {

  @Override
  public void onClick(View view) {
   Intent intent = new Intent();
   intent.setClass(getApplicationContext(), MusicService.class);
   if (view == playButton) {
    intent.putExtra("operate", 0);
    startService(intent);
   } else if (view == pauseButton) {
    intent.putExtra("operate", 1);
    startService(intent);
   } else if (view == stopButton) {
    intent.putExtra("operate", 2);
    startService(intent);
   } else if (view == stopService) {
    stopService(intent);
   }
  }
 }
}

服务还需要在AndroidManifest.xml注册后才能使用:

 代码如下 复制代码

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.pocketdigi.service"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".main"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    <service android:enabled="true" android:name=".Music" />
    </application>
</manifest>

今天文章来给各位安卓开者提供两个在应用中不错的实例,在安卓一个实例手动更新模块和自动更新模块程序代码,希望此代码对各位有帮助。

这里介绍了实现原理,为了使用方便,简单封装了一个类Updater。用法很简单。好吧,为了支持多语言,其实还是有些繁琐。

用法:

strings.xml 中用到的字符定义
其他语言的自己添加,下面的实例程序中,中英文都有

 代码如下 复制代码

<string name="update">check for update</string>
<string name="help">Help?</string>
<string name="help_content">I am helper,muhaha~~~</string>
<string name="found_newversion">Found a new version</string>
<string name="need_update">need update?</string>
<string name="alertdialog_title">Software Update</string>
<string name="alertdialog_update_button">Update</string>
<string name="alertdialog_cancel_button">Not now</string>
<string name="progressdialog_title">Downloading update</string>
<string name="progressdialog_message">Please wait a moment</string>

在AndroidManifest.xml添加更新需要用到的权限

 代码如下 复制代码
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
<uses-permission android:name="android.permission.INSTALL_PACKAGES"></uses-permission>

检查更新,如发现有新版本会弹出提示

 

 代码如下 复制代码
 private boolean checkUpdate() {
 Updater updater = new Updater("http://127.0.0.1/", this);
 if (updater.needUpdate())//found update
  updater.showNewVersionUpdate();
 else {
 
 }
 
 return true;
}

自动更新


之前帮别人定制的一个android应用需要加个自动更新的功能。在 Market 里的应用是无需操心此事的,但像我这种定制的程序就需要自己实现。

原理相当简单,检查更新的时候,通过指定的URL获取服务器端版本信息。比较版本,如果更新,访问服务器端返回的apk的URL地址,下载,安装。各种 Makert 也是通过类似的机制实现的。原理搞清楚了,代码就相当简单了。

获取apk的VesionName,即AndroidManifest.xml中定义的android:versionName

 代码如下 复制代码

public String getVesionName(Context context) {
 String versionName = null;
 try {
  versionName = context.getPackageManager().getPackageInfo("net.vpntunnel", 0).versionName;
 } catch (NameNotFoundException e) {
  Log.e(TAG, e.getMessage());
 }
 
 return versionName;
}

更新以及安装程序需要的权限,在AndroidManifest.xml中添加

 代码如下 复制代码
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
<uses-permission android:name="android.permission.INSTALL_PACKAGES"></uses-permission>

获取apk的versionCode,即AndroidManifest.xml中定义的android:versionCode

 代码如下 复制代码

public int getVersionCode(Context context) {
 int versionCode = 0;
 try {
  versionCode = context.getPackageManager().getPackageInfo("net.vpntunnel", 0).versionCode;
 } catch (NameNotFoundException e) {
  Log.e(TAG, e.getMessage());
 }
 
 return versionCode;
}

服务器端version.JSON,包含apk路径以及版本信息

 代码如下 复制代码

{
    "ApkName":"NAME",
    "ApkFullName":"NAME_1.0.5.apk",
    "VersionName":"1.0.5",
    "VersionCode":3
}

获取远程服务器的版本信息

 代码如下 复制代码

private void getRemoteJSON(string host) throws ClientProtocolException, IOException, JSONException {
 String url = String.format("http://%s/%s", host, VER_JSON);
 StringBuilder sb = new StringBuilder();
 HttpClient client = new DefaultHttpClient();
 HttpParams httpParams = client.getParams();
 HttpConnectionParams.setConnectionTimeout(httpParams, 3000);
 HttpConnectionParams.setSoTimeout(httpParams, 5000);
 HttpResponse response = client.execute(new HttpGet(url));
 HttpEntity entity = response.getEntity();
 if (entity != null) {
  BufferedReader reader = new BufferedReader(new InputStreamReader(entity.getContent(), "UTF-8"), 8192);
 
  String line = null;
  while ((line = reader.readLine()) != null) {
   sb.append(line + "n");
  }
  reader.close();
 }
 
 JSONObject object = (JSONObject) new JSONTokener(sb.toString()).nextValue();
 this.apkFullName = object.getString("ApkFullName");
 this.versionName = object.getString("VersionName");
 this.versionCode = Integer.valueOf(object.getInt("VersionCode"));
}

发现更新的提醒窗口,通过AlertDialog实现

 代码如下 复制代码

private void shoVersionUpdate(String newVersion, final String updateURL) {
 String message = String.format("%s: %s, %s", mContext.getString(R.string.found_newversion), newVersion, mContext.getString(R.string.need_update));
 AlertDialog dialog = new AlertDialog.Builder(mContext).setTitle(mContext.getString(R.string.alertdialog_title)).setMessage(message)
 // update
   .setPositiveButton(mContext.getString(R.string.alertdialog_update_button), new DialogInterface.OnClickListener() {
    @Override
    public void onClick(DialogInterface dialog, int which) {
     pBar = new ProgressDialog(mContext);
     pBar.setTitle(mContext.getString(R.string.progressdialog_title));
     pBar.setMessage(mContext.getString(R.string.progressdialog_message));
     pBar.setProgressStyle(ProgressDialog.STYLE_SPINNER);
     dialog.dismiss();
     downFile(updateURL);
    }
    // cancel
   }).setNegativeButton(mContext.getString(R.string.alertdialog_cancel_button), new DialogInterface.OnClickListener() {
    public void onClick(DialogInterface dialog, int whichButton) {
     dialog.dismiss();
    }
   }).create();
 dialog.show();
}

下载新版的apk文件,存放地址可以放到SD卡中。通过Environment.getExternalStorageDirectory()获取SD卡中的路径

 代码如下 复制代码

private void downFile(final String url) {
 pBar.show();
 new Thread() {
  public void run() {
   HttpClient client = new DefaultHttpClient();
   HttpGet get = new HttpGet(url);
   HttpResponse response;
   try {
    response = client.execute(get);
    HttpEntity entity = response.getEntity();
    long length = entity.getContentLength();
    InputStream is = entity.getContent();
    FileOutputStream fileOutputStream = null;
    if (is != null) {
     File f = new File(UPDATE_DIR);
     if (!f.exists()) {
      f.mkdirs();
     }
     fileOutputStream = new FileOutputStream(new File(UPDATE_DIR, updateFileName));
 
     byte[] buf = new byte[1024];
     int ch = -1;
     int count = 0;
     while ((ch = is.read(buf)) != -1) {
      fileOutputStream.write(buf, 0, ch);
      count += ch;
      Log.d(TAG, String.valueOf(count));
      if (length > 0) {
      }
     }
    }
    fileOutputStream.flush();
    if (fileOutputStream != null) {
     fileOutputStream.close();
    }
 
    handler.post(new Runnable() {
     public void run() {
      pBar.cancel();
      installUpdate();
     }
    });
   } catch (Exception e) {
    pBar.cancel();
    Log.e(TAG, e.getMessage());
   }
  }
 
 }.start();
}

安装更新

 代码如下 复制代码
private void installUpdate() {
 Intent intent = new Intent(Intent.ACTION_VIEW);
 intent.setDataAndType(Uri.fromFile(new File(UPDATE_DIR, updateFileName)), "application/vnd.android.package-archive");
 mContext.startActivity(intent);
}

至此更新需要函数就完成了,根据自己的业务逻辑组合一下,更新功能就搞定了。也可以稍微封装下,写成一个通用类,下次就可以直接用了。

有一个注册界面,有四个可填项: 用户名,密码,确认密码,手机号码 我就是想知道,当我填完了四项内容后,点击提交按钮,我所填的内容能保存在应用中,并在再次调到登录界面时能用刚注册的信息成功登录,这是可以实现的吧?

1:代码实现切换操作
2:配置中声明另外一个acitivity

我们先看第一步,这里是触屏处理中的一段代码:

 代码如下 复制代码
public boolean onTouchEvent(MotionEvent event) {
    float pointx = event.getX();
    float pointy = event.getY();
    if (pointx > bp_x + 14 && pointx < bp_x + 14 + 117) {
        if (pointy > bp_y + 43 && pointy < bp_y + 43 + 15) {
        // 帐号
        Intent i = new Intent();// 得到一个意图的实例
        i.putExtra("count", 1);// 写出数据
        i.putExtra("himi", str_zh);
        i.setClass(MainActivity.instance, Register.class);// 设置当前activity以及将要操作的类
        MainActivity.instance.startActivity(i);// 用当前activity来启动另外一个activity
        }
    }
}

显示定义一个intent对象,Intent这个类的机制是协助交互的,详细的说明这里不多讲。

Intent中的putExtra()函数是起到两个activity之间交互交互的作用,这个方法类似 hashtable 或者hashmap中的put,第一个参数是key(索引) ,后一个参数volue(值),根据key我们可以得到对应的volue了。那么后面我也附上接受的处理。

Intent 中的setClass()函数也是传入两个参数,第一个是传入当前实例的activity对象,后面一个参数指需要打开的activity这个类!然后我们就可以利用当前activity对象来启动另外一个activity了。然后我们看下在另外一个activity是如何创建并且怎么接受数据的。

 代码如下 复制代码

package com.himi;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.TextView;

/** * @author Himi **/

public class Register extends Activity {
    private Button button_ok;
    private EditText et;
    private TextView tv;
    private LinearLayout ly;
    private Register rs;
    private byte count;

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        rs = this;
        ly = new LinearLayout(this);
        button_ok = new Button(this);
        button_ok.setWidth(100);
        button_ok.setText("确定");
        button_ok.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
            if (count == 1) {
                MySurfaceView.str_zh = et.getText().toString();
            }
            else if (count == 2) {
                MySurfaceView.str_pass = et.getText().toString();
            }
            rs.finish();
        }
    });

    Intent intent = this.getIntent();
    count = (byte) intent.getIntExtra("count", 0);
    String temp_str = "";
    String temp_str2 = "";
    et = new EditText(this);
    tv = new TextView(this);
    if (count != 3) {
        temp_str = intent.getStringExtra("himi");
        if (count == 1) {
            rs.setTitle("请输入帐号!");
        }
        else {
            rs.setTitle("请输入密码!");
        }
        ly.addView(tv);
        ly.addView(et);
        ly.addView(button_ok);
        if (temp_str != null) {
            et.setText(temp_str);
        }
    }
    else {
        temp_str = intent.getStringExtra("himi_zh");
        temp_str2 = intent.getStringExtra("himi_pass");
        rs.setTitle("您输入的信息:");
        tv.setText("帐号:" + temp_str + "n" + "密码" + temp_str2);
        ly.addView(tv);
        ly.addView(button_ok);
        if (temp_str != null) {
            et.setText(temp_str);
        }
    }
    setContentView(ly);
 }
}

以上代码可以看出,新建一个activity其实只需要继承Activity以及重写onCreate()方法即可。当然创建的还需要一步很重要的步骤,我会在第二步中会详细说明,这里我们看下是如何接受之前的activity传来数据的。

 代码如下 复制代码
Intent intent = this.getIntent();
count = (byte) intent.getIntExtra("count", 0);

接受也是很简明易懂,创建一个Intent 意图对象,调用来去getIntExtra函数得到之前传来的数据,根据key。当然还有getStringExtra()等等函数都是类似,只是根据你传入的数据不同选择不同函数罢了。同学们应该注意的是getIntExtra中第二个参数是什么意思,其实就是一个对于找不到key相匹配的时候会默认return 0;

那么下面介绍第二步:在配置中声明

当创建一个activity的时候我们必须在AndroidMainFeset.xml中去声明我们创建的这个类是个Activity。

本文章来给大家介绍关于android.os.BinderProxy cannot be cast to com解决办法,希望此文章对各位有帮助呀。

Android在绑定服务的时候出现java.lang.ClassCastException:android.os.BinderProxy cannot be cast to com.

修改manifest文件里边相关服务去掉android:process=":remote"即可。

本文章来给大家介绍在安卓手机开发中的常用文件操作代码,这里一个不错的文件操作类,希望对大家有所帮助哦。
 代码如下 复制代码


package cn.youxigu.files;
 
import cn.youxigu.service.*;
import android.app.Activity;
import android.os.Bundle;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import android.view.*;
 
public class MainActivity extends Activity {
 
    EditText filename;
    EditText content;
    Button   buttonsave;
    Button   buttonopen;
    Button   buttonsaveSdCard;
    Button   buttonopenSdCard;
 
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
 
        filename = (EditText)this.findViewById(R.id.filename);
        content  = (EditText)this.findViewById(R.id.content);
        //获取本地保存按钮
        buttonsave   = (Button)this.findViewById(R.id.buttonsave);
        //获取本地打开按钮
        buttonopen   = (Button)this.findViewById(R.id.buttonsaveopen);
 
        //获取SD卡保存按钮
        buttonsaveSdCard   = (Button)this.findViewById(R.id.buttonsavesdcard);
        //获取SD卡打开按钮
        buttonopenSdCard   = (Button)this.findViewById(R.id.buttonsaveopensdcard);
 
 
        buttonsave.setOnClickListener(new SaveFileClick());
 
        buttonopen.setOnClickListener(new OpenFileClick());
 
        buttonsaveSdCard.setOnClickListener(new SaveSdCardFileClick());
 
        buttonopenSdCard.setOnClickListener(new OpenSdCardFileClick());
 
    }
 
 
    /**
     * 保存到本地的存储
     * @author xiaolu
     *
     */    
    private final class SaveFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String files    = filename.getText().toString();
            String contents = content.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
            try{
                file.save(files, contents);
                Toast.makeText(getApplicationContext(), "保存成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "保存失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
 
    /**
     * 打开本地的存储
     * @author xiaolu
     *
     */
    private final class OpenFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String filenames    = filename.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
 
            try{
 
                String contents = file.read(filenames);
                //填充到文本框
                content.setText(contents);
 
                Toast.makeText(getApplicationContext(), "打开成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "打开失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
 
    /**
     * 保存到SD卡的存储
     * @author xiaolu
     *
     */    
    private final class SaveSdCardFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String files    = filename.getText().toString();
            String contents = content.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
            try{
                file.saveSdCard(files, contents);
                Toast.makeText(getApplicationContext(), "保存到SD卡成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "保存到SD卡失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
 
    /**
     * 打开SD卡的存储
     * @author xiaolu
     *
     */
    private final class OpenSdCardFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String filenames    = filename.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
 
            try{
 
                String contents = file.readSdCard(filenames);
                //填充到文本框
                content.setText(contents);
 
                Toast.makeText(getApplicationContext(), "打开SdCard成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "打开SdCard失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
}

 


FileService文件代码:
 

 代码如下 复制代码

package cn.youxigu.service;
 
 
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
 
import android.content.Context;
import android.os.Environment;
 
public class FileService {
 
    //获取上下文
    private Context context;
 
    public FileService(Context context){
        this.context = context;
    }
 
    /**
     * 读取本地存储文件内容
     * @param filename 文件名
     * @return 文件内容
     * @throws Exception
     */
 
    public String read(String filename) throws Exception{
 
         FileInputStream InputStream = context.openFileInput(filename);
 
         //申请写入内存
         ByteArrayOutputStream  outStream = new ByteArrayOutputStream();
 
         byte[] buffer = new byte[1024];
 
         int len = 0;
         while((len = InputStream.read(buffer)) != -1){
 
             outStream.write(buffer);
         }
 
         byte[] data = outStream.toByteArray();
 
         return new String(data);
    }
 
 
 
    /**
     * 保存到本地存储
     * @param filename 文件名
     * @param content  文件内容
     * @throws Exception
     */
    public void save(String filename, String content) throws Exception{
        FileOutputStream outStream = context.openFileOutput(filename, Context.MODE_PRIVATE);
 
        outStream.write(content.getBytes());
        outStream.close();      
    }
 
 
    /**
     * 保存到SdCard存储
     * @param filename 文件名
     * @param content  文件内容
     * @throws Exception
     */
    public void saveSdCard(String filename, String content) throws Exception{
 
        //获取SD卡路径
        File sdCardDir = Environment.getExternalStorageDirectory();
 
        File saveFile = new File(sdCardDir, filename);
 
        FileOutputStream outStream = new FileOutputStream(saveFile);
 
        outStream.write(content.getBytes());
 
        outStream.close();
 
    }
 
 
    /**
     * 读取SdCard存储文件内容
     * @param filename 文件名
     * @return 文件内容
     * @throws Exception
     */
 
    public String readSdCard(String filename) throws Exception{
 
        //获取SD卡路径
         File sdCardDir = Environment.getExternalStorageDirectory();
 
         File openFile = new File(sdCardDir, filename);
 
         //用输入流对象进行读取数据
         FileInputStream InputStream = new FileInputStream(openFile);
 
         //申请写入内存
         ByteArrayOutputStream  outStream = new ByteArrayOutputStream();
 
         byte[] buffer = new byte[1024];
 
         int len = 0;
 
         while((len = InputStream.read(buffer)) != -1){
 
             outStream.write(buffer);
         }
 
 
         byte[] data = outStream.toByteArray();
 
         return new String(data);
    }
 
 
 
}

 


main.xml 文件代码:
 

 代码如下 复制代码
<?xml version=“1.0″ encoding=“utf-8″?>
<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”
    android:layout_width=“fill_parent”
    android:layout_height=“fill_parent”
    android:orientation=“vertical” >
    <TextView
        android:layout_width=“fill_parent”
        android:layout_height=“wrap_content”
       
        android:text=“@string/filenametext” />
    <EditText
        android:layout_width=“fill_parent”
        android:layout_height=“wrap_content”
        android:id=“@+id/filename”/>
   
    <EditText
        android:layout_width=“fill_parent”
        android:layout_height=“wrap_content”
           android:minLines=“3″
           android:id=“@+id/content”/>
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonsave”
        android:id=“@+id/buttonsave”
        />
   
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonopen”
        android:id=“@+id/buttonsaveopen”
        />
   
   
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonsavesdcard”
        android:id=“@+id/buttonsavesdcard”
        />
   
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonopensdcard”
        android:id=“@+id/buttonsaveopensdcard”
        />
</LinearLayout>
[!--infotagslink--]

相关文章

  • 图解PHP使用Zend Guard 6.0加密方法教程

    有时为了网站安全和版权问题,会对自己写的php源码进行加密,在php加密技术上最常用的是zend公司的zend guard 加密软件,现在我们来图文讲解一下。 下面就简单说说如何...2016-11-25
  • Android子控件超出父控件的范围显示出来方法

    下面我们来看一篇关于Android子控件超出父控件的范围显示出来方法,希望这篇文章能够帮助到各位朋友,有碰到此问题的朋友可以进来看看哦。 <RelativeLayout xmlns:an...2016-10-02
  • ps怎么使用HSL面板

    ps软件是现在很多人都会使用到的,HSL面板在ps软件中又有着非常独特的作用。这次文章就给大家介绍下ps怎么使用HSL面板,还不知道使用方法的下面一起来看看。 &#8195;...2017-07-06
  • c# 三种方法调用WebService接口

    这篇文章主要介绍了c# 三种方法调用WebService接口的相关资料,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下...2020-07-07
  • C#使用Http Post方式传递Json数据字符串调用Web Service

    这篇文章主要为大家详细介绍了C#使用Http Post方式传递Json数据字符串调用Web Service,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-06-25
  • Plesk控制面板新手使用手册总结

    许多的朋友对于Plesk控制面板应用不是非常的了解特别是英文版的Plesk控制面板,在这里小编整理了一些关于Plesk控制面板常用的使用方案整理,具体如下。 本文基于Linu...2016-10-10
  • 使用insertAfter()方法在现有元素后添加一个新元素

    复制代码 代码如下: //在现有元素后添加一个新元素 function insertAfter(newElement, targetElement){ var parent = targetElement.parentNode; if (parent.lastChild == targetElement){ parent.appendChild(newEl...2014-05-31
  • Android开发中findViewById()函数用法与简化

    findViewById方法在android开发中是获取页面控件的值了,有没有发现我们一个页面控件多了会反复研究写findViewById呢,下面我们一起来看它的简化方法。 Android中Fin...2016-09-20
  • Android模拟器上模拟来电和短信配置

    如果我们的项目需要做来电及短信的功能,那么我们就得在Android模拟器开发这些功能,本来就来告诉我们如何在Android模拟器上模拟来电及来短信的功能。 在Android模拟...2016-09-20
  • 使用GruntJS构建Web程序之构建篇

    大概有如下步骤 新建项目Bejs 新建文件package.json 新建文件Gruntfile.js 命令行执行grunt任务 一、新建项目Bejs源码放在src下,该目录有两个js文件,selector.js和ajax.js。编译后代码放在dest,这个grunt会...2014-06-07
  • 使用percona-toolkit操作MySQL的实用命令小结

    1.pt-archiver 功能介绍: 将mysql数据库中表的记录归档到另外一个表或者文件 用法介绍: pt-archiver [OPTION...] --source DSN --where WHERE 这个工具只是归档旧的数据,不会对线上数据的OLTP查询造成太大影响,你可以将...2015-11-24
  • 夜神android模拟器设置代理的方法

    夜神android模拟器如何设置代理呢?对于这个问题其实操作起来是非常的简单,下面小编来为各位详细介绍夜神android模拟器设置代理的方法,希望例子能够帮助到各位。 app...2016-09-20
  • 如何使用php脚本给html中引用的js和css路径打上版本号

    在搜索引擎中搜索关键字.htaccess 缓存,你可以搜索到很多关于设置网站文件缓存的教程,通过设置可以将css、js等不太经常更新的文件缓存在浏览器端,这样访客每次访问你的网站的时候,浏览器就可以从浏览器的缓存中获取css、...2015-11-24
  • android自定义动态设置Button样式【很常用】

    为了增强android应用的用户体验,我们可以在一些Button按钮上自定义动态的设置一些样式,比如交互时改变字体、颜色、背景图等。 今天来看一个通过重写Button来动态实...2016-09-20
  • Android WebView加载html5页面实例教程

    如果我们要在Android应用APP中加载html5页面,我们可以使用WebView,本文我们分享两个WebView加载html5页面实例应用。 实例一:WebView加载html5实现炫酷引导页面大多...2016-09-20
  • jQuery 1.9使用$.support替代$.browser的使用方法

    jQuery 从 1.9 版开始,移除了 $.browser 和 $.browser.version , 取而代之的是 $.support 。 在更新的 2.0 版本中,将不再支持 IE 6/7/8。 以后,如果用户需要支持 IE 6/7/8,只能使用 jQuery 1.9。 如果要全面支持 IE,并混合...2014-05-31
  • 安装和使用percona-toolkit来辅助操作MySQL的基本教程

    一、percona-toolkit简介 percona-toolkit是一组高级命令行工具的集合,用来执行各种通过手工执行非常复杂和麻烦的mysql和系统任务,这些任务包括: 检查master和slave数据的一致性 有效地对记录进行归档 查找重复的索...2015-11-24
  • 深入理解Android中View和ViewGroup

    深入理解Android中View和ViewGroup从组成架构上看,似乎ViewGroup在View之上,View需要继承ViewGroup,但实际上不是这样的。View是基类,ViewGroup是它的子类。本教程我们深...2016-09-20
  • MySQL日志分析软件mysqlsla的安装和使用教程

    一、下载 mysqlsla [root@localhost tmp]# wget http://hackmysql.com/scripts/mysqlsla-2.03.tar.gz--19:45:45-- http://hackmysql.com/scripts/mysqlsla-2.03.tar.gzResolving hackmysql.com... 64.13.232.157Conn...2015-11-24
  • Android自定义WebView网络视频播放控件例子

    下面我们来看一篇关于Android自定义WebView网络视频播放控件开发例子,这个文章写得非常的不错下面给各位共享一下吧。 因为业务需要,以下代码均以Youtube网站在线视...2016-10-02