仿Twitter登陆移动背景效果
有使用Twitter客户端的朋友应该有发现在登录的时候,屏幕上方和下方的云朵图片是不断移动着的,再加上Twitter那支可爱的小鸟在不停的动着,给人的感觉就好像是小鸟在飞翔一样,感觉效果很不错。
我也试着实现了一下,发现使用自定义的Drawable加上线程,还是比较容易实现的。下面是自定义Drawable的代码,注释已经写的很详细了。这里是使用了三张图片,使用一张图就更简单了,大家完全可以举一反三,实现自己的动画图片效果。
package com.liuzhichao.dynamicdrawable; import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.ColorFilter;
import android.graphics.drawable.Drawable;
import android.util.DisplayMetrics;
import android.view.View; public class DynamicDrawable extends Drawable implements Runnable { private static Bitmap mBottomBgBitmap; //底部大图
private static Bitmap mBottomFgBitmap; // 底部小图
private static Bitmap mTopBitmap; //顶部云图片 private final int dispalyWidth; //手机屏幕宽度
private final int dispalyHeight; //手机屏幕高度
private float mBottomBgTop; //顶部大图显示的位置
private float mBottomFgTop; //顶部小图显示的位置 private int startX; //顶部云图片和底部大图移动偏移变量
private int mBottomFgStartX; //底部小图移动偏移变量
private View mView; public DynamicDrawable(Activity activity, View mView) {
this.mView = mView; if (mTopBitmap == null) {
mTopBitmap = BitmapFactory.decodeResource(activity.getResources(),
R.drawable.cloud_top_bg);
}
if (mBottomBgBitmap == null) {
mBottomBgBitmap = BitmapFactory.decodeResource(
activity.getResources(), R.drawable.cloud_bottom_bg);
}
if (mBottomFgBitmap == null) {
mBottomFgBitmap = BitmapFactory.decodeResource(
activity.getResources(), R.drawable.cloud_bottom_fg);
} //获取屏幕高度和宽度
DisplayMetrics dm = new DisplayMetrics();
dm = activity.getResources().getDisplayMetrics();
this.dispalyHeight = dm.heightPixels;
this.dispalyWidth = dm.widthPixels; //顶部图片显示的位置 = 屏幕高度 - 图片自身高 - 标题高度
this.mBottomBgTop = dispalyHeight - mBottomBgBitmap.getHeight() - 100;
this.mBottomFgTop = dispalyHeight - mBottomFgBitmap.getHeight() - 100; //开始移动图片线程
new Thread(this).start();
} @Override
public void draw(Canvas canvas) {
// drawBitmap (Bitmap bitmap, float left, float top, Paint paint)
canvas.drawBitmap(mTopBitmap, startX, 0, null);
canvas.drawBitmap(mBottomBgBitmap, startX, mBottomBgTop, null);
canvas.drawBitmap(mBottomFgBitmap, mBottomFgStartX, mBottomFgTop, null);
} @Override
public int getOpacity() {
// TODO Auto-generated method stub
return 0;
} @Override
public void setAlpha(int arg0) {
// TODO Auto-generated method stub } @Override
public void setColorFilter(ColorFilter arg0) {
// TODO Auto-generated method stub } @Override
public void run() {
while (!Thread.currentThread().isInterrupted()) {
//900 是图片的长度
//如果移动偏量已经大于图片的长度 - 屏幕宽度,则说明已经移动到了图片的末端,如果继续移动,则会显示空白
//所以将startX重新赋予0,让图片重新开始移动
//但是这样过渡效果会比较明显,再切换的那一刹那,会明显感觉图片变化较大
if (startX + (900 - dispalyWidth) == 0) {
startX = 0;
} else {
startX -= 1;
} //底部小图的移动,
// -=2 是让小图移动的比大图快,造成不同的视觉效果
if (mBottomFgStartX + (900 - dispalyWidth) == 0) {
mBottomFgStartX = 0;
} else {
mBottomFgStartX -= 2;
}
try {
//每 1/10秒移动一次
Thread.sleep(100L);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
//刷新界面
mView.postInvalidate();
} } }
然后在需要背景图的地方,直接setBackgroundDrawable就可以了,下面的background是整个布局文件的id。
private View background;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
background = findViewById(android.R.id.background);
background.setBackgroundDrawable(new DynamicDrawable(this, background));
}
布局文件也还是贴出来吧:
<RelativeLayout 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:id="@android:id/background" > <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:padding="@dimen/padding_medium"
android:text="@string/hello_world"
tools:context=".MainActivity" /> </RelativeLayout>
还是截张图吧,虽然看不到动画效果。

本文转自:http://liuzhichao.com/p/659.html
仿Twitter登陆移动背景效果的更多相关文章
- C# 实现简单仿QQ登陆注册功能
闲来没事,想做一个仿QQ登陆注册的winform,于是利用工作之余,根据自己的掌握和查阅的资料,历时4天修改完成,新手水平,希望和大家共同学习进步,有不同见解希望提出! 废话不多说,进入正题: 先来看 ...
- WPF实现Twitter按钮效果
最近上网看到这个CSS3实现的Twitter按钮,感觉很漂亮,于是想用WPF来实现下. 实现这个效果,参考了CSS3 原文地址:http://www.html5tricks.com/css3-twit ...
- 浅谈HTML之模仿人人网登陆界面(新手必学)
为方便大家对web相关知识的了解,现谈谈新手如何从HTML css Javascript到以后后台的发展.首先,让大家看看HTML仿人人登陆界面: <!doctype html> < ...
- WPF实现Twitter按钮效果(转)
最近上网看到这个CSS3实现的Twitter按钮,感觉很漂亮,于是想用WPF来实现下. 实现这个效果,参考了CSS3 原文地址:http://www.html5tricks.com/css3-twit ...
- 那些年一起用过的iOS开发利器之Parse
阅读此文章需要对Objective-C和iOS有一定的了解,完全没有基础的朋友请先阅读<让不懂编程的人爱上iPhone开发>系列教程. 什么是后台服务(back-end service)? ...
- 【android design】android常用设计资源
一.概述 大部分程序员擅长开发,但是对于设计却知之甚少.这直接导致,程序员在初期开发出来的应用(大多为兴趣或实用导向)中看不中用.因此,有必要搜集整合一些设计资源,这样既能减轻程序员在设计上所耗费的时 ...
- 50个Android开发人员必备UI效果源码[转载]
50个Android开发人员必备UI效果源码[转载] http://blog.csdn.net/qq1059458376/article/details/8145497 Android 仿微信之主页面 ...
- duilib修复ActiveXUI控件bug,以支持flash透明动态背景
转载请说明原出处,谢谢~~ 昨天在QQ控件里和同学说起QQ2013登陆窗体的开发,从界面角度考虑,单单一个登陆界面是很容易做出来的.腾讯公司为了 防止各种盗号行为可谓煞费苦心,QQ2013采用了动态背 ...
- [转载] 50个Android开发人员必备UI效果源码
好东西,多学习! Android 仿微信之主页面实现篇Android 仿微信之界面导航篇Android 高仿QQ 好友分组列表Android 高仿QQ 界面滑动效果Android 高仿QQ 登陆界面A ...
随机推荐
- js&html5实现消星星游戏
前段时间看见园子里有同学用js+jquery实现了消星星游戏,自己也早有这个想法,于是就利用业余时间用js+html5实现了一下消星星游戏. 主要是想实现效果,运用了css3中的动画属性.游戏积分算法 ...
- java理论基础学习一
java的最大优势是跨平台 java的版本和体系架构 1.J2EE Java 2 Enterprise Edition 定位在服务器端的应用 2.J2SE Java 2 Standard Ed ...
- 配置IIS应用程序池
IIS 6的核心在于工作进程隔离模式,而应用程序池则是定义工作进程如何进行工作,因此,可以说应用程序池是整个IIS 6的核心. 和IIS 5中只能使用单个应用程序池不同,工作在工作进程隔离模式的IIS ...
- 关于 RTMP RTMPT RTMPS RTMPE RTMPTE RTMFP AMF 简介
http://www.360doc.com/content/13/0709/16/21412_298738723.shtml 1. AMFAMF(是Action Message Format的缩写)是 ...
- ios开发--集成银联3.3.0
项目最近需要集成银联,在网上搜了一下发现都并不是最新版的银联集成教程,自己摸索了一下,总结写了下来. 附上3.3.0的下载网址 https://open.unionpay.com/upload/dow ...
- JLink v8克隆版破解向导(此方法仅适用XP32位版 WIN7及以上和64位均不支持 建议使用虚拟机)
此方法仅适用XP32位版 WIN7及以上和64位均不支持 建议使用虚拟机 摘要 Jlink 4.5版本之后驱动会识别老的克隆版的JlinkV8,Jlink软件在启动时会提示为克隆版本后退出.目前主流的 ...
- android-exploitme(四):参数篡改
今天我们来测试请求中参数的篡改,这个在web安全测试中是常用的,拦截请求包,修改参数,提交 1. 首先我们需要启动模拟器,并使用本机的代理(加上参数-partition-size的目的是为了可以往a ...
- 转载网页博客:ie7bug:div容器下的img与div存在间隙
1.代码及在浏览器上的显示 ie7: ie8+: Firefox: Chrome: 可以看出ie7上在div容器下添加img,div与img中有间隙,而在ie8+和其他浏览器上均显示正常 网页源代码如 ...
- mars android视频学习笔记一:Activity生命周期
(1)创建:onCreate->onStart->onResume;(2)失去焦点:onPause->onStop:(3)重新获得焦点:onRestart->onStart-& ...
- http://www.cnblogs.com/AloneSword/p/3370462.html
http://www.cnblogs.com/AloneSword/p/3370462.html