应用描述:各大手机都支持锁屏功能,其中用的最多的就是滑动解锁了。ui界面由九个点构成,当用户的手指点击屏幕或者在屏幕上滑动时 就可以通过点亮点和点亮线画出与用户设置的相同图案解锁手机
(完整代码见GitHub:https://github.com/ZdwCode/OpenBySlide)
第一步:布局
1.将九个点布局在屏幕页面上,通过拖拽的方式布局九个点。
Q:如何点亮?
A: 通过在这九个点上再加九个红色的点(如图) 红点一开始我们将其Visibility的属性设置为INVISIBLE 当收直滑动上去时 我们将其Visibility的属性设置为VISIBLE,这样在视觉上是点亮的效果
2.将所有的线条布局在屏幕上
步骤同布局九个点一样
第二步:点亮点
获取手指点击位置的坐标:
通过event.x和event.y属性可以获取相对手机页面的坐标(橙色框框)但我们的圆点是布局在容器中的(红色框框) 所以我们需要将坐标转换
private fun convertTouchLocationToContainer(event: MotionEvent):Point{
val point=Point().apply {
x=(event.x-container.x).toInt()
y=(event.y-barheight-container.y).toInt()
}
return point
}
得到相对于容器的位置后就可以判断是否在九个点里面了 如果是则点亮该点
第三步:点亮线
思路:我们发现每一条线都连接了两个点,我们通过这两个点的Tag值进行组合,形成一个唯一的标识,通过这个标识来点亮线
//1.获取线的tag值
val lastTag=(lastdot?.tag as String ).toInt()
val currentTag=(view.tag as String).toInt()
val lineTag=if(lastTag>currentTag) currentTag*10+lastTag else lastTag*10+currentTag
//判断是否有这条线
if(allLineTag.contains(lineTag)){ //如果有
//点亮点
highlightDot(view)
//点亮线
container.findViewWithTag<ImageView>(lineTag.toString()).also {
it.visibility=ImageView.VISIBLE
selectedViews.add(it)
}
}
效果如下:
密码保存与读取(轻量存取)
1.存:
步骤:①获取SharePerference的对象(通过Context对象获取) :需要传递两个参数,一个文件名,一个保存模式
②获取edit对象(通过SharedPerference对象获取)
③用edit对象写入数据:putString()方法 ,以Key——value的形式保存
④提交:commit()方法提交
//获取sharedPerference对象
val sharedPerference:SharedPreferences?=mycontext?.getSharedPreferences("zdw", Context.MODE_PRIVATE)
//获取edit对象-》写数据
val edit:SharedPreferences.Editor?=sharedPerference?.edit()
//写入数据
edit?.putString("pwd",pwd)
//提交
edit?.commit()
2.取:
步骤:①获取SharePerference的对象(通过Context对象获取) :需要传递两个参数,一个文件名,一个保存模式
②使用SharePerference对象的getString()方法获取
//获取sharedPerference对象
val sharedPerference:SharedPreferences?=mycontext?.getSharedPreferences("zdw", Context.MODE_PRIVATE)
val result=sharedPerference?.getString("pwd",null)
从相册中读取图像作为头像
1.隐式跳转
意图和意图过滤器
应用的三个核心组件 — 活动,服务和广播接收器 — 通过消息被激活,该消息被称为“意图”。意图通知是在运行后期绑定相同或不同应用间组件的设备。意图本身,一个[Intent](http://developer.android.com/reference/android/content/Intent.html)
对象,是一种数据结构,该结构持有被执行操作的抽象描述,或者,通常在广播的情况下,结构持有描述是将要发生的事情和正在广播的内容。
意图
意图就是我们跳转时使用的工具,表示我们打算从当前页面跳转到何种页面上去
我们只需要创造一个Intent对象,需要启动跳转时调用startActivity方法就可以了
意图过滤器
对要配置的的意图的值的描述,它可以通过acion、category、data
来匹配一个意图。而且意图过滤器还有一个叫作“优先级”值,用来对多个配置的意图过滤器进行排序。
通常意图过滤器是在清单文件中用intent-filter标签进行配置的,而<intent-filter>需要定义三个组件结点中。
跳转到相册
找到相册对应的action值,然后为我们的intent设置该action值就可以了
//从相机里获取图片
val intent=Intent()
intent.action=Intent.ACTION_PICK
intent.type="image/*"
startActivityForResult(intent,123)
在startActivityForResult()结束后,会默认执行onActivityResult()方法,方便我们在此处执行有关意图结束后的各种操作
挑选图片后将图片设为头像
第一步:判断该意图是否为我们的意图,通过requestCode的值来实现
第二步:判断意图是否因为用户取消操作(即用户误点换头像,然后自行退出),通过resultCode的值来实现
第三步:解析头像
我们要知道,此时图像传过来的是uri值 ,我们要解析该uri
①首先打开uri:contentResolver.openInputStream(uri)
② 用BitmapFactory解析:BitmapFactory.decodeStream(it) 解析后的结果即为一张图片,可以使用了
③保存图片:创建一个目录,将获取到的图片保存在目录中
fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
when(requestCode){
123->{
//图片
//判断用户是否取消操作
if(resultCode != Activity.RESULT_CANCELED){
data?.data?.let {uri->
contentResolver.openInputStream(uri).use {
BitmapFactory.decodeStream(it).also { image->
myHead.setImageBitmap(image)
//把图片缓存起来
val myFile=File(filesDir,"header.jpg")
FileOutputStream(myFile).also {fos->
image.compress(Bitmap.CompressFormat.JPEG,50,fos)
}
}
}
}
}
}
}
super.onActivityResult(requestCode, resultCode, data)
}