zoukankan      html  css  js  c++  java
  • Android中的复制粘贴

     

     

    Android中的复制粘贴

    The Clipboard Framework

      当使用clipboard framework时,把数据放在一个剪切对象(clip object)里,然后这个对象会放在系统的剪贴板里。

      clip object可以有三种形式:

      Text:文字字符串。

      文字是直接放在clip对象中,然后放在剪贴板里;粘贴这个字符串的时候直接从剪贴板拿到这个对象,把字符串放入你的应用存储中。

      URI:一个Uri 对象。

      表示任何形式的URI。这种形式主要用于从一个content provider中复制复杂的数据。

      复制的时候把一个Uri 对象放在一个clip对象中,然后再放在剪贴板里;粘贴的时候取出这个clip对象,得到Uri,把它解析为一个数据资源比如content provider,然后从资源中复制数据到应用存储中。

      Intent: Intent对象。

      这支持了复制应用快捷方式。

      复制的时候把Intent对象放在clip对象中,再放入剪贴板;粘贴数据时,从clip对象中得到Intent对象,放入应用存储区域中。

      剪贴板每次仅会持有一个clip对象,当应用放另一个clip对象进来时,前一个就消失了。

     

    剪贴板的类

    ClipboardManager

      ClipboardManager代表了系统的剪贴板,通过getSystemService(CLIPBOARD_SERVICE)获取。

      全名为android.text.ClipboardManager从API 11开始就废弃了。

      取而代之的是它的子类:android.content.ClipboardManager (since API Level 11)。

    ClipData, ClipDescription, and ClipData.Item

      前面说的clip对象就是ClipData类的对象,其中包含了一个 ClipDescription对象和一个或多个ClipData.Item对象。

      ClipDescription对象中包含了一个数组,描述clip对象的MIME类型。

      ClipData.Item对象中包含文字、URI或者Intent数据。一个clip对象中可以包含一个或多个Item对象

      比如你想要复制list中的多项数据,你可以为list中的每一项创建一个ClipData.Item对象,然后把它们放进一个ClipData对象中,这样就一次性把多项数据都放在了剪贴板中。

      注意ClipData这个类是API 11才有的。

    ClipData中的简洁方法

      ClipData类中有一些静态的简洁方法,用于创建只有一个ClipData.Item和一条简单描述( ClipDescription)的ClipData对象。

      newPlainText(label, text)返回ClipData对象,数据是文字text,描述是label,MIME类型是MIMETYPE_TEXT_PLAIN

      类似的有:

      newUri(resolver, label, URI)

      newIntent(label, intent)

    把剪贴板中的数据强转为文字

      剪贴板中的非text数据可以通过ClipData.Item.coerceToText()方法转换为text处理。

      1.这个方法首先会检测item是不是包含text,如果有就直接返回。

      2.不包含text,之后看是否有URI:

      如果这个URI是content URI,并且provider返回文字流,coerceToText()就返回该文字流;

      如果provider不返回文字流,或者这个URI根本不是content URI,coerceToText()方法会返回URI的表达,即 Uri.toString()

      3.最后,如果这个item即不包含text也没有URI,那么它就应该包含Intent, coerceToText() 方法会把Intent对象转化为一个Intent URI返回,  和 Intent.toUri(URI_INTENT_SCHEME)一样。

    Android clipboard framework总结

      如图:

     

    复制到剪贴板

      1.首先,获取剪贴板服务:

    // Gets a handle to the clipboard service.
    ClipboardManager clipboard = (ClipboardManager)
            getSystemService(Context.CLIPBOARD_SERVICE);

      2.然后把数据放在ClipData对象中。

      对文字:

    // Creates a new text clip to put on the clipboard
    ClipData clip = ClipData.newPlainText("simple text","Hello, World!");

      对URI:

    复制代码
    // Creates a Uri based on a base Uri and a record ID based on the contact's last name
    // Declares the base URI string
    private static final String CONTACTS = "content://com.example.contacts";
    
    // Declares a path string for URIs that you use to copy data
    private static final String COPY_PATH = "/copy";
    
    // Declares the Uri to paste to the clipboard
    Uri copyUri = Uri.parse(CONTACTS + COPY_PATH + "/" + lastName);
    
    ...
    
    // Creates a new URI clip object. The system uses the anonymous getContentResolver() object to
    // get MIME types from provider. The clip object's label is "URI", and its data is
    // the Uri previously created.
    ClipData clip = ClipData.newUri(getContentResolver(),"URI",copyUri);
    复制代码

      对Intent:

    复制代码
    // Creates the Intent
    Intent appIntent = new Intent(this, com.example.demo.myapplication.class);
    
    ...
    
    // Creates a clip object with the Intent in it. Its label is "Intent" and its data is
    // the Intent object created previously
    ClipData clip = ClipData.newIntent("Intent",appIntent);
    复制代码

      3.把clip对象放在剪贴板中:

    // Set the clipboard's primary clip.
    clipboard.setPrimaryClip(clip);
     

    从剪贴板中粘贴

      以文字的粘贴为例,其他略。

      例子如下:

    复制代码
    package com.example.helloclipboard;
    
    import android.os.Bundle;
    import android.app.Activity;
    import android.content.ClipData;
    import android.content.ClipboardManager;
    import android.content.Context;
    import android.util.Log;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.TextView;
    import android.widget.Toast;
    
    public class HelloClipboardMainActivity extends Activity {
    
        private EditText mEditText1 = null;
        private TextView mResultTextView = null;
    
        private ClipboardManager mClipboard = null;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_hello_clipboard_main);
    
            mResultTextView = (TextView) findViewById(R.id.textView1);
            mEditText1 = (EditText) findViewById(R.id.editText1);
            Button copyButton = (Button) findViewById(R.id.button1);
    
            Button pasteButton = (Button) findViewById(R.id.button2);
    
            copyButton.setOnClickListener(mOnClickListener);
            pasteButton.setOnClickListener(mOnClickListener);
    
        }
    
        private OnClickListener mOnClickListener = new OnClickListener() {
    
            @Override
            public void onClick(View v) {
    
                switch (v.getId()) {
                case R.id.button1:
                    copyFromEditText1();
                    break;
                case R.id.button2:
                    pasteToResult();
                    break;
    
                default:
                    break;
                }
            }
        };
    
        private void copyFromEditText1() {
    
            // Gets a handle to the clipboard service.
            if (null == mClipboard) {
                mClipboard = (ClipboardManager) getSystemService(Context.CLIPBOARD_SERVICE);
    
            }
    
            // Creates a new text clip to put on the clipboard
            ClipData clip = ClipData.newPlainText("simple text",
                    mEditText1.getText());
    
            // Set the clipboard's primary clip.
            mClipboard.setPrimaryClip(clip);
        }
    
        private void pasteToResult() {
            // Gets a handle to the clipboard service.
            if (null == mClipboard) {
                mClipboard = (ClipboardManager) getSystemService(Context.CLIPBOARD_SERVICE);
            }
    
            String resultString = "";
            // 检查剪贴板是否有内容
            if (!mClipboard.hasPrimaryClip()) {
                Toast.makeText(HelloClipboardMainActivity.this,
                        "Clipboard is empty", Toast.LENGTH_SHORT).show();
            }
            else {
                ClipData clipData = mClipboard.getPrimaryClip();
                int count = clipData.getItemCount();
    
                for (int i = 0; i < count; ++i) {
    
                    ClipData.Item item = clipData.getItemAt(i);
                    CharSequence str = item
                            .coerceToText(HelloClipboardMainActivity.this);
                    Log.i("mengdd", "item : " + i + ": " + str);
    
                    resultString += str;
                }
    
            }
            mResultTextView.setText(resultString);
        }
    }
    复制代码

    设计有效的复制粘贴功能

      为了设计有效的复制粘贴功能,以下几点需要注意:

      1.任何时间,都只有一个clip对象在剪贴板里。

      新的复制操作都会覆盖前一个clip对象,因为用户可能从你的应用中退出,从其他应用中拷贝一个东西,所以你不能假定用户在你的应用中拷贝的上一个东西一定还放在剪贴板里。

      2.一个clip对象,即ClipData中的多个ClipData.Item 对象是为了支持多选项的复制粘贴,而不是为了支持单选的多种形式。

      你通常需要clip对象中的所有的项目,即ClipData.Item有一样的形式,比如都是文字,都是URI或都是Intent,而不是混合各种形式。

      3.当你提供数据时,你可以提供不同的MIME表达方式。

      将你支持的MIME类型加入到ClipDescription中去,然后在你的content provider中实现它。

      4.当你从剪贴板得到数据时,你的应用有责任检查可用的MIME类型,然后决定使用哪一个。

      即便有一个clip对象在剪贴板中并且用户要求粘贴,你的应用有可能不需要进行粘贴操作。

      你应该在MIME类型兼容的时候执行粘贴操作。你可以选择使用 coerceToText()方法将粘贴的内容转换为文字。

      如果你的应用支持多种类型,你可以让用户自己选用哪一个。

    参考资料

      API Guides: Copy and Paste:

      http://developer.android.com/guide/topics/text/copy-paste.html

     
    分类: Android
    标签: Android
    好文要顶 关注我 收藏该文  
    2
    0
     
    (请您对文章做出评价)
     
    « 上一篇:Android PopupWindow的使用和分析
    » 下一篇:Windows下修改Android手机的hosts
    http://www.cnblogs.com/mengdd/p/3572316.html
  • 相关阅读:
    Azure 中 Linux 虚拟机的大小
    排查在 Azure 中创建、重启 Linux VM 或调整其大小时发生的分配故障
    如何在 Azure 中的 Linux 经典虚拟机上设置终结点
    针对通过 SSH 连接到 Azure Linux VM 时发生的失败、错误或被拒绝问题进行故障排除
    Linux 内核超时导致虚拟机无法正常启动
    Java并发编程(十三)同步容器类
    可以开发着玩一下的web项目
    org.tmatesoft.svn.core.SVNCancelException: svn: E200015: authentication canc
    FastDFS单机搭建以及java客户端Demo
    做前端(单纯页面和js)遇到的问题辑录(一)
  • 原文地址:https://www.cnblogs.com/pengmn/p/5228124.html
Copyright © 2011-2022 走看看