安卓下导航栏代码编写&&使用iconfront

下导航栏代码编写

activity_main.xml

新建一个activity命名为main,整体布局设置为LinearLayout

整体设置为上下模块

上模块代码:

    <FrameLayout
        android:id="@+id/fl_main"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"></FrameLayout>

此处将会呈现按下不同底部按钮,切换的视图

下模块使用RadioGroup组件,将每个RadioButton作为切换视图的按钮,并且设置宽和高,为每个按钮命名,并且设置样式,代码如下:

<RadioGroup
        android:id="@+id/rg_main"
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:orientation="horizontal"
        android:background="@drawable/bottom_border"
        >

        <RadioButton
            android:id="@+id/chat"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:background="@drawable/main_button_bg_seleor"
            android:button="@null"
            android:gravity="center"
            android:text="@string/home"
            android:textSize="26dp"
            android:textColor="@drawable/text_color" >
        </RadioButton>


        <RadioButton
            android:id="@+id/contact"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:background="@drawable/main_button_bg_seleor"
            android:button="@null"
            android:gravity="center"
            android:text="@string/add"
            android:textSize="60dp"
            android:textColor="@drawable/text_color_add" />

        <RadioButton
            android:id="@+id/setting"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:background="@drawable/main_button_bg_seleor"
            android:button="@null"
            android:gravity="center"
            android:text="@string/mine"
            android:textSize="26dp"
            android:textColor="@drawable/text_color" />
    </RadioGroup>

呈现效果如下

请添加图片描述

MainActivity.java

在java代码中,首先找到RadioGroup

RadioGroup rg_main;
rg_main = (RadioGroup) findViewById(R.id.rg_main);

然后新建三个Fragment对应于三个界面

        chatFragment = new ChatFramgment();
        contactFragment = new ContactListFragment();
        settingFragment = new SettingFragment();

请添加图片描述

在这三个Fragment中就可以添加任意的功能模块与样式

然后为找到的RadioGroup定义一个监听器,在监听器中做判断,当点击某个按钮,对应的fragment就为该页面

private void initListenter() {
        rg_main.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(RadioGroup radioGroup, int i) {
                Fragment fragment = null;
                switch (i) {
                    case R.id.chat:
                        fragment = chatFragment;
                        break;
                    case R.id.contact:
                        fragment = (Fragment) contactFragment;
                        break;
                    case R.id.setting:
                        fragment = (Fragment) settingFragment;
                        break;
                }
                switchFragment(fragment);
            }
        });
        rg_main.check(R.id.chat);
    }

    private void switchFragment(Fragment fragment) {//切换Fragment
        FragmentManager fragmentManager = getSupportFragmentManager();
        fragmentManager.beginTransaction().replace(R.id.fl_main, fragment).commit();
    }

这样就可以进行不同页面的切换了,效果展示:

请添加图片描述

安卓使用iconfront

上一步基本功能出来了,但是样式不太好看,我们使用iconfront给她装饰一下

首先进入iconfront官网,选择喜欢的图标,点击添加入库

请添加图片描述

点击上方的购物车图标

请添加图片描述
点击添加至项目,加入到你的项目中
请添加图片描述
在我的项目中,点击下载至本地

请添加图片描述
可以得到一个download.zip的文件,解压文件,其中目录为:

请添加图片描述
打开demo_index.html,可以看到不同的图标对应的值,将值复制到string.xml文件中,并命名

请添加图片描述

    <string name="home">&#xe751;</string>
    <string name="mine">&#xe600;</string>
    <string name="add">&#xe728;</string>

复制ttf文件到安卓项目中的assets文件夹下,如果没有assets文件夹可以新建一个

请添加图片描述

在xml文件中,为该图标设置属性text:

android:text="@string/add"

在java文件中,找到这个组件,设置iconfront图标

TextView radioButton1=(TextView) findViewById(R.id.contact);
        Typeface font1 = Typeface.createFromAsset(getAssets(), "iconfont.ttf");
        radioButton1.setTypeface(font1);

启动app,就可以看到设置的图标了

请添加图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值