开源项目LookLook的学习笔记(未完待续)

MVP架构,网络请求库是RxJava & Retrofit + okhttp 图片加载是glide。
使用DrawerLayout + NavigationView 实现了侧滑菜单。
数据展示是RecyclerView 。

DrawerLayout + NavigationView

DrawerLayout 是google借鉴第三方控件如MenuDrawer提供的官方控件,用来侧滑菜单效果。DrawerLayout 分为侧滑菜单和主内容去,可以根据手势进行显示和隐藏。
现在通过对侧滑菜单中的选项进行点击,来切换主内容区中的fragment< 已实现内容的改变。

<!-- A DrawerLayout is intended to be used as the top-level content view using match_parent for both width and height to consume the full space available. -->
<android.support.v4.widget.DrawerLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <!-- As the main content view, the view below consumes the entire
         space available using match_parent in both dimensions. -->
    <FrameLayout
        android:id="@+id/content_frame"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
    <!-- android:layout_gravity="start" tells DrawerLayout to treat
         this as a sliding drawer on the left side for left-to-right
         languages and on the right side for right-to-left languages.
         The drawer is given a fixed width in dp and extends the full height of
         the container. A solid background is used for contrast
         with the content view. -->
    <ListView
        android:id="@+id/left_drawer"
        android:layout_width="240dp"
        android:layout_height="match_parent"
        android:choiceMode="singleChoice"
        android:divider="@android:color/transparent"
        android:dividerHeight="0dp"
        android:background="#111"/>
</android.support.v4.widget.DrawerLayout>

主内容区域的布局代码要放在侧滑菜单布局的前面,以帮助DrawerLayout来区分;侧滑菜单的部分的布局可以设置layout_gravity属性,来设置侧滑菜单是靠左还是靠右。用DrawerLayout.closeDrawer和openDrawer来控制侧滑菜单的显示和隐藏。

Navigation是一个导航菜单框架,一般用来配合DrawerLayout使用,来实现侧滑菜单的部分。
它有两个自定义属性 headlayout 和 menu,用来实现侧滑菜单的头部和列表部分。
用setNavigationItemSelectedListener来设置菜单项被点击时候的回调。

//如果是5.0以上 则使用toolbar替换actionBar
setSupportActionBar(toolbar);

//当前手机版本是否大于5.0 
if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.LOLLIPOP){
    //对toolbar中的textview添加动画
    ``````
}

MVP

粗略,不准确的总结。
model是数据层 包括数据的获取,存储等
view是视图层,获取录入的数据,展示界面
presenter是逻辑处理层,调度model和view
view和presenter通过接口相互调用


    /*Presenter中的一个方法*/
    @Override
    public void getMeiziData(int t) {
        //显示进度条  对界面的操作  调用view的方法
        mMeiziFragment.showProgressDialog();
        //网络请求获取数据  数据的操作   调用model
        Subscription subscription = ApiManage.getInstence().getGankService().getMeizhiData(t)
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new Observer<MeiziData>() {
                    @Override
                    public void onCompleted() {

                    }

                    @Override
                    public void onError(Throwable e) {
                        //获取失败   取消进度条 显示toast  界面的操作  调用view层
                        mMeiziFragment.hidProgressDialog();
                        mMeiziFragment.showError(e.getMessage());
                    }

                    @Override
                    public void onNext(MeiziData meiziData) {
                        //获取成功 取消进度条  更新数据  界面的操作 调用view层
                        mMeiziFragment.hidProgressDialog();
                        mCacheUtil.put(Config.ZHIHU, gson.toJson(meiziData));
                        mMeiziFragment.updateMeiziData(meiziData.getResults());
                    }
                });
        addSubscription(subscription);
    }

结构图

在项目比较小的时候,可以用这种结构,将 presenter,adapter 等按类型存放。

RecyclerView

RecyclerView实现加载更多。
在滑动结束时判断是否已经滑动到底部。
new RecyclerView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
                super.onScrollStateChanged(recyclerView, newState);
            }

            @Override
            public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                super.onScrolled(recyclerView, dx, dy);

                if (dy > 0) //向下滚动
                {

                    //当前屏幕内可以容纳多少个可见的item
                    int visibleItemCount = mLinearLayoutManager.getChildCount();
                    //当前RecyclerView一共有多少个item
                    int totalItemCount = mLinearLayoutManager.getItemCount();
                    // 在当前屏幕中第一个可见的item处于RecyclerView的第几个
                    int pastVisiblesItems = mLinearLayoutManager.findFirstVisibleItemPosition();
                    if (!loading && (visibleItemCount + pastVisiblesItems) >= totalItemCount) {
                        loading = true;
                        loadMoreDate();
                    }
                }
            }
        };
深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值