Android UI之自定义——最简单的仿QQ音乐歌词颜色渐变

转载请注明本文出自JFlex的博客http://blog.csdn.net/jflex/article/details/46550849,请尊重他人的辛勤劳动成果,谢谢!

Android UI之自定义——最简单的仿QQ音乐歌词颜色渐变

记得刚开始做android的时候,就发现QQ音乐歌词颜色渐变的效果,就在网上搜索过,但是就是没有找到满意的。今天突然用QQ音乐听歌的时候,看到歌词颜色渐变,决定来分析看看,没想到实现原来如此简单。这篇只是将最简单的歌词颜色渐变功能,不包括歌词滚动等效果。


首先来看下QQ音乐歌词界面

这里写图片描述


实现步骤

从界面上可以看出,是通过不同颜色的文本叠加所形成的视觉效果。那么android文本一般使用TextView实现,那就来试试用TextView在layout中实现。

  1. Layout尝试
    需要一个比较长的TextView和一个短的TextView

    <RelativeLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:singleLine="true"
            android:text="最简单的仿QQ音乐歌词颜色渐变"
            android:textAppearance="?android:attr/textAppearanceLarge"
            android:textColor="#726463" />
    
        <TextView
            android:layout_width="40dp"
            android:layout_height="wrap_content"
            android:singleLine="true"
            android:text="最简单的仿QQ音乐歌词颜色渐变"
            android:textAppearance="?android:attr/textAppearanceLarge"
            android:textColor="#39DF7C" />
    </RelativeLayout>
    
    

    上面一个确实是一个长点的TextView和一个短点的TextView,效果如下
    这里写图片描述
    按照设置40dp的width,应该显示2个字才对。所以失败

接下来修改layout,关键属性android:ellipsize,当设置这个属性为none,如下

 <RelativeLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:singleLine="true"
            android:text="最简单的仿QQ音乐歌词颜色渐变"
            android:textAppearance="?android:attr/textAppearanceLarge"
            android:textColor="#726463" />

        <TextView
            android:layout_width="40dp"
            android:layout_height="wrap_content"
            android:ellipsize="none"
            android:singleLine="true"
            android:text="最简单的仿QQ音乐歌词颜色渐变"
            android:textAppearance="?android:attr/textAppearanceLarge"
            android:textColor="#39DF7C" />
    </RelativeLayout>

效果图如下:
这里写图片描述
貌似好像成功了,接下来看下面封装LRCTextView
2. LRCTextView封装
直接上代码

package com.example.qqmusiclrc.view;

import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Color;
import android.util.AttributeSet;
import android.view.View;
import android.widget.RelativeLayout;
import android.widget.TextView;

@SuppressLint("NewApi")
public class LRCTextView extends RelativeLayout {
    private TextView tvDefault;
    private TextView tvSelect;
    private String lrc = "我是测试歌词 我是测试歌词 我是测试歌词";

    /**
     * 设置歌词
     * 
     * @param lrc
     */
    public void setLrc(String lrc) {
        this.lrc = lrc;
        tvDefault.setText(lrc);
        tvSelect.setText(lrc);
    }

    public LRCTextView(Context context, AttributeSet attrs, int defStyleAttr,
            int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
        init();
    }

    public LRCTextView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        init();
    }

    public LRCTextView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    public LRCTextView(Context context) {
        super(context);
        init();
    }

    private void init() {
        tvDefault = new TextView(getContext());
        tvDefault.setText(lrc);
        tvDefault.setTextColor(Color.parseColor("#726463"));
        tvDefault.setEllipsize(null);
        tvDefault.setSingleLine();
        tvDefault.setTextSize(16);

        tvSelect = new TextView(getContext());
        tvSelect.setTextColor(Color.parseColor("#39DF7C"));
        tvSelect.setText(lrc);
        tvSelect.setEllipsize(null);
        tvSelect.setSingleLine();
        tvSelect.setTextSize(16);
        addView(tvDefault);
        addView(tvSelect);
        tvSelect.setWidth(0);
    }

    @Override
    protected void onWindowVisibilityChanged(int visibility) {
        super.onWindowVisibilityChanged(visibility);
        if (visibility == View.VISIBLE) {
            postDelayed(new Runnable() {
                @Override
                public void run() {
                    setPercent(percent);
                }
            }, 10);
        }
    }

    private float percent;

    /**
     * 设置颜色渐变百分比
     * 
     * @param percent
     */
    public void setPercent(float percent) {
        this.percent = percent;
        setSelectWidth((int) (getSelectWidth() * percent));
    }

    private int getSelectWidth() {
        return tvDefault.getWidth();
    }

    private void setSelectWidth(int pixels) {
        if (pixels <= getSelectWidth()) {
            tvSelect.setWidth(pixels);
        }
    }
}

代码很简单,我就不多说啥了。

最后

上传demo,点击这里下载

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
Android 系统界面的一部分是 SystemUI。它是 Android 操作系统的一个系统应用程序,提供了通知栏、状态栏、快捷设置等重要的用户界面元素。如果您想要自定义 SystemUI,可以按照以下步骤进行操作: 1. 首先,您需要了解 SystemUI 的架构和工作原理。它是一个基于 Java 的应用程序,使用 Android 的 Binder 机制与系统服务通信。您可以通过下载 Android 源代码并查看源代码来深入了解其工作原理。 2. 然后,您需要创建一个新的 Android 应用程序项目,并将其配置为 SystemUI 扩展。这可以通过在 manifest 文件中声明一个文件提供者来实现。例如: ```xml <provider android:name=".SystemUIProvider" android:authorities="com.example.systemui.provider" android:exported="true" android:grantUriPermissions="true"> <meta-data android:name="com.android.systemui" android:resource="@xml/systemui_extensions" /> </provider> ``` 其中,`SystemUIProvider` 是您创建的文件提供者类的名称,`com.example.systemui.provider` 是您自己的包名,`@xml/systemui_extensions` 是您的扩展配置文件的资源 ID。 3. 接下来,您需要创建一个扩展配置文件,以指定 SystemUI 如何加载您的扩展。例如: ```xml <extensions> <extension class="com.example.systemui.MyExtension" targetPackage="com.android.systemui" targetClass="com.android.systemui.statusbar.phone.PhoneStatusBar" attach="true" /> </extensions> ``` 其中,`MyExtension` 是您创建的扩展类的名称,`com.android.systemui.statusbar.phone.PhoneStatusBar` 是您要扩展的目标类的完全限定名称。 4. 最后,您需要创建一个扩展类,并实现所需的功能。例如,如果您想要添加一个新的按钮到状态栏,您可以创建一个 `View`,并将其添加到状态栏中。您可以使用 Android 提供的 `StatusBarManager` 类来添加视图。 以上是自定义 Android SystemUI 的大致步骤,希望对您有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值