属性动画android,Android之属性动画

前言

Android应用市场现在愈来愈受欢迎了,有一部分缘由是它可以模拟物理世界,让人有身临其境的感觉,提升用户的体验。

这里就介绍一下简单的落日景象的模拟应用。html

代码详解

(一)使用抽象的activity托管fragment

一、通用的fragment托管布局(activity_fragment.xml):java

android:id="@+id/fragment_container"

android:layout_width="match_parent"

android:layout_height="match_parent"

/>

二、抽象的activity类(SingleFragmentActivity.java):android

public abstract class SingleFragmentActivity extends FragmentActivity {

protected abstract Fragment createFragment();

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_fragment);

FragmentManager fm = getSupportFragmentManager();

Fragment fragment = fm.findFragmentById(R.id.fragment_container);

if (fragment == null) {

fragment = createFragment();

fm.beginTransaction()

.add(R.id.fragment_container, fragment)

.commit();

}

}

}

从activity_fragment.xml布局里实例化activity视图,而后在容器中查找FragmentManager里的fragment。若是找不到,就新建fragment并将其添加到容器中。web

(二)创建场景

一、新建一个模拟太阳的drawable资源(sun.xml):编程

android:shape="oval">

二、创建布局文件构建整个场景(fragment_sunset.xml):ide

android:orientation="vertical"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/sky"

android:layout_width="match_parent"

android:layout_height="0dp"

android:layout_weight="0.61"

android:background="@color/blue_sky">

android:id="@+id/sun"

android:layout_width="100dp"

android:layout_height="100dp"

android:layout_gravity="center"

android:src="@drawable/sun"

/>

android:layout_width="match_parent"

android:layout_height="0dp"

android:layout_weight="0.39"

android:background="@color/sea"

/>

三、新建SunsetFragment类(SunsetFragment.java):svg

public class SunsetFragment extends Fragment {

public static SunsetFragment newInstance() {

return new SunsetFragment();

}

@Override

public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.fragment_sunset, container, false);

return view;

}

}

四、建立SunsetFragment类(SunsetActivity.java):函数

public class SunsetActivity extends SingleFragmentActivity {

@Override

protected Fragment createFragment() {

return SunsetFragment.newInstance();

}

}

到这里,就可以看见一个太阳在水平线上的静态应用了。

06ab6ad3f5a9624fef567ed03b6a3f80.png布局

(三)简单属性动画

一、获取视图引用

在SunsetFragment.java中添加如下代码:优化

private View mSceneView;

private View mSunView;

private View mSkyView;

在onCreateView函数中添加:

mSceneView = view;

mSunView = view.findViewById(R.id.sun);

mSkyView = view.findViewById(R.id.sky);

二、获取视图的顶部坐标位置

在SunsetFragment.java中添加如下代码:

private void startAnimation() {

float sunYStart = mSunView.getTop();

float sunYEnd = mSkyView.getHeight();

}

三、建立一个ObjectAnimator对象执行动画

在SunsetFragment.java的startAnimation函数中添加如下代码:

ObjectAnimator heightAnimator = ObjectAnimator

.ofFloat(mSunView, "y", sunYStart, sunYEnd)

.setDuration(3000);

heightAnimator.start();

四、为mSceneView视图设置监听器

在SunsetFragment.java的onCreateView函数中添加如下代码:

mSceneView.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

startAnimation();

}

});

到这边,就能实现落日的动态应用。

a2334df80584f6aeaaf458fc9e2d42ec.gif

(四)优化动画效果

一、添加加速特效

在SunsetFragment.java的startAnimation函数中添加如下代码:

heightAnimator.setInterpolator(new AccelerateInterpolator());

二、色彩渐变

2.一、取出日落色彩资源

private int mBlueSkyColor;

private int mSunsetSkyColor;

private int mNightSkyColor;

Resources resources = getResources();

mBlueSkyColor = resources.getColor(R.color.blue_sky);

mSunsetSkyColor = resources.getColor(R.color.sunset_sky);

mNightSkyColor = resources.getColor(R.color.night_sky);

2.二、实现天空的色彩变化

ObjectAnimator sunsetSkyAnimator = ObjectAnimator

.ofInt(mSkyView, "backgroundColor", mBlueSkyColor, mSunsetSkyColor)

.setDuration(3000);

sunsetSkyAnimator.start();

2.三、增长色彩的过渡

sunsetSkyAnimator.setEvaluator(new ArgbEvaluator());

到这里,就能实现背景从蓝色到橘黄色的色彩的天然过渡。

c4b254cbcc0475aa9f99b1e453713fb9.png

(五)播放多个动画

一、建立夜空动画

在SunsetFragment.java的startAnimation函数中添加如下代码,并删除原来的动画启动代码:

ObjectAnimator nightSkyAnimator = ObjectAnimator

.ofInt(mSkyView, "backgroundColor", mSunsetSkyColor, mNightSkyColor)

.setDuration(1500);

nightSkyAnimator.setEvaluator(new ArgbEvaluator());

二、建立动画集

在SunsetFragment.java的startAnimation函数中添加如下代码:

AnimatorSet animatorSet = new AnimatorSet();

animatorSet

.play(heightAnimator)

.with(sunsetSkyAnimator)

.before(nightSkyAnimator);

animatorSet.start();

若有发现不当或错误之处,欢迎指导评论!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
您好!要使用Canvas绘制一个户型图,您可以按照以下步骤进行操作: 1. 首先,创建一个Canvas元素并添加到HTML页面中: ``` <canvas id="myCanvas" width="800" height="600"></canvas> ``` 这会创建一个宽度为800像素、高度为600像素的Canvas。 2. 在JavaScript中获取Canvas元素的引用: ```javascript var canvas = document.getElementById("myCanvas"); var ctx = canvas.getContext("2d"); ``` 3. 使用Canvas的绘图上下文(context)进行绘制: ```javascript // 绘制房间轮廓 ctx.beginPath(); ctx.moveTo(100, 100); // 移动到起始点(100, 100) ctx.lineTo(300, 100); // 绘制一条直线到点(300, 100) ctx.lineTo(300, 300); // 绘制一条直线到点(300, 300) ctx.lineTo(100, 300); // 绘制一条直线到点(100, 300) ctx.closePath(); // 封闭路径 ctx.stroke(); // 绘制轮廓线 // 绘制房间内部元素 ctx.fillStyle = "red"; // 设置填充颜色为红色 ctx.fillRect(120, 120, 160, 160); // 绘制一个红色矩形 ctx.fillStyle = "blue"; // 设置填充颜色为蓝色 ctx.beginPath(); ctx.arc(250, 250, 50, 0, 2 * Math.PI); // 绘制一个蓝色圆形 ctx.fill(); // 填充圆形 // 绘制文字 ctx.font = "20px Arial"; ctx.fillStyle = "black"; ctx.fillText("房间1", 130, 200); ``` 以上代码演示了如何绘制一个简单的户型图,包括房间轮廓、内部元素和文字标记。您可以根据实际需求进行调整和扩展。希望对您有所帮助!如果您有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值