新款builder仿照qq音乐HD版左侧fragment效果

1.效果图:

临时增加一下builder文件,这东西很新

apply plugin: 'com.android.application'

android {
    compileSdkVersion 29
    buildToolsVersion "28.0.3"
    defaultConfig {
        applicationId "com.example.administrator.testz"
        minSdkVersion 21
        targetSdkVersion 29
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    androidTestImplementation('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    implementation 'androidx.appcompat:appcompat:1.0.2'
    implementation 'com.google.android.material:material:1.0.0'
    testImplementation 'junit:junit:4.12'
}

2.源码下载地址:https://github.com/wrs13634194612/QQMusicFragment

文件太多了,我这篇博客只是贴一下核心代码,需要源码的,请自行下载

3.主界面

package com.example.administrator.testz;


import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.view.Gravity;
import android.widget.Toast;


public class TextActivity extends AppCompatActivity implements VerticalTabLayout.OnTabSelectedListener {
    VerticalTabLayout vTabLayout;
    private ViewPager viewPager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_test);

        vTabLayout = (VerticalTabLayout) findViewById(R.id.tab_layout_4);
        viewPager=findViewById(R.id.myViewPager);

        for (int i = 0; i < 3; i++) {
            vTabLayout.addTab(vTabLayout.newTab().setText("界面 " + i).setIcon(R.drawable.ic_selector).setIconGravity(Gravity.LEFT));
        }
        vTabLayout.setOnTabSelectedListener(this);


         TabPagerAdapter tabPagerAdapter=new  TabPagerAdapter(getSupportFragmentManager(),3);
        viewPager.setAdapter(tabPagerAdapter);
    }

    @Override
    public void onTabSelected(VerticalTabLayout.Tab tab, int position) {
        //Toast.makeText(getApplicationContext(), "onTabSelected: " + position, Toast.LENGTH_SHORT).show();
        viewPager.setCurrentItem(position);
    }

    @Override
    public void onTabReleased(VerticalTabLayout.Tab tab, int position) {

    }


    private class TabPagerAdapter extends FragmentPagerAdapter {

        private int tabCount;

        public TabPagerAdapter(FragmentManager fm, int tabCount) {
            super(fm);
            this.tabCount=tabCount;
        }

        @Override
        public Fragment getItem(int i) {
            switch (i){
                case 0:
                    return  new ContactFragment();
                case 1:
                    return  new ContactHistoryFragment();
                case 2:
                    return  new FavoriteFragment();
            }
            return null;
        }

        @Override
        public int getCount() {
            return tabCount;
        }
    }
}

4.自定义的view:

package com.example.administrator.testz;

import android.annotation.TargetApi;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.drawable.Drawable;
import android.os.Build;
import android.util.AttributeSet;
import android.view.Gravity;
import android.view.View;

/**
 * Created by qwang on 2016/8/12.
 */
public class TabItem extends View {

    private Drawable mIcon;
    private String mText;
    private int mIconGravity = Gravity.LEFT;
    private int mIconWidth;
    private int mIconHeight;

    public TabItem(Context context) {
        super(context);
        init(context, null);
    }

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

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

    @TargetApi(Build.VERSION_CODES.LOLLIPOP)
    public TabItem(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
        init(context, attrs);
    }

    private void init(Context context, AttributeSet attrs) {
        if (attrs == null) {
            return;
        }
        TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.TabItem);
        mIcon = typedArray.getDrawable(R.styleable.TabItem_icon);
        mText = typedArray.getString(R.styleable.TabItem_text);
        mIconGravity = typedArray.getInt(R.styleable.TabItem_icon_Gravity, mIconGravity);
        mIconWidth = (int) typedArray.getDimension(R.styleable.TabItem_iconWidth, 0);
        mIconHeight = (int) typedArray.getDimension(R.styleable.TabItem_iconHeight, 0);
        typedArray.recycle();
    }

    public Drawable getIcon() {
        return mIcon;
    }

    public void setIcon(Drawable mIcon) {
        this.mIcon = mIcon;
    }

    public String getText() {
        return mText;
    }

    public void setText(String mText) {
        this.mText = mText;
    }

    public int getIconGravity() {
        return mIconGravity;
    }

    public int getIconHeight() {
        return mIconHeight;
    }

    public void setIconHeight(int mIconHeight) {
        this.mIconHeight = mIconHeight;
    }

    public int getIconWidth() {
        return mIconWidth;
    }

    public void setIconWidth(int mIconWidth) {
        this.mIconWidth = mIconWidth;
    }

    public void setIconGravity(int mIconGravity) {
        this.mIconGravity = mIconGravity;
    }
}

5.引用自定义控件布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white"
    android:orientation="horizontal">


    <com.example.administrator.testz.VerticalTabLayout
        android:id="@+id/tab_layout_4"
        android:layout_width="80dp"
        android:layout_height="match_parent"
        android:background="@drawable/blue_angle"
        app:tabHeight="30dp"
        app:tabIconPadding="8dp"
        app:tabIndicatorColor="@android:color/holo_green_dark"
        app:tabIndicatorCorners="15dp"
        app:tabPaddingRight="20dp"
        app:tabSelectedTextColor="@android:color/holo_red_dark"
        app:tabTextColor="#555555"
        app:tabTextSize="10dp"
        app:tabViewGravity="right" />


    <android.support.v4.view.ViewPager
        android:id="@+id/myViewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />



</LinearLayout>

end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值