简介
记录一个利用系统分享功能进行图片分享的工具类(代码是用Kotlin写的,都是比较简单的语法,部分可能需要自定义的地方都已经标出)。调用方式比较简单:
Util.startShareImage(this) //this为当前的Activity实例
权限
记得添加文件操作权限, 另外需要注意6.0版本以上的权限管理
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
具体细节见代码
/** * 系统分享图片功能 * Created by wiky on 2018/1/13. */ object Util { fun startShareImage(activity: Activity) { //过滤出需要分享到对应的平台:微信好友、朋友圈、QQ好友。 可自行修改 val targetApp = arrayOf("com.tencent.mm.ui.tools.ShareImgUI", "com.tencent.mm.ui.tools.ShareToTimeLineUI", "com.tencent.mobileqq.activity.JumpActivity") /** * 分享图片 */ val bitmap = getImageFromAssetsFile(activity, "img_share.jpg") //从assets目录中取到对应的文件,文件名自行修改 val localImage = saveBitmap(bitmap!!, "share.jpg") //分享前,需要先将图片存在本地(记得添加权限),文件名自行修改 val shareIntent = Intent(Intent.ACTION_SEND) shareIntent.type = "image/*" //设置分享内容的类型:图片 shareIntent.putExtra(Intent.EXTRA_STREAM, localImage) try { val resInfo = activity.packageManager.queryIntentActivities(shareIntent, 0) if (!resInfo.isEmpty()) { val targetedShareIntents = ArrayList<Intent>() for (info in resInfo) { val targeted = Intent(Intent.ACTION_SEND) targeted.type = "image/*" //设置分享内容的类型 val activityInfo = info.activityInfo //如果还需要分享至其它平台,可以打印出具体信息,然后找到对应的Activity名称,填入上面的数组中即可 // println("package = ${activityInfo.packageName}, activity = ${activityInfo.name}") //进行过滤(只显示需要分享的平台) if (targetApp.any { it == activityInfo.name }) { val comp = ComponentName(activityInfo.packageName, activityInfo.name) targeted.component = comp targeted.putExtra(Intent.EXTRA_STREAM, localImage) targetedShareIntents.add(targeted) } } val chooserIntent = Intent.createChooser(targetedShareIntents.removeAt(0), "选择要分享到的平台") if (chooserIntent != null) { chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, targetedShareIntents.toTypedArray<Parcelable>()) activity.startActivity(chooserIntent) } } } catch (e: Exception) { Log.e(StatConstants.LOG_TAG, "Unable to share image, logs : " + e.toString()) } } /** * 从Assets中读取图片 */ private fun getImageFromAssetsFile(context: Context, fileName: String): Bitmap? { var image: Bitmap? = null val am = context.resources.assets try { val inputStream = am.open(fileName) image = BitmapFactory.decodeStream(inputStream) inputStream.close() } catch (e: IOException) { e.printStackTrace() } return image } /** * 将图片存到本地 */ private fun saveBitmap(bm: Bitmap, picName: String): Uri? { try { val dir = Environment.getExternalStorageDirectory().absolutePath + File.separator + picName val f = File(dir) if (!f.exists()) { f.parentFile.mkdirs() f.createNewFile() } val out = FileOutputStream(f) bm.compress(Bitmap.CompressFormat.JPEG, 90, out) out.flush() out.close() return Uri.fromFile(f) } catch (e: FileNotFoundException) { e.printStackTrace() } catch (e: IOException) { e.printStackTrace() } return null } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Android系统自带分享图片功能,包括了Android系统自带分享图片功能的使用技巧和注意事项,需要的朋友参考一下 简介 记录一个利用系统分享功能进行图片分享的工具类(代码是用Kotlin写的,都是比较简单的语法,部分可能需要自定义的地方都已经标出)。调用方式比较简单: 权限 记得添加文件操作权限, 另外需要注意6.0版本以上的权限管理 具体细节见代码 以上就是本文的全部内容,希望
Clex —— 命令行文件管理器 Clex是基于命令行的文件管理器,具有详细的目录列表、目录比较、简单编辑等特性。 Clex是一个轻快、易用的文件管理器,可以通过/.clexrc 和 ~/.clexbm(书签)设置,或者在程序中按下Ctrl+G打开设置面板。要在命令行或者终端里启动Clex: $ clex PCManFM PCmanFM是一个十分有用的文件管理工具,它可以管理设备、在当前 文件夹打
Curl Validate File Random
构建商城功能插件大全 打开后台-设置-系统工具 1.插件管理 功能性的插件,下载可使用 2.钩子管理 3.系统菜单 商家可自行编辑,后台打开时所展示的类别 4.数据备份 数据库备份,以防万一,点击按钮直接备份或修复 5.数据恢复 数据丢失或损伤之后的恢复 6.数据表缓存和类库缓存的更新 1.数据表缓存 数据表缓存是针对系统数据表结构进行缓存,这样系统查询就不用进行数据表字段查询,这样大大提高了系统
EasySwoole提供了基础的数据校验。 $data = array( "a"=>1, "b"=>array( "age"=>2, "b2"=>null ), "c"=>array( "age"=>3, "b2"=>"asas" ), "URL"=>'http://www.baidu.
为了让开发者能更便捷的调用cURL,easySwoole对cURL进行了封装,先来个例子感受一下 use CoreUtilityCurlRequest; // 获取快递100接口数据 $param = ['type' => 'zhongtong', 'postid' => '457500981717']; $url = 'http://www.kuaidi100.com/query?' . htt