Kotlin高仿微信-第24篇-新消息通知

 Kotlin高仿微信-项目实践58篇详细讲解了各个功能点,包括:注册、登录、主页、单聊(文本、表情、语音、图片、小视频、视频通话、语音通话、红包、转账)、群聊、个人信息、朋友圈、支付服务、扫一扫、搜索好友、添加好友、开通VIP等众多功能。

Kotlin高仿微信-项目实践58篇,点击查看详情

效果图:

实现代码:

<?xml version="1.0" encoding="utf-8"?>
<layout >

    <androidx.constraintlayout.widget.ConstraintLayout
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/notification_setting_root"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/wc_base_bg">


        <include
            layout="@layout/wc_base_top_title"/>

        <androidx.appcompat.widget.AppCompatTextView
            android:id="@+id/notifi_tip"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            app:layout_constraintTop_toTopOf="@+id/notifi_tip_cb"
            app:layout_constraintBottom_toBottomOf="@+id/notifi_tip_cb"
            app:layout_constraintStart_toStartOf="parent"
            android:layout_marginLeft="12dp"
            android:text="消息提示:"/>

        <CheckBox
            android:id="@+id/notifi_tip_cb"
            android:layout_width="30dp"
            android:layout_height="30dp"
            android:layout_marginRight="12dp"
            android:layout_marginTop="30dp"
            android:checked="true"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/base_top_root_layout"/>

        <androidx.appcompat.widget.AppCompatTextView
            android:id="@+id/notifi_voice_tip"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="20dp"
            android:paddingVertical="10dp"
            app:layout_constraintTop_toBottomOf="@+id/notifi_tip"
            app:layout_constraintStart_toStartOf="@+id/notifi_tip"
            android:text="消息声音:"/>

        <androidx.appcompat.widget.AppCompatTextView
            android:id="@+id/notifi_voice_content"
            app:layout_constraintTop_toTopOf="@+id/notifi_voice_tip"
            app:layout_constraintBottom_toBottomOf="@+id/notifi_voice_tip"
            app:layout_constraintStart_toEndOf="@+id/notifi_voice_tip"
            app:layout_constraintEnd_toEndOf="@+id/notifi_tip_cb"
            android:gravity="right"
            android:paddingVertical="10dp"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:drawableRight="@drawable/wc_notification_setting_arrow_down"
            android:drawablePadding="6dp"
            android:paddingRight="8dp"
            android:text="已选择声音:"/>

        <androidx.appcompat.widget.AppCompatTextView
            android:id="@+id/notifi_important_tip"
            app:layout_constraintTop_toBottomOf="@id/notifi_voice_tip"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            android:gravity="right"
            android:paddingVertical="10dp"
            android:layout_marginTop="40dp"
            android:layout_marginHorizontal="12dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="@color/red"
            android:textSize="18sp"
            android:visibility="gone"
            android:text="@string/wc_notification_setting_content2"/>

    </androidx.constraintlayout.widget.ConstraintLayout>
</layout>

/**
 * Author : wangning
 * Email : maoning20080809@163.com
 * Date : 2022/7/3 18:56
 * Description : 消息通知设置
 */
class NotificationSettingFragment : BaseDataBindingFragment<WcNotificationSettingRootBinding>(){

    override fun getLayoutRes() = R.layout.wc_notification_setting_root

    private var notificationSettingMsg : NotificationSettingMsg? = null

    override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        super.onViewCreated(view, savedInstanceState)

        super.builder().setTitleContent(R.string.wc_base_top_notify_message)

        notificationSettingMsg = NotificationSettingMsg()
        notifi_voice_content.setOnClickListener {
            showSingleDialog()
        }
        processNotification()

        notifi_tip_cb.setOnCheckedChangeListener { compoundButton, b ->
            if(!ChatNotificationUtils.isNotificationEnabled()){
                processNotification()
            } else {
                if(b){
                    showVoiceTip()
                } else {
                    hideVoiceTip()
                }
                DataStoreUtils.put(CommonUtils.Notification.Notify_TIP, b)
            }
        }

        var checkedId = DataStoreUtils.get(CommonUtils.Notification.SELECTED_VOICE_ID,1) as Int
        notifi_voice_content.text = BaseUtils.getString(R.string.wc_notification_setting_selected_voice, items.get(checkedId))

        if(notifi_tip_cb.isChecked){
            showVoiceTip()
        } else {
            hideVoiceTip()
        }

    }

    override fun onResume() {
        super.onResume()
        notification_setting_root.isFocusableInTouchMode = true
        notification_setting_root.requestFocus()
        notification_setting_root.setOnKeyListener { view, i, keyEvent ->
            if (i == KeyEvent.KEYCODE_BACK && keyEvent.getAction() == KeyEvent.ACTION_DOWN) {
                TagUtils.d("onResume .>  ${notificationSettingMsg} , ${notificationSettingMsg?.isShowing()}")
                if(notificationSettingMsg != null && notificationSettingMsg?.isShowing() != null && notificationSettingMsg?.isShowing()!!){
                    return@setOnKeyListener true
                }
            }
            return@setOnKeyListener false
        }
    }

    override fun onHiddenChanged(hidden: Boolean) {
        super.onHiddenChanged(hidden)
        if(!hidden){
            processNotification()
        }
    }

    private fun hideVoiceTip(){
        notifi_voice_tip.visibility = View.GONE
        notifi_voice_content.visibility = View.GONE
    }

    private fun showVoiceTip(){
        notifi_voice_tip.visibility = View.VISIBLE
        notifi_voice_content.visibility = View.VISIBLE
    }

    /**
     * 判断手机通知栏是否启用, 如果不启用,跳转到页面开启
     */
    private fun processNotification(){
        if(!ChatNotificationUtils.isNotificationEnabled()){
            showVoiceTip()
            notifi_important_tip.visibility = View.VISIBLE
            notifi_tip_cb.isChecked = false
            notificationSettingMsg?.showNotificationSetting(requireActivity(), notification_setting_root, true, object : BasePopupWindow.IOnDismissListener{
                override fun onDismiss() {
                    if(!ChatNotificationUtils.isNotificationEnabled()) {
                        showVoiceTip()
                        notifi_important_tip.visibility = View.VISIBLE
                        notifi_tip_cb.isChecked = false
                    } else {
                        hideVoiceTip()
                        notifi_important_tip.visibility = View.GONE
                        notifi_tip_cb.isChecked = DataStoreUtils.get(CommonUtils.Notification.Notify_TIP, true) as Boolean
                    }
                }
            })
        } else {
            hideVoiceTip()
            notifi_important_tip.visibility = View.GONE
            notifi_tip_cb.isChecked = DataStoreUtils.get(CommonUtils.Notification.Notify_TIP, true) as Boolean
        }
    }

    val items = arrayOf("无声音", "宿鸟流萤", "BB机", "老式闹钟", "鸟叫", "弹簧", "经典", "消失", "水滴")

    fun showSingleDialog(){
        var checkedId = DataStoreUtils.get(CommonUtils.Notification.SELECTED_VOICE_ID,1) as Int
        TagUtils.d("开始选择:${checkedId}")
        val builder = AlertDialog.Builder(requireActivity())
            .setTitle("请选择消息声音")
            .setSingleChoiceItems(items, checkedId,
            DialogInterface.OnClickListener { dialogInterface, i ->
                TagUtils.d("选择:${i}")
                checkedId = i
                CommonUtils.Notification.playNotification(i)
            })
            .setPositiveButton("确定",
                DialogInterface.OnClickListener {
                        dialogInterface, i ->
                    DataStoreUtils.put(CommonUtils.Notification.SELECTED_VOICE_ID, checkedId)
                    notifi_voice_content.text = BaseUtils.getString(R.string.wc_notification_setting_selected_voice, items.get(checkedId))
                    dialogInterface.dismiss()

                })
            .setNegativeButton("取消", null)
            .show()
        //修改 确定取消 按钮的字体大小
        builder.getButton(AlertDialog.BUTTON_POSITIVE).textSize = 20f
        builder.getButton(AlertDialog.BUTTON_POSITIVE).setTextColor(BaseUtils.getColor(R.color.color05C160))
        builder.getButton(DialogInterface.BUTTON_NEGATIVE).textSize = 20f
        builder.getButton(DialogInterface.BUTTON_NEGATIVE).setTextColor(BaseUtils.getColor(R.color.color05C160))

        //下面是改变显示内容的字体和颜色
        /*try {
            //获取mAlert对象
            val mAlert: Field = AlertDialog::class.java.getDeclaredField("mAlert")
            mAlert.setAccessible(true)
            val mAlertController: Any = mAlert.get(builder)

            //获取mTitleView并设置大小颜色
            val mTitle: Field = mAlertController.javaClass.getDeclaredField("mTitleView")
            mTitle.setAccessible(true)
            val mTitleView = mTitle.get(mAlertController) as TextView

            mTitleView.textSize = 40f
            mTitleView.setTextColor(Color.YELLOW)

            //获取mMessageView并设置大小颜色
            val mMessage: Field = mAlertController.javaClass.getDeclaredField("mMessageView")
            mMessage.setAccessible(true)
            val mMessageView = mMessage.get(mAlertController) as TextView
            mMessageView.setTextColor(Color.RED)
            mMessageView.textSize = 30f

        } catch (e: IllegalAccessException) {
            e.printStackTrace()
        } catch (e: NoSuchFieldException) {
            e.printStackTrace()
        }*/
    }




}

根据提供的引用内容,出现了两个关于Kotlin的错误信息。第一个引用中显示了一个无法解析依赖的错误,指出无法下载kotlin-reflect.jar文件。第二个引用中显示了一个关于kotlin-gradle-1.8.10.jar (org.jetbrains.kotlin:kotlin-reflect)",这个错误通常是由于Gradle无法找到所需的kotlin-reflect库而引起的。解决这个问题的方法是确保你的项目的Gradle配置正确,并且指定了正确的Kotlin版本。 你可以尝试以下几个步骤来解决这个问题: 1. 确保你的项目的build.gradle文件中包含了正确的Kotlin版本和kotlin-gradle-plugin版本。你可以在build.gradle文件中找到类似于以下代码的部分: ```groovy ext { kotlin_version = '1.8.10' } dependencies { // ... implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" // ... } buildscript { // ... dependencies { // ... classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // ... } } ``` 请确保kotlin_version变量的值与你想要使用的Kotlin版本一致,并且在dependencies和buildscript的classpath中正确引用了kotlin-gradle-plugin。 2. 如果你已经确认了build.gradle文件中的配置正确无误,那么可能是因为Gradle无法从远程仓库下载kotlin-reflect.jar文件。你可以尝试清除Gradle的缓存并重构建项目。在命令行中执行以下命令: ```shell ./gradlew clean ``` 然后重构建项目: ```shell ./gradlew build ``` 这将清除Gradle的缓存并重下载所需的依赖。 3. 如果上述步骤***切换到其他网络环境来解决这个问题。 希望以上步骤能够帮助你解决问题。如果你还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

六毛六66

你的鼓励是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值