Android 分享控件的實現(xiàn)代碼
如今很多應(yīng)用都提供向外分享信息的功能,在進行分享操作時,一般是從屏幕底部彈出所有具備分享功能的應(yīng)用列表,再由用戶進行選擇
現(xiàn)在我就來模仿實現(xiàn)這種效果,不僅使分享控件從屏幕底部彈出,還要使分享控件能夠上下拖動,這就需要使用到 design 包提供的 BottomSheetDialog 控件了
首先,聲明 BottomSheetDialog
對話框的主布局 dialog_bottom_sheet.xml
當(dāng)中,RecyclerView 用于展示提供分享功能的應(yīng)用列表
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="14dp" android:orientation="vertical"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="14dp" android:text="進一步的說明 -> leavesC" android:textAppearance="@style/TextAppearance.AppCompat" android:textSize="16sp"/> <View android:layout_width="match_parent" android:layout_height="0.6dp" android:background="#ddd"/> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="12dp" android:paddingStart="14dp" android:text="分享文本信息到..." android:textAppearance="@style/TextAppearance.AppCompat" android:textSize="14sp"/> <android.support.v7.widget.RecyclerView android:id="@+id/rv_appList" android:layout_width="match_parent" android:layout_height="match_parent"/> </LinearLayout>
RecyclerView 單個子項使用的布局 item_app.xml
<?xml version="1.0" encoding="utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="wrap_content" android:paddingBottom="8dp" android:paddingLeft="16dp" android:paddingRight="16dp" android:paddingTop="8dp"> <ImageView android:id="@+id/iv_appIcon" android:layout_width="50dp" android:layout_height="50dp" android:scaleType="centerCrop" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" tools:src="@mipmap/ic_launcher"/> <TextView android:id="@+id/tv_appName" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="3dp" android:ellipsize="end" android:maxLength="6" android:textSize="12sp" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@id/iv_appIcon" tools:text="之乎者也"/> </android.support.constraint.ConstraintLayout>
RecyclerView 配套使用的 Adapter : AppShareAdapter
/** * 作者:葉應(yīng)是葉 * 時間:2018/3/28 20:30 * 描述:https://github.com/leavesC */ public class AppShareAdapter extends RecyclerView.Adapter<AppShareAdapter.ViewHolder> { public interface OnClickListener { void onClick(int position); } public interface OnLongClickListener { void onLongClick(int position); } private List<App> appList; private LayoutInflater layoutInflater; private OnClickListener clickListener; private OnLongClickListener longClickListener; AppShareAdapter(Context context, List<App> appList) { this.layoutInflater = LayoutInflater.from(context); this.appList = appList; } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = layoutInflater.inflate(R.layout.item_app, parent, false); return new AppShareAdapter.ViewHolder(view); } @Override public void onBindViewHolder(final ViewHolder holder, int position) { holder.iv_appIcon.setBackground(appList.get(position).getAppIcon()); holder.tv_appName.setText(appList.get(position).getAppName()); holder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (clickListener != null) { clickListener.onClick(holder.getAdapterPosition()); } } }); holder.itemView.setOnLongClickListener(new View.OnLongClickListener() { @Override public boolean onLongClick(View v) { if (longClickListener != null) { longClickListener.onLongClick(holder.getAdapterPosition()); } return true; } }); } @Override public int getItemCount() { return appList.size(); } void setClickListener(OnClickListener clickListener) { this.clickListener = clickListener; } void setLongClickListener(OnLongClickListener longClickListener) { this.longClickListener = longClickListener; } class ViewHolder extends RecyclerView.ViewHolder { private ImageView iv_appIcon; private TextView tv_appName; ViewHolder(View itemView) { super(itemView); iv_appIcon = itemView.findViewById(R.id.iv_appIcon); tv_appName = itemView.findViewById(R.id.tv_appName); } } }
利用 Intent 找出所有提供分享功能的應(yīng)用,初始化 BottomSheetDialog 即可
/** * 作者:葉應(yīng)是葉 * 時間:2018/3/28 20:30 * 描述:https://github.com/leavesC */ public class MainActivity extends AppCompatActivity { private List<App> appList; private BottomSheetDialog bottomSheetDialog; private Intent shareIntent; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); shareIntent = new Intent(Intent.ACTION_SEND); shareIntent.setType("text/plain"); shareIntent.putExtra(Intent.EXTRA_TEXT, "https://github.com/leavesC"); } public void originalShare(View view) { Intent intent = Intent.createChooser(shareIntent, "分享一段文本信息"); if (shareIntent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } } public void customizedShare(View view) { if (bottomSheetDialog == null) { bottomSheetDialog = new BottomSheetDialog(this); bottomSheetDialog.setContentView(R.layout.dialog_bottom_sheet); initBottomDialog(); } bottomSheetDialog.show(); } private void initBottomDialog() { appList = getShareAppList(this, shareIntent); AppShareAdapter appShareAdapter = new AppShareAdapter(this, appList); appShareAdapter.setClickListener(new AppShareAdapter.OnClickListener() { @Override public void onClick(int position) { Intent intent = new Intent(Intent.ACTION_SEND); intent.setComponent(new ComponentName(appList.get(position).getPackageName(), appList.get(position).getMainClassName())); intent.setType("text/plain"); intent.putExtra(Intent.EXTRA_TEXT, "https://github.com/leavesC"); startActivity(intent); } }); appShareAdapter.setLongClickListener(new AppShareAdapter.OnLongClickListener() { @Override public void onLongClick(int position) { Intent intent = new Intent(); intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS); intent.setData(Uri.parse("package:" + appList.get(position).getPackageName())); startActivity(intent); } }); RecyclerView rv_appList = bottomSheetDialog.findViewById(R.id.rv_appList); if (rv_appList != null) { rv_appList.setLayoutManager(new GridLayoutManager(this, 4)); rv_appList.setAdapter(appShareAdapter); } } public static List<App> getShareAppList(Context context, Intent intent) { List<App> appList = new ArrayList<>(); PackageManager packageManager = context.getPackageManager(); List<ResolveInfo> resolveInfoList = packageManager.queryIntentActivities(intent, PackageManager.COMPONENT_ENABLED_STATE_DEFAULT); if (resolveInfoList == null || resolveInfoList.size() == 0) { return null; } else { for (ResolveInfo resolveInfo : resolveInfoList) { App appInfo = new App(resolveInfo.loadLabel(packageManager).toString(), resolveInfo.activityInfo.packageName, resolveInfo.activityInfo.name, resolveInfo.loadIcon(packageManager)); appList.add(appInfo); } } return appList; } }
這里提供上述示例代碼: ShareDialog_Demo
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android多功能時鐘開發(fā)案例(基礎(chǔ)篇)
這篇文章主要為大家詳細介紹了Android多功能時鐘開發(fā)案例的基礎(chǔ)知識,為開發(fā)Android時鐘打下基礎(chǔ),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-05-05Android中ListView如何分頁加載數(shù)據(jù)
這篇文章主要介紹了Android中ListView如何分頁加載數(shù)據(jù),本文就結(jié)合實例來演示一下使用ListView獲取數(shù)據(jù)的過程,需要的朋友可以參考下2015-12-12Android使用xUtils3.0實現(xiàn)文件上傳
這篇文章主要為大家詳細介紹了Android使用xUtils3.0實現(xiàn)文件上傳的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11Compose自定義View實現(xiàn)繪制Rainbow運動三環(huán)效果
這篇文章主要為大家介紹了一個基于Compose自定義的一個Rainbow彩虹運動三環(huán),業(yè)務(wù)上類似于iWatch上的那個運動三環(huán),感興趣的小伙伴可以了解一下2023-02-02Android Studio獲取網(wǎng)絡(luò)JSON數(shù)據(jù)并處理的方法
這篇文章主要為大家詳細介紹了Android Studio獲取網(wǎng)絡(luò)JSON數(shù)據(jù)并處理的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10