Android 仿QQ消息提示,相册选择对话框

Android 仿QQ消息提示,相册选择对话框

好久没写博客了,也是因为最近实在是太忙了,从我入职到现在,一直都是在加班。。。苦逼的生活。
因公司要求和IOS统一对话框(万恶的pm,什么都要和ios一样),所以就有了本文的对话框,二话不说,先来张效果图(没效果图的博客看着真蛋疼)。
这里写图片描述

先看看消息提示对话框布局文件:
dialog_message.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:orientation="vertical"
        android:paddingLeft="25dp"
        android:paddingRight="25dp" >

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@drawable/rounded_trans_white_top"
            android:orientation="vertical"
            android:paddingBottom="25dp"
            android:paddingLeft="15dp"
            android:paddingRight="15dp"
            android:paddingTop="25dp" >

            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:gravity="center"
                android:paddingBottom="17dp"
                android:singleLine="true"
                android:text="@string/message"
                android:textColor="@android:color/black"
                android:textSize="20sp"
                android:textStyle="bold" />

            <TextView
                android:id="@+id/tv_message"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:gravity="center"
                android:text=""
                android:textColor="@android:color/black"
                android:textSize="17sp" />
        </LinearLayout>

        <View
            android:layout_width="match_parent"
            android:layout_height="0.5dp"
            android:background="@color/dialog_line" />

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="45dp" >

            <View
                android:id="@+id/v_center_line"
                android:layout_width="0.5dp"
                android:layout_height="match_parent"
                android:layout_centerInParent="true"
                android:background="@color/dialog_line" />

            <Button
                android:id="@+id/btn_cancel"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_alignParentLeft="true"
                android:layout_toLeftOf="@id/v_center_line"
                android:background="@drawable/dialog_bottom_left_selector"
                android:text="@string/cancel"
                android:textColor="@color/common_text"
                android:textSize="17sp" />

            <Button
                android:id="@+id/btn_ok"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_alignParentRight="true"
                android:layout_toRightOf="@id/v_center_line"
                android:background="@drawable/dialog_bottom_right_selector"
                android:text="@string/ok"
                android:textColor="@color/common_text"
                android:textSize="17sp" />
        </RelativeLayout>
    </LinearLayout>

</RelativeLayout>

消息提示对话框java代码:
MessageDialog.java

public class MessageDialog extends Dialog implements View.OnClickListener {

    private final TextView tv_message;
    private final Button btn_cancel;
    private final Button btn_ok;
    private MessageCallBack callBack;

    public MessageDialog(Context context) {
        super(context, R.style.DialogCenterTheme);
        setContentView(R.layout.dialog_message);
        tv_message = (TextView) findViewById(R.id.tv_message);
        btn_cancel = (Button) findViewById(R.id.btn_cancel);
        btn_ok = (Button) findViewById(R.id.btn_ok);

        btn_cancel.setOnClickListener(this);
        btn_ok.setOnClickListener(this);
    }

    public void show(MessageCallBack callBack) {
        this.callBack = callBack;
        super.show();
    }

    @Override
    public void show() {
    }

    //确认、取消回调
    public interface MessageCallBack {
        void onOkClick();

        void onCancelClick();
    }

    //消费了此次事件
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        cancel();
        return true;
    }

    @Override
    public void onClick(View v) {
        switch (v.getId()){
            case R.id.btn_cancel:
                callBack.onCancelClick();
                cancel();
                break;
            case R.id.btn_ok:
                callBack.onOkClick();
                cancel();
                break;
        }
    }
}

相册选择对话框布局文件:
dialog_picture_picker.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:orientation="vertical"
        android:paddingLeft="10dp"
        android:paddingRight="10dp" >

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical" >

            <Button
                android:id="@+id/btn_photograph"
                android:layout_width="match_parent"
                android:layout_height="45dp"
                android:background="@drawable/dialog_top_selector"
                android:text="@string/photograph"
                android:textColor="@color/common_text"
                android:textSize="17sp" />

            <View
                android:layout_width="match_parent"
                android:layout_height="0.5dp"
                android:background="@color/dialog_line" />

            <Button
                android:id="@+id/btn_from_album"
                android:layout_width="match_parent"
                android:layout_height="45dp"
                android:background="@drawable/dialog_bottom_selector"
                android:text="@string/select_from_album"
                android:textColor="@color/common_text"
                android:textSize="17sp" />
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="8dp"
            android:layout_marginBottom="8dp"
            android:orientation="vertical" >

            <Button
                android:id="@+id/btn_cancel"
                android:layout_width="match_parent"
                android:layout_height="45dp"
                android:background="@drawable/dialog_cancel_selector"
                android:text="@string/cancel"
                android:textColor="@color/common_blue"
                android:textSize="17sp" />
        </LinearLayout>
    </LinearLayout>

</RelativeLayout>

相册选择对话框java代码:
PicturePickerDialog.java

public class PicturePickerDialog extends Dialog implements View.OnClickListener {

    private final Button btn_photograph;
    private final Button btn_from_album;
    private final Button btn_cancel;
    private PicturePickerCallBack callBack;

    public PicturePickerDialog(Context context) {
        super(context, R.style.DialogBottomTheme);
        setContentView(R.layout.dialog_picture_picker);

        btn_photograph = (Button) findViewById(R.id.btn_photograph);
        btn_from_album = (Button) findViewById(R.id.btn_from_album);
        btn_cancel = (Button) findViewById(R.id.btn_cancel);

        btn_photograph.setOnClickListener(this);
        btn_from_album.setOnClickListener(this);
        btn_cancel.setOnClickListener(this);
    }

    public void show(PicturePickerCallBack callBack){
        this.callBack = callBack;
        super.show();
    }

    @Override
    public void show() {
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        cancel();
        return true;
    }

    public interface PicturePickerCallBack {
        void onPhotoClick();

        void onAlbumClick();
    }

    @Override
    public void onClick(View v) {
        switch (v.getId()){
            case R.id.btn_photograph:
                callBack.onPhotoClick();
                cancel();
                break;
            case R.id.btn_from_album:
                callBack.onAlbumClick();
                cancel();
                break;
            case R.id.btn_cancel:
                cancel();
                break;
        }
    }
}

MainActivity布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:background="#22cccccc"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:orientation="vertical"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.mumu.dialog.MainActivity">

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="showDialog"
        android:text="消息对话框" />
    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="showPicturePicker"
        android:text="相册选择对话框" />
</LinearLayout>

调用:

public class MainActivity extends AppCompatActivity {

    private Context mContext;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mContext = this;
    }

    public void showDialog(View view){
        MessageDialog messageDialog = new MessageDialog(this);
        messageDialog.show(new MessageDialog.MessageCallBack() {
            @Override
            public void onOkClick() {
                Toast.makeText(mContext,"确 定",Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onCancelClick() {
                Toast.makeText(mContext,"取 消",Toast.LENGTH_SHORT).show();
            }
        });
    }

    public void showPicturePicker(View view){
        PicturePickerDialog picturePickerDialog = new PicturePickerDialog(this);
        picturePickerDialog.show(new PicturePickerDialog.PicturePickerCallBack() {
            @Override
            public void onPhotoClick() {
                Toast.makeText(mContext,"拍 照",Toast.LENGTH_SHORT).show();
            }

            @Override
            public void onAlbumClick() {
                Toast.makeText(mContext,"相册选择",Toast.LENGTH_SHORT).show();
            }
        });
    }
}

优快云下载地址:
http://download.youkuaiyun.com/detail/u013653230/9603210

github:
https://github.com/diycoder/Dialog

当做一款APP,需要选择本地图片时,首先考虑的无疑是系统相册,但是Android手机五花八门,再者手机像素的提升,大图无法返回等异常因数,导致适配机型比较困难,微信、QQ都相继的在自己的APP里集成了图片选择功能,放弃了系统提供的图片选择器,这里仿QQ做了一个本地图片选择器,PS:之前有人说"仿"写成“防”了,今儿特意注意了下,求不错。先上一张效果图,无图无真相啊~~~实现的效果大概是这样的:  1.单选:跳转到本地图片选择文件夹,选择文件夹后,进入到该文件夹下的所有图片,选择某张图片后,返回改图片地址信息  2.多选:跳转到图片文件夹,选择一个文件夹,选择图片,点击右上角的小圆圈,选中该图,点击图片其他区域,查看大图,点击预览,查看已选图片,可以跨文件夹选择图片。 为了达到这效果,需要做几件事:  1.读取本地所有 有图片的文件夹:    这里用ContentResolver读取媒体文件String[] columns = {MediaStore.Images.Media._ID, MediaStore.Images.Thumbnails.DATA, MediaStore.Images.Media.DATA, MediaStore.Images.Media.BUCKET_ID,                         MediaStore.Images.Media.BUCKET_DISPLAY_NAME, "COUNT(1) AS count"};  String selection = "0==0) GROUP BY ("   MediaStore.Images.Media.BUCKET_ID;  String sortOrder = MediaStore.Images.Media.DATE_MODIFIED;  Cursor cursor = contentResolver.query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, columns, selection, null, sortOrder);这是一个简单的SQL查询语句,按文件夹分组,并返回文件夹下图片数。 2.读取指定文件夹下所有图片:  当选择某一目录时,需要读取该目录下所有图片了。String[] columns = new String[]{MediaStore.Images.Media._ID, MediaStore.Images.Media.DATA}; /*查询文件路径包含上面指定的文件夹路径的图片--这样才能保证查询到的文件属于当前文件夹下*/  String whereclause = MediaStore.Images.ImageColumns.DATA   " like'"   folderPath   "/%'";  Log.i("queryGalleryPicture", "galleryPath:"   folderPath);  Cursor corsor = c.getContentResolver().query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, columns, whereclause, null, null);这里的查询语句是根据文件名字来过滤的,只要图片路径包含文件夹路径的,则为该文件夹下的图片  3.UI交互   首先在展示所有包含图片的文件夹时,异步加载有图片的文件夹,读取成功后列表展示,这里用的RecyclerView展示列表信息,点击某一目录时,在读取改目录下的图片,在图片展示页里,需要注意的是,每次点击判断当前点击图片是否已在选择列表中,若在,删除,不在,添加。这里图片加载用了开源框架ImageLoaderif (mSelectlist.contains(imageBean)) { //点击的item为已选过的图片时,删除                      mSelectlist.remove(imageBean);                      subSelectPosition();                  } else { //不在选择列表里,添加                      if (mSelectlist.size() >= maxCount) {                          Toast.makeText(mContext, mContext.getResources().getString(R.string.publish_select_photo_max, maxCount), Toast.LENGTH_SHORT).show();                          return;                      }                      mSelectlist.add(imageBean);                      imageBean.selectPosition = mSelectlist.size();                  }                  //通知点击项发生了改变                  notifyItemChanged(position);同时没删除一张图片,图片上的序号相应的作改变,然后通知改变项更新UI。   不同Activity跳转时,因为要传递图片列表List,list里是自定义实体类,刚开始考虑过用intent传递,但是intent传递后,通过list.get(positon).contains比较是否同一对象时,始终是不同对象,大家可以去验证下。所以这里定义了一个观察者的类,去保存选择的图片和文件夹下的所有图片,同时查看大图时,若选择了一张或者取消选择了一张图,通过观察者通知更新即可/**      * 通知图片选择已改变      */     public void updateImageSelectChanged () {         setChanged();         notifyObservers(imgSelectObj);     }好了,有了以上的,就可以使用我们的图片选择器了:单选时,在需要的地方调用:/*参数对应context, 回调code, 传入的图片List, 可选的最大张数*/ FolderListActivity.startFolderListActivity(this, 1, null, 9);最后Activity的onActivityResult中接收返回的图片数据:List<ImageFolderBean> list = (List<ImageFolderBean>) data.getSerializableExtra("list");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值