国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

android中實(shí)現(xiàn)底部導(dǎo)航欄

這篇具有很好參考價(jià)值的文章主要介紹了android中實(shí)現(xiàn)底部導(dǎo)航欄。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

1、引言

??????? 底部導(dǎo)航欄在app應(yīng)用中是十分常見了,大部分的安卓應(yīng)用中也都實(shí)現(xiàn)了底部導(dǎo)航欄的功能,這里我就以我以前做的一個(gè)簡(jiǎn)單小說(shuō)閱讀軟件為例,為大家演示一下底部導(dǎo)航欄的使用,需要的朋友直接復(fù)制代碼過去改寫就行了。

2、代碼實(shí)現(xiàn)

2.1、主界面布局

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">
    <FrameLayout
        android:id="@+id/fl_content"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1" />
    <RadioGroup
        android:id="@+id/rg_main"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#f5f5f5"
        android:gravity="center_vertical"
        android:orientation="horizontal"
        android:padding="3dp">
        <!--書架-->
        <com.kotlin.custom.DrawableRadioButton
            android:id="@+id/rb_main_book"
            style="@style/bottom_tag_style"
            android:text="書架"
            app:drawableSize="30dp"
            android:clickable="true"
            app:drawableTop="@drawable/book_drawable_selector" />
        <!--書城-->
        <com.kotlin.custom.DrawableRadioButton
            android:id="@+id/rb_main_store"
            style="@style/bottom_tag_style"
            android:text="書城"
            android:clickable="true"
            app:drawableSize="30dp"
            app:drawableTop="@drawable/store_drawable_selector" />
        <!--我的-->
        <com.kotlin.custom.DrawableRadioButton
            android:id="@+id/rb_main_user"
            style="@style/bottom_tag_style"
            android:text="我的"
            android:clickable="true"
            app:drawableSize="30dp"
            app:drawableTop="@drawable/user_drawable_selector" />
    </RadioGroup>
</LinearLayout>

2.2、主界面代碼

??????? 這里包含了一些進(jìn)行操作實(shí)際功能的代碼,大家復(fù)制時(shí)直接忽略就行。

package com.kotlin.novel;

import androidx.annotation.NonNull;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentActivity;
import androidx.fragment.app.FragmentTransaction;

import android.content.Intent;
import android.content.pm.ActivityInfo;
import android.graphics.Color;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.Gravity;
import android.view.KeyEvent;
import android.view.View;
import android.widget.RadioGroup;
import android.widget.Toast;

import com.google.gson.Gson;
import com.kotlin.base.BaseFragment;
import com.kotlin.data.UpdateVersion;
import com.kotlin.dialog.UpdateDialogActivity;
import com.kotlin.fragment.BookShelfFragment;
import com.kotlin.fragment.BookStoreFragment;
import com.kotlin.fragment.UserFragment;
import com.kotlin.utils.ServerUtils;
import com.kotlin.utils.SetUiSize;

import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

/**
 * 主界面導(dǎo)航切換,如果需要添加界面來(lái)這里修改
 */
public class MainActivity extends FragmentActivity {
    @Override
    protected void onResume() {//強(qiáng)制豎屏
        if (getRequestedOrientation()!=ActivityInfo.SCREEN_ORIENTATION_PORTRAIT){
            setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
        }
        super.onResume();
    }
    public static MainActivity activity;
    public RadioGroup rg_main;
    private List<BaseFragment> baseFragment;
    private int position;//選中的Fragment的對(duì)應(yīng)的位置
    private Fragment fragment;//上次切換的Fragment
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        View decorView=getWindow().getDecorView();//獲取當(dāng)前界面的DecorView
        int option=View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN |
                View.SYSTEM_UI_FLAG_LAYOUT_STABLE |//全屏隱藏狀態(tài)欄
                View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR;//更改文字顏色為深黑色
        decorView.setSystemUiVisibility(option);//設(shè)置系統(tǒng)UI元素的可見性
        getWindow().setNavigationBarColor(Color.TRANSPARENT);
        getWindow().setStatusBarColor(Color.TRANSPARENT);//將狀態(tài)欄設(shè)置為透明色
        rg_main = findViewById(R.id.rg_main);
        initFragment();
        setListener();
        activity=this;
        updateVersion();
    }
    private void setListener() {
        rg_main.setOnCheckedChangeListener(new CheckedChangeListener());
        //設(shè)置默認(rèn)選中書架
        rg_main.check(R.id.rb_main_book);
    }
    class CheckedChangeListener implements RadioGroup.OnCheckedChangeListener {
        @Override
        public void onCheckedChanged(RadioGroup group, int checkedId) {
            switch (checkedId){
                case R.id.rb_main_book://書架
                    position = 0;
                    break;
                case R.id.rb_main_store://書城
                    position = 1;
                    break;
                case R.id.rb_main_user://我的
                    position = 2;
                    break;
            }
            //根據(jù)位置得到對(duì)應(yīng)的Fragment
            BaseFragment to = getFragment();
            //替換
            switchFrament(fragment,to);
        }
    }
    /**
     * @param from 剛顯示的Fragment,馬上就要被隱藏
     * @param to 馬上要切換到的Fragment,馬上就要被顯示
     */
    private void switchFrament(Fragment from,Fragment to) {
        if(from != to){
            fragment = to;
            FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
            //判斷有沒有被添加,才切換
            if(!to.isAdded()){
                //to沒有被添加
                //from隱藏
                if(from != null){
                    ft.hide(from);
                }
                //添加to
                if(to != null){
                    ft.add(R.id.fl_content,to).commit();
                }
            }else{
                //to已經(jīng)被添加
                // from隱藏
                if(from != null){
                    ft.hide(from);
                }
                //顯示to
                if(to != null){
                    ft.show(to).commit();
                }
            }
        }
    }
    /**
     * 根據(jù)位置得到對(duì)應(yīng)的Fragment
     * @return
     */
    private BaseFragment getFragment() {
        BaseFragment fragment = baseFragment.get(position);
        return fragment;
    }
    private void initFragment() {
        baseFragment = new ArrayList<>();
        baseFragment.add(new BookShelfFragment());//書架Fragment
        baseFragment.add(new BookStoreFragment());//書城Fragment
        baseFragment.add(new UserFragment());//我的Fragment
    }
    public boolean exit;//標(biāo)識(shí)是否可以退出
    @Override
    public boolean onKeyUp(int keyCode, KeyEvent event) {
        if(event.getKeyCode()==KeyEvent.KEYCODE_BACK) {
            if(exit) {
                BookShelfFragment.fragment.handler.sendEmptyMessage(1);//刷新書架,取消選擇
                return true;//不退出
            }
        }
        return super.onKeyUp(keyCode, event);
    }
    private String result;
    /**
     * 獲取更新數(shù)據(jù)
     */
    private void updateVersion(){
        new Thread(){
            @Override
            public void run() {
                URL url;
                try {
                    url=new URL(ServerUtils.updatePath);
                    HttpURLConnection connection = (HttpURLConnection) url.openConnection();
                    connection.setReadTimeout(5000);
                    connection.setConnectTimeout(5000);
                    int code = connection.getResponseCode();
                    if (code==200){
                        InputStream is = connection.getInputStream();
                        ByteArrayOutputStream bs=new ByteArrayOutputStream();
                        int len=-1;
                        byte[] buffer=new byte[1024];
                        while ((len=is.read(buffer))!=-1){
                            bs.write(buffer,0,len);
                        }
                        result = bs.toString();
                        bs.close();
                        is.close();
                        connection.disconnect();
                    }
                } catch (Exception e) {
                }
                if (result!=null&&!result.equals("")){
                    handler.sendEmptyMessage(0);
                }
            }
        }.start();
    }
    /**
     * 提示
     * @param message
     */
    private void tip(String message){
        runOnUiThread(() -> {
            //更改默認(rèn)Toast顯示方式,需要什么直接調(diào)用方法就行
            Toast toast=Toast.makeText(MainActivity.this,
                    message,Toast.LENGTH_SHORT);
            int size= (int) (280/ SetUiSize.displayHeightDp*SetUiSize.displayHeight);
            toast.setGravity(Gravity.TOP,
                    0,size);
            toast.show();
        });
    }
    private Handler handler=new Handler(){
        @Override
        public void handleMessage(@NonNull Message msg) {
            super.handleMessage(msg);
            switch (msg.what){
                case 0:
                {
                    UpdateVersion version = new Gson().fromJson(result, UpdateVersion.class);
                    if (version.getApk_version()>ServerUtils.versionCode){
                        Intent intent=new Intent(MainActivity.this, UpdateDialogActivity.class);
                        intent.putExtra("result",result);
                        startActivity(intent);
                    }
                }
                break;
            }
        }
    };
}

2.3、自定義控件

??????? 自定義radiobutton:

package com.kotlin.custom;

import android.annotation.SuppressLint;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.widget.RadioButton;

import com.kotlin.novel.R;
/**
 * Describe:可控制drawableTop等圖片的大小
 */
@SuppressLint("AppCompatCustomView")
public class DrawableRadioButton extends RadioButton {
    private int mDrawableSize;// xml文件中設(shè)置的大小
    public DrawableRadioButton(Context context) {
        this(context, null, 0);
    }
    public DrawableRadioButton(Context context, AttributeSet attrs) {
        this(context, attrs, 0);
    }
    public DrawableRadioButton(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        Drawable drawableLeft = null, drawableTop = null, drawableRight = null, drawableBottom = null;
        TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.DrawableRadioButton);
        int n = a.getIndexCount();
        for (int i = 0; i < n; i++) {
            int attr = a.getIndex(i);
            switch (attr) {
                case R.styleable.DrawableRadioButton_drawableSize:
                    mDrawableSize = a.getDimensionPixelSize(R.styleable.DrawableRadioButton_drawableSize, 50);
                    break;
                case R.styleable.DrawableRadioButton_drawableTop:
                    drawableTop = a.getDrawable(attr);
                    break;
                case R.styleable.DrawableRadioButton_drawableBottom:
                    drawableRight = a.getDrawable(attr);
                    break;
                case R.styleable.DrawableRadioButton_drawableRight:
                    drawableBottom = a.getDrawable(attr);
                    break;
                case R.styleable.DrawableRadioButton_drawableLeft:
                    drawableLeft = a.getDrawable(attr);
                    break;
            }
        }
        a.recycle();
        setCompoundDrawablesWithIntrinsicBounds(drawableLeft, drawableTop, drawableRight, drawableBottom);
    }
    /**
     * RadioButton上、下、左、右設(shè)置圖標(biāo)
     */
    public void setCompoundDrawablesWithIntrinsicBounds(Drawable left, Drawable top, Drawable right, Drawable bottom) {
        if (left != null) {
            left.setBounds(0, 0, mDrawableSize, mDrawableSize);
        }
        if (right != null) {
            right.setBounds(0, 0, mDrawableSize, mDrawableSize);
        }
        if (top != null) {
            top.setBounds(0, 0, mDrawableSize, mDrawableSize);
        }
        if (bottom != null) {
            bottom.setBounds(0, 0, mDrawableSize, mDrawableSize);
        }
        setCompoundDrawables(left, top, right, bottom);
    }
}

??????? 自定義圓形圖標(biāo)。

package com.kotlin.custom;

import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.*;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.ColorDrawable;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import com.kotlin.novel.R;

public class CircleImageView extends androidx.appcompat.widget.AppCompatImageView {
    private static final ScaleType SCALE_TYPE = ScaleType.CENTER_CROP;
    private static final Bitmap.Config BITMAP_CONFIG = Bitmap.Config.ARGB_8888;
    private static final int COLORDRAWABLE_DIMENSION = 1;
    private static final int DEFAULT_BORDER_WIDTH = 0;
    private static final int DEFAULT_BORDER_COLOR = Color.BLACK;
    private final RectF mDrawableRect = new RectF();
    private final RectF mBorderRect = new RectF();
    private final Matrix mShaderMatrix = new Matrix();
    private final Paint mBitmapPaint = new Paint();
    private final Paint mBorderPaint = new Paint();
    private int mBorderColor = DEFAULT_BORDER_COLOR;
    private int mBorderWidth = DEFAULT_BORDER_WIDTH;
    private Bitmap mBitmap;
    private BitmapShader mBitmapShader;
    private int mBitmapWidth;
    private int mBitmapHeight;
    private float mDrawableRadius;
    private float mBorderRadius;
    private boolean mReady;
    private boolean mSetupPending;
    public CircleImageView(Context context) {
        super(context);
    }
    public CircleImageView(Context context, AttributeSet attrs) {
        this(context, attrs, 0);
    }
    public CircleImageView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        super.setScaleType(SCALE_TYPE);
        TypedArray a = context.obtainStyledAttributes(attrs,
                R.styleable.CircleImageView, defStyle, 0);
        mBorderWidth = a.getDimensionPixelSize(
                R.styleable.CircleImageView_border_width, DEFAULT_BORDER_WIDTH);
        mBorderColor = a.getColor(R.styleable.CircleImageView_border_color,
                DEFAULT_BORDER_COLOR);
        a.recycle();
        mReady = true;
        if (mSetupPending) {
            setup();
            mSetupPending = false;
        }
    }
    @Override
    public ScaleType getScaleType() {
        return SCALE_TYPE;
    }
    @Override
    public void setScaleType(ScaleType scaleType) {
        if (scaleType != SCALE_TYPE) {
            throw new IllegalArgumentException(String.format(
                    "ScaleType %s not supported.", scaleType));
        }
    }
    @Override
    protected void onDraw(Canvas canvas) {
        if (getDrawable() == null) {
            return;
        }
        canvas.drawCircle(getWidth() / 2, getHeight() / 2, mDrawableRadius,
                mBitmapPaint);
        if (mBorderWidth != 0) {
            canvas.drawCircle(getWidth() / 2, getHeight() / 2, mBorderRadius,
                    mBorderPaint);
        }
    }
    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
        setup();
    }
    public int getBorderColor() {
        return mBorderColor;
    }
    public void setBorderColor(int borderColor) {
        if (borderColor == mBorderColor) {
            return;
        }
        mBorderColor = borderColor;
        mBorderPaint.setColor(mBorderColor);
        invalidate();
    }
    public int getBorderWidth() {
        return mBorderWidth;
    }
    public void setBorderWidth(int borderWidth) {
        if (borderWidth == mBorderWidth) {
            return;
        }
        mBorderWidth = borderWidth;
        setup();
    }
    @Override
    public void setImageBitmap(Bitmap bm) {
        super.setImageBitmap(bm);
        mBitmap = bm;
        setup();
    }
    @Override
    public void setImageDrawable(Drawable drawable) {
        super.setImageDrawable(drawable);
        mBitmap = getBitmapFromDrawable(drawable);
        setup();
    }
    @Override
    public void setImageResource(int resId) {
        super.setImageResource(resId);
        mBitmap = getBitmapFromDrawable(getDrawable());
        setup();
    }
    private Bitmap getBitmapFromDrawable(Drawable drawable) {
        if (drawable == null) {
            return null;
        }
        if (drawable instanceof BitmapDrawable) {
            return ((BitmapDrawable) drawable).getBitmap();
        }
        try {
            Bitmap bitmap;
            if (drawable instanceof ColorDrawable) {
                bitmap = Bitmap.createBitmap(COLORDRAWABLE_DIMENSION,
                        COLORDRAWABLE_DIMENSION, BITMAP_CONFIG);
            } else {
                bitmap = Bitmap.createBitmap(drawable.getIntrinsicWidth(),
                        drawable.getIntrinsicHeight(), BITMAP_CONFIG);
            }
            Canvas canvas = new Canvas(bitmap);
            drawable.setBounds(0, 0, canvas.getWidth(), canvas.getHeight());
            drawable.draw(canvas);
            return bitmap;
        } catch (OutOfMemoryError e) {
            return null;
        }
    }
    private void setup() {
        if (!mReady) {
            mSetupPending = true;
            return;
        }
        if (mBitmap == null) {
            return;
        }
        mBitmapShader = new BitmapShader(mBitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);
        mBitmapPaint.setAntiAlias(true);
        mBitmapPaint.setShader(mBitmapShader);
        mBorderPaint.setStyle(Paint.Style.STROKE);
        mBorderPaint.setAntiAlias(true);
        mBorderPaint.setColor(mBorderColor);
        mBorderPaint.setStrokeWidth(mBorderWidth);
        mBitmapHeight = mBitmap.getHeight();
        mBitmapWidth = mBitmap.getWidth();
        mBorderRect.set(0, 0, getWidth(), getHeight());
        mBorderRadius = Math.min((mBorderRect.height() - mBorderWidth) / 2,
                (mBorderRect.width() - mBorderWidth) / 2);
        mDrawableRect.set(mBorderWidth, mBorderWidth, mBorderRect.width()
                - mBorderWidth, mBorderRect.height() - mBorderWidth);
        mDrawableRadius = Math.min(mDrawableRect.height() / 2,
                mDrawableRect.width() / 2);
        updateShaderMatrix();
        invalidate();
    }
    private void updateShaderMatrix() {
        float scale;
        float dx = 0;
        float dy = 0;
        mShaderMatrix.set(null);
        if (mBitmapWidth * mDrawableRect.height() > mDrawableRect.width()
                * mBitmapHeight) {
            scale = mDrawableRect.height() / (float) mBitmapHeight;
            dx = (mDrawableRect.width() - mBitmapWidth * scale) * 0.5f;
        } else {
            scale = mDrawableRect.width() / (float) mBitmapWidth;
            dy = (mDrawableRect.height() - mBitmapHeight * scale) * 0.5f;
        }
        mShaderMatrix.setScale(scale, scale);
        mShaderMatrix.postTranslate((int) (dx + 0.5f) + mBorderWidth,
                (int) (dy + 0.5f) + mBorderWidth);
        mBitmapShader.setLocalMatrix(mShaderMatrix);
    }
}

??????? 自定義控件的attrs文件。

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <!--自定義RadioButton,增加了控制圖片的功能,不要在themes文件中也加上,否則會(huì)報(bào)錯(cuò)-->
    <declare-styleable name="DrawableRadioButton">
        <attr name="drawableSize" format="dimension"/>
        <attr name="drawableTop" format="reference"/>
        <attr name="drawableLeft" format="reference"/>
        <attr name="drawableRight" format="reference"/>
        <attr name="drawableBottom" format="reference"/>
    </declare-styleable>
    <declare-styleable name="CircleImageView">
        <attr name="border_width" format="dimension"/>
        <attr name="border_color" format="color" />
    </declare-styleable>
</resources>

3、效果

3.1、書架頁(yè)面

android中實(shí)現(xiàn)底部導(dǎo)航欄,android,自定義控件,底部導(dǎo)航欄,頁(yè)面切換

3.2、書城頁(yè)面

android中實(shí)現(xiàn)底部導(dǎo)航欄,android,自定義控件,底部導(dǎo)航欄,頁(yè)面切換

3.3、我的頁(yè)面

android中實(shí)現(xiàn)底部導(dǎo)航欄,android,自定義控件,底部導(dǎo)航欄,頁(yè)面切換文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-825661.html

到了這里,關(guān)于android中實(shí)現(xiàn)底部導(dǎo)航欄的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • uniapp隱藏底部導(dǎo)航欄(非自定義底部導(dǎo)航欄)

    uniapp官方網(wǎng)址:uni設(shè)置TabBar

    2024年02月12日
    瀏覽(17)
  • 【微信小程序-原生開發(fā)】實(shí)用教程02-添加全局頁(yè)面配置、頁(yè)面、底部導(dǎo)航

    【微信小程序-原生開發(fā)】實(shí)用教程02-添加全局頁(yè)面配置、頁(yè)面、底部導(dǎo)航

    開始前,請(qǐng)先完成項(xiàng)目創(chuàng)建,詳見 【微信小程序-原生開發(fā)】實(shí)用教程01-注冊(cè)登錄賬號(hào),獲取 AppID、下載安裝開發(fā)工具、創(chuàng)建項(xiàng)目、上傳體驗(yàn) 因我們的項(xiàng)目是根據(jù)模板創(chuàng)建的,需先清理掉無(wú)效的頁(yè)面代碼,具體操作方式如下: 刪除 pages 文件夾下的所有文件 用下方代碼替換掉

    2023年04月10日
    瀏覽(20)
  • 微信小程序自定義底部導(dǎo)航欄

    微信小程序自定義底部導(dǎo)航欄

    微信小程序自定義底部導(dǎo)航欄,原生實(shí)現(xiàn),不包含其他任何第三方組件,比較干凈,開箱即用 效果預(yù)覽: 可自定義底部導(dǎo)航欄列表樣式 可自定義每個(gè)菜單的默認(rèn)、激活后的圖標(biāo)和文字樣式 可自定義是否添加中間的大圖標(biāo)菜單,當(dāng)然也可自定義大圖標(biāo)的默認(rèn)與激活樣式 可自

    2024年02月07日
    瀏覽(35)
  • Android底部導(dǎo)航欄之BottomNavigationView

    Android底部導(dǎo)航欄之BottomNavigationView

    1,首先需要添加依賴: implementation \\\'com.google.android.material:material:1.1.0\\\' 2,布局文件中引入: 3,常用屬性: app:itemTextColor 文字的顏色,可以通過 selector 來(lái)控制選中和未選中的顏色 app:itemIconTint 圖標(biāo)的顏色,可以通過 selector 來(lái)控制選中和未選中的顏色 app:itemIconSize 圖標(biāo)大小,

    2024年02月08日
    瀏覽(21)
  • Android---DslTabLayout實(shí)現(xiàn)底部導(dǎo)航欄

    Android---DslTabLayout實(shí)現(xiàn)底部導(dǎo)航欄

    1. 在 Android 項(xiàng)目中引用 JitPack 庫(kù) ?AGP 8.+ 根目錄的 settings.gradle ?AGP 8.+ 根目錄如果是??settings.gradle.kts 文件 ?AGP 8.- 根目錄的 build.gradle 2. 添加依賴 ?在APP目錄中的 build.gradle 3. 布局 activity_main.xml 4. 底部 tab_item.xml 布局 5. 每個(gè)底部 tab 對(duì)應(yīng)的 fragment a. DiscoveryFragment b. fragment_dis

    2024年02月20日
    瀏覽(23)
  • Android BottomNavigation底部導(dǎo)航欄使用

    Android BottomNavigation底部導(dǎo)航欄使用

    原文地址: Android BottomNavigation底部導(dǎo)航欄使用 - Stars-One的雜貨小窩 本文側(cè)重點(diǎn)記錄一些特殊的樣式設(shè)置,所以基本使用這里就簡(jiǎn)單概述一下,詳細(xì)圖文可以去找其他人的博文 1.創(chuàng)建對(duì)應(yīng)的menu菜單文件 2.xml布局引用menu菜單 3.啟動(dòng)Activity預(yù)覽效果 可以使用 setOnItemSelectedListener 方法監(jiān)

    2024年02月12日
    瀏覽(54)
  • 微信小程序自定義導(dǎo)航欄機(jī)型適配--底部Tabbar--view高度--底部按鈕適配

    微信小程序自定義導(dǎo)航欄機(jī)型適配--底部Tabbar--view高度--底部按鈕適配

    自定義微信小程序頭部導(dǎo)航欄 自定義微信小程序頭部導(dǎo)航欄,有幾種方式 方式一 定義此方法后,頭部的導(dǎo)航欄會(huì)去掉,導(dǎo)航欄下的元素會(huì)直接向上移動(dòng)到原導(dǎo)航欄的位置,可以再app.json配置成全局沉浸式導(dǎo)航欄,以及在單頁(yè)面配置沉浸式導(dǎo)航欄。 方式二 使用組件 這里使用

    2024年02月02日
    瀏覽(23)
  • 微信小程序、uniapp自定義底部導(dǎo)航欄(附源碼)

    微信小程序、uniapp自定義底部導(dǎo)航欄(附源碼)

    需求分析 目前開發(fā)一套“同城跑腿平臺(tái)”小程序,面向用戶和騎手,需要兩個(gè)不同的底部導(dǎo)航,uniapp原生導(dǎo)航不滿足要求。所以需要自定義導(dǎo)航欄。 隨著自定義導(dǎo)航卡完成,切換選項(xiàng)卡頁(yè)面總是閃爍,在網(wǎng)上也沒有搜到完整的解決方法,總不能完美解決。現(xiàn)在我有一個(gè)方法

    2024年02月04日
    瀏覽(28)
  • 微信小程序基于vant的自定義底部導(dǎo)航欄

    微信小程序基于vant的自定義底部導(dǎo)航欄

    基于vant-weapp的底部導(dǎo)航欄,首先根據(jù)vant官網(wǎng)安裝vant https://vant-ui.github.io/vant-weapp/#/quickstart 由于vant的Tabbar 標(biāo)簽欄自帶翻頁(yè)效果,而且不夠美觀,且小程序最多只支持10個(gè)頁(yè)面棧,點(diǎn)擊多了會(huì)導(dǎo)致報(bào)錯(cuò) 報(bào)錯(cuò)如下? 將wx.navigateTo改為wx.redirectTo在反復(fù)多點(diǎn)很多次之后依然會(huì)報(bào)錯(cuò),所

    2024年02月13日
    瀏覽(33)
  • uni-app uView自定義底部導(dǎo)航欄

    uni-app uView自定義底部導(dǎo)航欄

    因項(xiàng)目需要自定義底部導(dǎo)航欄,我把它寫在了組件里,基于uView2框架寫的(vue2); ? 在components下創(chuàng)建tabbar.vue文件,代碼如下: ?app.vue (有沒有大佬知道為什么這個(gè)樣式加載app.vue里才生效) ?pages.json配置 頁(yè)面使用: ( mine.vue ) 注: current是底部導(dǎo)航欄的下標(biāo),你在tabb

    2024年02月14日
    瀏覽(37)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包