这篇文章主要为大家详细介绍了Android帧式布局实现自动切换颜色,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Android帧式布局实现自动切换颜色的具体代码,供大家参考,具体内容如下
效果:
实现:
activity_main.xml
<?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:gravity="center"
android:orientation="vertical"
tools:context=".MainActivity">
<FrameLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<TextView
android:id="@+id/tvBottom"
android:layout_width="300dp"
android:layout_height="300dp"
android:layout_gravity="center"
android:background="#ff0000"
android:text="@string/bottom"
android:textColor="#ffff00"
android:textSize="30sp" />
<TextView
android:id="@+id/tvMiddle"
android:layout_width="200dp"
android:layout_height="200dp"
android:layout_gravity="center"
android:background="#0000ff"
android:text="@string/middle"
android:textColor="#ffff00"
android:textSize="30sp" />
<TextView
android:id="@+id/tvTop"
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_gravity="center"
android:background="#00ff00"
android:text="@string/top"
android:textColor="#ffff00"
android:textSize="30sp" />
</FrameLayout>
<LinearLayout
android:layout_marginTop="20dp"
android:layout_width="300dp"
android:layout_height="50dp"
android:gravity="center">
<Button
android:layout_width="100dp"
android:layout_height="wrap_content"
android:text="@string/start"
android:textSize="20sp"
android:onClick="doStart"
android:layout_marginRight="50dp"
android:background="#04b102"/>
<Button
android:layout_width="100dp"
android:layout_height="wrap_content"
android:text="@string/stop"
android:textSize="20sp"
android:onClick="doStop"
android:background="#04b102"/>
</LinearLayout>
</LinearLayout>ActivityMain.java
import android.graphics.Color;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
public class MainActivity extends AppCompatActivity {
private TextView tvBottom;
private TextView tvMiddle;
private TextView tvTop;
private int[] colors;
private Handler handler;
private Thread thread;
private boolean isRunning;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//利用布局资源设置用户界面
setContentView(R.layout.activity_main);
//通过资源标识符获取控件实例
tvBottom = findViewById(R.id.tvBottom);
tvMiddle = findViewById(R.id.tvMiddle);
tvTop = findViewById(R.id.tvTop);
//初始化颜色数组
colors = new int[]{Color.RED, Color.BLUE, Color.GREEN};
handler = new Handler() {
@Override
public void handleMessage(@NonNull Message msg) {
super.handleMessage(msg);
if (msg.what == 0x0001) {
//切换颜色
int temp = colors[0];
for (int i = 0; i < colors.length - 1; i++) {
colors[i] = colors[i + 1];
}
colors[colors.length - 1] = temp;
// 根据切换后的颜色数组来设置三层标签的背景色
tvBottom.setBackgroundColor(colors[0]);
tvMiddle.setBackgroundColor(colors[1]);
tvTop.setBackgroundColor(colors[2]);
}
}
};
}
/**
* 【开始】按钮单击事件处理方法
*/
public void doStart(View view) {
// 设置线程运行控制变量
isRunning = true;
// 创建子线程,定时发送消息
thread = new Thread(new Runnable() {
@Override
public void run() {
while (isRunning) {
// 向主线程发送消息
handler.sendEmptyMessage(0x0001);
// 让线程睡眠500毫秒
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
});
// 启动线程
thread.start();
}
/**
* 【停止】按钮单击事件处理方法
*/
public void doStop(View view) {
// 设置线程运行控制变量
isRunning = false;
// 销毁子线程
thread = null;
}
}string.xml
<resources>
<string name="app_name">帧式布局:颜色切换</string>
<string name="bottom">底层</string>
<string name="middle">中层</string>
<string name="top">顶层</string>
<string name="start">开始</string>
<string name="stop">结束</string>
</resources>原本想用Timer定时器实现,但是不知怎么的总是报错,所有就使用了这个旧方法。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。
沃梦达教程
本文标题为:Android帧式布局实现自动切换颜色
猜你喜欢
- Flutter实现底部和顶部导航栏 2022-08-31
- Android studio实现动态背景页面 2023-05-23
- Android实现轮询的三种方式 2023-02-17
- Android实现监听音量的变化 2023-03-30
- 最好用的ios数据恢复软件:PhoneRescue for Mac 2023-09-14
- iOS 对当前webView进行截屏的方法 2023-03-01
- 详解flutter engine 那些没被释放的东西 2022-12-04
- SurfaceView播放视频发送弹幕并实现滚动歌词 2023-01-02
- Android MaterialButton使用实例详解(告别shape、selector) 2023-06-16
- 作为iOS开发,这道面试题你能答出来,说明你基础很OK! 2023-09-14
