Android剪贴板

2024-08-30 15:58
文章标签 android 剪贴板

本文主要是介绍Android剪贴板,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当我们用剪切板的时候我们首先应该获得ClipboardManager对象,但是我们值得注意的是Android在3.0之前ClipboardManager在android.text.ClipboardManager包内,在3.0之后

在android.content.ClipboardManager包内

下面是代码

  if (android.os.Build.VERSION.SDK_INT > 11) {
     android.content.ClipboardManager c = (android.content.ClipboardManager) getSystemService(CLIPBOARD_SERVICE);
     c.setText(activitioncode.getText());

    } else {
     android.text.ClipboardManager c = (android.text.ClipboardManager) getSystemService(CLIPBOARD_SERVICE);

     c.setText(activitioncode.getText());
    }

往clipboard里面设置值我们可以 c.setText(text)


前段时间忙着学东西做东西,这几天小马有时间就拿来学习下官方的文档,里面好东西太多了,今天看到了Clip,反正不懂,小马带着无耻的好奇心,做了个DEMO,先讲下注意的一点,就是在使用Android剪贴板的时候大家只记住一点就行了,不管是安卓设备还是PC机,复制粘贴在同一时间里只能用于一个对象上,整通俗点就是:PC机上,不可能同时从C盘复制,又从D盘复制就行了,具体的看代码,很简单,直接上代码:
 
1. package com.xiaoma.clipboard.demo;
2. 
3. import android.app.Activity;
4. import android.content.ClipData;
5. import android.content.ClipData.Item;
6. import android.content.ClipDescription;
7. import android.content.ClipboardManager;
8. import android.content.ContentResolver;
9. import android.content.Intent;
10. import android.database.Cursor;
11. import android.net.Uri;
12. import android.os.Bundle;
13. import android.view.View;
14. import android.view.View.OnClickListener;
15. import android.widget.Button;
16. import android.widget.Toast;
17. 
18. /**  
19. * @Title: ClipBoardDemoActivity.java
20. * @Package com.xiaoma.clipboard.demo
21. * @Description: 剪贴板学习
22. * @author MZH
23. */
24. public class ClipBoardDemoActivity extends Activity implements OnClickListener{
25.     
26.     private Button put = null;
27.     private Button get = null;
28.     private ClipboardManager clipboard = null;
29.     private static final String CONTACTS = "content://com.example.contacts";
30.     private String COPY_PATH = "/copy";
31.     public static final String MIME_TYPE_CONTACT = "vnd.android.cursor.item/vnd.xiaoma.contact";
32.     @Override
33.     public void onCreate(Bundle savedInstanceState) {
34.         super.onCreate(savedInstanceState);
35.         setContentView(R.layout.main);
36.         init();
37.     }
38.     
39.     /**
40.      * 初始化方法实现
41.      */
42.     private void init(){
43.         put = (Button)findViewById(R.id.button1);
44.         put.setOnClickListener(this);
45.         
46.         get = (Button)findViewById(R.id.button2);
47.         get.setOnClickListener(this);
48.     }
49.     
50.     /**
51.      * 监听实现
52.      */
53.     @Override
54.     public void onClick(View v) {
55.         switch (v.getId()) {
56.         case R.id.button1:
57.             put();
58.             break;
59.         case R.id.button2:
60.             get();
61.             break;
62.         default:
63.             break;
64.         }
65.     }
66.     
67.     /**
68.      * 往Clip中放入数据
69.      */
70.     private void put(){
71.         
72.         /**
73.          * 往ClipboardManager中可放的数据类型有三种:
74.          * 因为大家都知道,就算是电脑,Ctrl+c也不可能在同一时间里即
75.          * 从C盘剪贴,又从D般剪贴,所以小马只写一种简单的信息进去,
76.          * 另外两种写在注释中
77.         
78.         //类型一:text
79.         clipboard = (ClipboardManager)getSystemService(CLIPBOARD_SERVICE);
80.         ClipData textCd = ClipData.newPlainText("kkk", "WaHouHou!Clip....");
81.         clipboard.setPrimaryClip(textCd);
82.          */
83.         /**
84.          * 
85.         //类型二:URI
86.         Uri copyUri = Uri.parse(CONTACTS + COPY_PATH + "/" + "XiaoMa");
87.         ClipData clipUri = ClipData.newUri(getContentResolver(),"URI",copyUri);
88.         clipboard.setPrimaryClip(clipUri);
89.         *
90.         */
91.         //类型三:Intent
92.         //试下在Intent剪贴时使用Bundle传值进去
93.         clipboard = (ClipboardManager)getSystemService(CLIPBOARD_SERVICE);
94.         Intent appIntent = new Intent();
95.         Bundle bundle = new Bundle();
96.         bundle.putInt("xiaoma", 3344258);
97.         bundle.putInt("yatou", 3344179);
98.         appIntent.putExtra("XiaoMaGuo", bundle);
99.         appIntent.setClass(ClipBoardDemoActivity.this, ReceiverClip.class);
100.         ClipData clipIntent = ClipData.newIntent("Intent",appIntent);
101.         clipboard.setPrimaryClip(clipIntent);
102.     }
103.     
104.     /**
105.      * 从Clip中取数据
106.      */
107.     private void get(){
108.         clipboard = (ClipboardManager)getSystemService(CLIPBOARD_SERVICE);
109.         Item item = null;
110.         
111.         //无数据时直接返回
112.         if(!clipboard.hasPrimaryClip()){
113.             Toast.makeText(getApplicationContext(), "剪贴板中无数据", Toast.LENGTH_SHORT).show();
114.             return ;
115.         } 
116.         
117.         //如果是文本信息
118.         if (clipboard.getPrimaryClipDescription().hasMimeType(
119.                 ClipDescription.MIMETYPE_TEXT_PLAIN)) {
120.             ClipData cdText = clipboard.getPrimaryClip();
121.             item = cdText.getItemAt(0);
122.             //此处是TEXT文本信息
123.             if(item.getText() == null){
124.                 Toast.makeText(getApplicationContext(), "剪贴板中无内容", Toast.LENGTH_SHORT).show();
125.                 return ;
126.             }else{
127.                 Toast.makeText(getApplicationContext(), item.getText(), Toast.LENGTH_SHORT).show();
128.             }
129. 
130.         //如果是INTENT
131.         } else if (clipboard.getPrimaryClipDescription().hasMimeType(
132.                 ClipDescription.MIMETYPE_TEXT_INTENT)) {
133.             //此处是INTENT
134.             item = clipboard.getPrimaryClip().getItemAt(0);
135.             Intent intent = item.getIntent();
136.             startActivity(intent);
137.             //........
138.         
139.         //如果是URI
140.         } else if (clipboard.getPrimaryClipDescription().hasMimeType(
141.                 ClipDescription.MIMETYPE_TEXT_URILIST)) {
142.             //此处是URI内容www.2cto.com
143.             ContentResolver cr = getContentResolver();
144.             ClipData cdUri = clipboard.getPrimaryClip();
145.             item = cdUri.getItemAt(0);
146.             Uri uri = item.getUri();
147.             if(uri != null){
148.                 String mimeType = cr.getType(uri);
149.                 if (mimeType != null) {
150.                     if (mimeType.equals(MIME_TYPE_CONTACT)) {
151.                         Cursor pasteCursor = cr.query(uri, null, null, null, null);
152.                         if (pasteCursor != null) {
153.                             if (pasteCursor.moveToFirst()) {
154.                                  //此处对数据进行操作就可以了,前提是有权限
155.                             }
156.                         }
157.                         pasteCursor.close();
158.                      }
159.                  }
160.             }
161.         }
162.     }
163. }
   下面是用来接收Intent传递的值,临时的一个Activity,代码更简单:
 
1. package com.xiaoma.clipboard.demo;
2. 
3. import android.app.Activity;
4. import android.content.Intent;
5. import android.os.Bundle;
6. import android.view.TextureView;
7. import android.widget.TextView;
8. 
9. /**
10.  * @Title: ReceiverClip.java
11.  * @Package com.xiaoma.clipboard.demo
12.  * @Description:临时用来接收下从Clip传过来的Intent值
13.  * @author MZH
14.  */
15. public class ReceiverClip extends Activity {
16.     
17.     private TextView tv1 ; 
18.     private TextView tv2 ;
19.     
20.     @Override
21.     protected void onCreate(Bundle savedInstanceState) {
22.         // TODO Auto-generated method stub
23.         super.onCreate(savedInstanceState);
24.         setContentView(R.layout.main2);
25.         init();
26.     }
27.     
28.     private void init(){
29.         
30.         tv1 = (TextView)findViewById(R.id.xiaoma);
31.         tv2 = (TextView)findViewById(R.id.yatou);
32.         
33.         Intent intent = getIntent();
34.         Bundle b =intent.getBundleExtra("XiaoMaGuo");
35.         if(b != null){
36.             int xiaoma = b.getInt("xiaoma");
37.             int yatou = b.getInt("yatou");
38.             if(!"".equals(String.valueOf(xiaoma)) && !"".equals(String.valueOf(yatou))){
39.                 tv1.setText(String.valueOf(xiaoma));
40.                 tv2.setText(String.valueOf(yatou));
41.             }
42.         }
43.     }
44. }
  全局配置文件里面没什么,如下:
 
1. <?xml version="1.0" encoding="utf-8"?>
2. <manifest xmlns:android=""
3.     package="com.xiaoma.clipboard.demo"
4.     android:versionCode="1"
5.     android:versionName="1.0" >
6. 
7.     <uses-sdk android:minSdkVersion="14" />
8. 
9.     <application
10.         android:icon="@drawable/guoguo"
11.         android:label="@string/app_name" >
12.         <activity
13.             android:name=".ClipBoardDemoActivity"
14.             android:label="@string/app_name" >
15.             <intent-filter>
16.                 <action android:name="android.intent.action.MAIN" />
17. 
18.                 <category android:name="android.intent.category.LAUNCHER" />
19.             </intent-filter>
20.         </activity>
21.         <activity android:name=".ReceiverClip"></activity>
22.     </application>
23. 
24. </manifest>
    如果因为没效果图看不爽的话,朋友们可以直接下载小马写的DEMO,代码很简单,大牛跳过,跟小马一样的菜菜可以学习交流下,吼吼...老规矩,如有小马讲不清楚的地方,还请朋友直接批评指点,有错必改,共同提高进步,谢谢

摘自  酷_莫名简单

Android学习交流群:523487222

(欢迎加入,一起学习进步)
点击链接加入群【Android学习群】

这篇关于Android剪贴板的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121275

相关文章

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

android应用中res目录说明

Android应用的res目录是一个特殊的项目,该项目里存放了Android应用所用的全部资源,包括图片、字符串、颜色、尺寸、样式等,类似于web开发中的public目录,js、css、image、style。。。。 Android按照约定,将不同的资源放在不同的文件夹中,这样可以方便的让AAPT(即Android Asset Packaging Tool , 在SDK的build-tools目

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR