精华内容
下载资源
问答
  • 微信UI实例:图片瀑布流布局源码,现在听到瀑布流,已经没有什么新鲜感了,在jQuery那几年非常火热,在HTML5时代,瀑布流更是使用广泛了,那么今天咱们来看一看,运行在微信中的小程序里的瀑布流是如何实现的,源码...
  • 圆角按钮,或布局可以在xml文件中实现,但也可以使用图片直接达到所需的效果,以前版本的微信就使用了这种方法。 实现效果图:   不得不说,这种做法还是比较方便的。 源代码: MainActivity(没写任何...

    圆角按钮,或布局可以在xml文件中实现,但也可以使用图片直接达到所需的效果,以前版本的微信就使用了这种方法。

    实现效果图:

      

    不得不说,这种做法还是比较方便的。

    源代码:


    MainActivity(没写任何代码,效果全在布局文件中实现):

    package com.android_settings;
    
    import android.app.Activity;
    import android.os.Bundle;
    
    public class MainActivity extends Activity {
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_main);
    	}
    
    }
    


    activity_main:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="#eee"
        android:orientation="vertical" >
    
        <LinearLayout
            android:id="@+id/title"
            android:layout_width="fill_parent"
            android:layout_height="45dp"
            android:background="@drawable/title_bar"
            android:gravity="center_horizontal|center_vertical" >
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="设置"
                android:textColor="#ffffff"
                android:textSize="20sp" />
        </LinearLayout>
    
        <ScrollView
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:scrollbarStyle="outsideOverlay" >
    
            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical" >
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="14dp"
                    android:background="@drawable/preference_first_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="个人信息"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:clickable="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="二维码名片"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="腾讯微博"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_last_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="二维码名片"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <!-- ******************************************************************** -->
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="14dp"
                    android:background="@drawable/preference_first_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="我的帐号"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_last_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="手机通讯录匹配"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <!-- *********************************************************************** -->
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="14dp"
                    android:background="@drawable/preference_single_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="聊天背景"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <!-- *********************************************************************** -->
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="14dp"
                    android:background="@drawable/preference_first_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="通用"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="插件"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="黑名单"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="隐私"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="系统通知"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_last_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="流量统计"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
                <!-- ******************************************************************** -->
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="14dp"
                    android:background="@drawable/preference_first_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="帮助与反馈"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:background="@drawable/preference_last_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="关于微信"
                        android:textColor="#000"
                        android:textSize="17sp" />
    
                    <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:scaleType="matrix"
                        android:src="@drawable/mm_submenu" />
                </RelativeLayout>
    
                <!-- *********************************************************************** -->
    
                <RelativeLayout
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="14dp"
                    android:background="@drawable/preference_single_item"
                    android:clickable="true"
                    android:gravity="center_vertical" >
    
                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:padding="8dp"
                        android:text="清空聊天记录"
                        android:textColor="#000"
                        android:textSize="17sp" />
                </RelativeLayout>
                <!-- *********************************************************************** -->
    
                <Button
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginBottom="14dp"
                    android:layout_marginLeft="12dp"
                    android:layout_marginRight="12dp"
                    android:layout_marginTop="14dp"
                    android:background="@drawable/btn_style_red"
                    android:gravity="center"
                    android:padding="4dp"
                    android:text="退出登录"
                    android:textColor="#fff"
                    android:textSize="18sp" />
            </LinearLayout>
        </ScrollView>
    
    </LinearLayout>
    drawable文件夹下的xml文件:

    preference_first_item.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <selector
      xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:state_enabled="true" android:state_selected="true" android:drawable="@drawable/ic_preference_first_pressed" />
        <item android:state_enabled="true" android:state_pressed="true" android:drawable="@drawable/ic_preference_first_pressed" />
        <item android:drawable="@drawable/ic_preference_first_normal" />
    </selector>


    drawable文件夹下的其他布局文件,都大同小异,我这里就不一一给出来了。但这里需要注意的就是,圆角布局块是由上、中、下三块图拼起来的。。。

    如下图:

        

    需要源代码的可以我上传的资源中下载。


    展开全文
  • 微信布局

    2018-06-14 10:08:22
    整个页面布局样式 嵌套使用规范 ul 和 li 嵌套实现横向等分添加 元素 组件 wx:for scroll-view template wx:if hidden textarea form WXSS page container 距离顶部绝对定位 距离底部绝对定位 距离左边绝对定位 ...

    微信布组件

    WXML

    整个页面布局样式

    定义容器 container 确定整体是横向还是纵向

    <view class="container">
    </view>

    标题命名

    <view class='title'>
    </view>

    横向命名

    <view class='row'>
    </view>

    纵向命名

    <view class='col'>
    </view>

    文本命名

    <textarea  class='text'>
    </textarea>

    底部命名

    <view class='bottom'>
    </view>

    页脚命名

    <view class='footer'>
    </view>
     ```
    输入框命名
    ```xml
    <view class="input">
        <input bindfocus="bindfocus" bindblur='bindblur'  value="{{addinput}}" type="text" />
    </view>
    
    
    
    
    <div class="se-preview-section-delimiter"></div>
    

    嵌套使用规范

    通过上下命名连接的方式组成

    页脚里面嵌套了input 、 send 、add

    <!--提交框-->
    <view  class="footer">
        <view  class="footinput">
            <view class="input"><input bindfocus="bindfocus" bindblur='bindblur'  value="{{addinput}}" type="text" /></view>
        </view>
        <view wx:if="{{sendflag}}" class="foodsend">
            <view class="send">发送</view>
        </view>
        <view wx:else class="footadd" bindtap="bindtapimg">
          <view class="addbroder">
              <image src="../../images/hotapp_add.png"/>
          </view>
        </view>
    </view>
    
    
    
    
    <div class="se-preview-section-delimiter"></div>
    

    ul 和 li 嵌套实现横向等分添加 元素

    wxml 布局

    <view class="footaddbox">
          <ul>
             <li>
               <view class="footaddimg"><image src="../../images/hotapp_img.png"></image></view>
               <text>添加图片</text>
             </li>
              <li>
               <view class="footaddimg"><image src="../../images/hotapp_img.png"></image></view>
               <text>添加图片</text>
             </li>
              <li>
               <view class="footaddimg"><image src="../../images/hotapp_img.png"></image></view>
               <text>添加图片</text>
             </li>
          </ul>
      </view>
    
    
    
    
    <div class="se-preview-section-delimiter"></div>
    

    wxss 样式

    .footaddbox{
      height: 200rpx;
    }
    .footaddbox ul{
      display: flex;
      height: 100%;
      flex-direction: row;
    }
    .footaddbox ul li{
      flex: 1;
      height: 100%;
      font-size: 12px;
      color: #9a9a9a;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
    }
    .footaddimg{
      border: 1px solid #ccc;
      border-radius: 20rpx;
      margin: 10rpx;
      padding: 30rpx;
    }
    
    
    
    
    <div class="se-preview-section-delimiter"></div>
    

    组件

    wx:for

    wx:key 设置成index 提高效率

    <block wx:for="{{feedback}}" wx:key="index">
      <view>item</view>
      <view>index</view>
    </block>
    
    
    
    
    <div class="se-preview-section-delimiter"></div>
    

    scroll-view

    滑动到底监听 bindscrolltolower | 沿Y轴滑动 scroll-y

    <scroll-view class="scrollview" scroll-y="true" bindscrolltolower="friendListsScrollHandler">
    </scroll-view>
    
    
    
    
    <div class="se-preview-section-delimiter"></div>
    
    .scrollview {
     height: 100%;
    }

    template

    定义

    //addtell.wxml
    <template name="addtell">
      <view>
       我是template
      </view>
    </template>

    引用

    <import src="/template/addtell.wxml" />
    <template is="addtell" data="{{...addtell}}" />
      data: {
        addtell: {
        },
      },

    wx:if

     <view wx:if="{{sendflag}}" class="foodsend">
          <view class="send">发送</view>
        </view>
        <view wx:else class="footadd" bindtap="bindtapimg">
          <view class="addbroder">
            <image src="../../images/hotapp_add.png" />
          </view>
        </view>

    hidden

      <view hidden="{{flag ? true : false}}">
      </view>

    textarea

      <textarea  class='text' value="{{item.value.content}}" maxlength="5000" auto-height="true"
            placeholder-class="placeholder"
            name="content" focus="{{focus}}" auto-focus="true"  placeholder="点击添加文本"   />

    form

    <form bindsubmit="onSubmit">
    <view class='bottom'>
            <button formType="submit" class='btn success'>保存</button>
        </view>
    /**
       * 保存数据事件
        */
     onSubmit: function(event) {
     },

    WXSS

    page

    page {
      height: 100%;
      width: 100%;
    }

    container

    .container {
      height: 100%;
      width: 100%;
      flex-direction: column;
    }

    距离顶部绝对定位

      position: absolute;
      top:40rpx;

    距离底部绝对定位

      position: absolute;
      bottom:40rpx;

    距离左边绝对定位

      position: absolute;
      left:40rpx;

    距离右边绝对定位

      position: absolute;
      right:40rpx;

    设置阴影

    box-shadow: 10rpx 10rpx 20rpx rgba(0, 0, 0, 0.10), -10rpx 10rpx 20rpx rgba(0, 0, 0, 0.10);

    设置圆角

    border-radius: 40rpx;

    设置边框线

     border: 4rpx solid #555;

    设置背景颜色

     background-color: #cfcfcf;

    设置容器中内容都居中对齐

     flex-flow:column nowrap;
     justify-content: center;
     align-items: center;
     width: 100%;
     height: 100%;

    单独设置下边框线

     border-bottom: 1px solid #f5f5f5;

    设置文字居中

     width: 90%;
     text-align: center;
     height: 60rpx;
     font-size: 38rpx;

    嵌套申明class

    .row{
    }
    .row .text{
    }

    display flex 下设置等比填充

    flex :1

    .bottom{
        width: 100%;
        background: #fff;
        display: flex;
        flex-flow:row nowrap;
        justify-content: center;
        align-items: center;
    }
    .bottom .btn{
        flex: 1;
        line-height: 2;
        padding-top: 10rpx;//相对父组件上边缘距离
        padding-bottom: 10rpx;
        margin: 30rpx 30rpx;//left rigth
    }
    .btn.success{
        background: #1aad19;
        color: #fff;
    }
    .btn.del{
        background: #e64340;
        color: #fff;
    }
    <view class='bottom'>
             <button formType="submit" class='btn success'>保存</button>
            <button class='btn del' bindtap="onDelete">删除</button>
    </view>
    展开全文
  • bottom_bar.xml的思路是通过LinearLayout布局,一共放四个LinearLayout,给每个LinearLayout添加点击事件,同时每个LinearLayout内有包含一个ImgButton和一个TextView,ImgButton放置图标并屏蔽点击事件,TextView...

    比起侧边栏,个人感觉底部按钮切换界面的方式对于使用者来说,操作更方便,更直观,由此决定写个Demo备着。
    主界面
    主界面xml:

    <include layout="@layout/title_bar"/>
    
        <FrameLayout
            android:id="@+id/id_content"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1" >
        </FrameLayout>
    
        <include layout="@layout/bottom_bar"/>

    首先include一个title作为不同界面标题的提示。
    其次放一个FrameLayout放需要加载的界面。
    最后include底部按钮。
    title_bar.xml就正中间一个TextView,很简单,代码省略。
    bottom_bar.xml的思路是通过LinearLayout布局,一共放四个LinearLayout,给每个LinearLayout添加点击事件,同时每个LinearLayout内有包含一个ImgButton和一个TextView,ImgButton放置图标并屏蔽点击事件,TextView显示按钮名称。

    <LinearLayout
                android:id="@+id/TabBtnWeChat"
                android:orientation="vertical"
                android:layout_width="0dp"
                android:layout_weight="1"
                android:gravity="center"
                android:descendantFocusability="beforeDescendants"
                android:layout_height="match_parent">
                <ImageButton
                    android:id="@+id/imgWeChat"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:background="@android:color/transparent"
                    android:clickable="false"
                    android:src="@drawable/tab_weixin_pressed"/>
                <TextView
                    android:text="WeChat"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:gravity="center"/>
            </LinearLayout>

    android:descendantFocusability=”beforeDescendants”会覆盖子类控件而直接获得焦点。
    剩余三个以此类推设置。
    MainActivity.java

    package com.example.zhan.mfragment;
    
    import android.app.FragmentManager;
    import android.app.FragmentTransaction;
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.view.View;
    import android.widget.ImageButton;
    import android.widget.LinearLayout;
    import android.widget.TextView;
    
    public class MainActivity extends AppCompatActivity implements View.OnClickListener{
    
        private MainWeChat mWeChat;
        private MainFriend mFriend;
        private MainAddress mAddress;
        private MainSettings mSettings;
    
        private LinearLayout mTabBtnWeChat;
        private LinearLayout mTabBtnFriend;
        private LinearLayout mTabBtnAddress;
        private LinearLayout mTabBtnSettings;
    
        private FragmentManager fragmentManager;
    
        TextView t;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            initViews();
            fragmentManager = getFragmentManager();
            setTabSelection(0);
            t = (TextView) findViewById(R.id.Title1);
            t.setText("WeChat");
        }
    
        private void initViews()
        {
    
            mTabBtnWeChat = (LinearLayout) findViewById(R.id.TabBtnWeChat);
            mTabBtnFriend = (LinearLayout) findViewById(R.id.TabBtnFriend);
            mTabBtnAddress = (LinearLayout) findViewById(R.id.TabBtnAddress);
            mTabBtnSettings = (LinearLayout) findViewById(R.id.TabBtnSettings);
    
            mTabBtnWeChat.setOnClickListener(this);
            mTabBtnFriend.setOnClickListener(this);
            mTabBtnAddress.setOnClickListener(this);
            mTabBtnSettings.setOnClickListener(this);
        }
    
        @Override
        public void onClick(View v) {
            switch (v.getId())
            {
                case R.id.TabBtnWeChat:
                    t.setText("WeChat");
                    setTabSelection(0);
                    break;
                case R.id.TabBtnFriend:
                    t.setText("Friend");
                    setTabSelection(1);
                    break;
                case R.id.TabBtnAddress:
                    t.setText("Address");
                    setTabSelection(2);
                    break;
                case R.id.TabBtnSettings:
                    t.setText("Settings");
                    setTabSelection(3);
                    break;
                default:
                    break;
            }
        }
    
        /**
         * 根据传入的index参数来设置选中的tab页。
         */
        private void setTabSelection(int index)
        {
            // 重置按钮
            resetBtn();
            // 开启一个Fragment事务
            FragmentTransaction transaction = fragmentManager.beginTransaction();
            // 先隐藏掉所有的Fragment,以防止有多个Fragment显示在界面上的情况
            hideFragments(transaction);
            switch (index) {
                case 0:
                    // 当点击了消息tab时,改变控件的图片和文字颜色
                    ((ImageButton) mTabBtnWeChat.findViewById(R.id.imgWeChat)).setImageResource(R.drawable.tab_weixin_pressed);
                    if (mWeChat == null) {
                        // 如果MessageFragment为空,则创建一个并添加到界面上
                        mWeChat = new MainWeChat();
                        transaction.add(R.id.id_content, mWeChat);
                    } else {
                        // 如果MessageFragment不为空,则直接将它显示出来
                        transaction.show(mWeChat);
                    }
                    break;
                case 1:
                    ((ImageButton) mTabBtnFriend.findViewById(R.id.imgFriend)).setImageResource(R.drawable.tab_find_frd_pressed);
                    if (mFriend == null) {
                        mFriend = new MainFriend();
                        transaction.add(R.id.id_content, mFriend);
                    } else {
                        transaction.show(mFriend);
                    }
                    break;
                case 2:
                    ((ImageButton) mTabBtnAddress.findViewById(R.id.imgAddress)).setImageResource(R.drawable.tab_address_pressed);
                    if (mAddress == null) {
                        mAddress = new MainAddress();
                        transaction.add(R.id.id_content, mAddress);
                    } else {
                        transaction.show(mAddress);
                    }
                    break;
                case 3:
                    ((ImageButton) mTabBtnSettings.findViewById(R.id.imgSettings)).setImageResource(R.drawable.tab_settings_pressed);
                    if (mSettings == null) {
                        mSettings = new MainSettings();
                        transaction.add(R.id.id_content, mSettings);
                    } else {
                        transaction.show(mSettings);
                    }
                    break;
            }transaction.commit();
        }
        private void resetBtn()
        {
            ((ImageButton) mTabBtnWeChat.findViewById(R.id.imgWeChat))
                    .setImageResource(R.drawable.tab_weixin_normal);
            ((ImageButton) mTabBtnFriend.findViewById(R.id.imgFriend))
                    .setImageResource(R.drawable.tab_find_frd_normal);
            ((ImageButton) mTabBtnAddress.findViewById(R.id.imgAddress))
                    .setImageResource(R.drawable.tab_address_normal);
            ((ImageButton) mTabBtnSettings.findViewById(R.id.imgSettings))
                    .setImageResource(R.drawable.tab_settings_normal);
        }
        /**
         * 将所有的Fragment都置为隐藏状态。
         * 用于对Fragment执行操作的事务
         */
        private void hideFragments(FragmentTransaction transaction)
        {
            if (mWeChat != null)
            {
                transaction.hide(mWeChat);
            }
            if (mFriend != null)
            {
                transaction.hide(mFriend);
            }
            if (mAddress != null)
            {
                transaction.hide(mAddress);
            }
            if (mSettings != null)
            {
                transaction.hide(mSettings);
            }
        }
    }

    这部分其实没什么复杂的,就是初始化,添加界面,没有的创建,有的显示(或隐藏)就好了。
    MainWeChat.java

    package com.example.zhan.mfragment;
    
    import android.app.Fragment;
    import android.os.Bundle;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.Button;
    import android.widget.TextView;
    
    
    public class MainWeChat extends Fragment implements View.OnClickListener
    {
        int i = 0;
        View v;
        TextView tv ;
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
        {
            v = inflater.inflate(R.layout.wechat_view,container,false);
            Button btn = (Button)v.findViewById(R.id.fsbtn);
            tv = (TextView) v.findViewById(R.id.fstv);
            btn.setOnClickListener(this);
            return v;
        }
        @Override
        public void onClick(View v)
        {
            switch (v.getId()){
                case R.id.fsbtn:
                    if(i == 0){
                    tv.setText("Click");
                    i++;
                    }else if(i == 1){
                        tv.setText("WeChat");
                        i--;
                    }
            }
        }
    }

    这一部分主要是继承Fragment,然后把要添加的xml在onCreateView中返回就好了。
    到这里,回过头来看一下整个流程,其实就是在MainActivity关联的xml上的FrameLayout里添加一个xml,所以想要对wechat_view.xml中的控件操作,不是简简单单的findViewById就好了。所以需要

    View v = inflater.inflate(R.layout.wechat_view,container,false);

    将xml布局转换为view对象,再利用view对象,找到布局中的组件

    Button btn = (Button)v.findViewById(R.id.fsbtn);
    tv = (TextView) v.findViewById(R.id.fstv);

    到此,一个简单的Demo就介绍完了。很简单,Demo只要做好第一个Fragment,后面的copy、paste好了,具体的根据项目需求自己添加内容、控件、功能就行了。


    资源下载:http://download.csdn.net/detail/u012138272/9702272


    参考资料: Android项目Tab类型主界面大总结 Fragment+TabPageIndicator+ViewPager

    展开全文
  • 微信小程序布局

    2018-12-04 17:32:18
    微信小程序布局,以及后台联调,数据展示,页面跳转,图片上传,获取微信appid 等功能。
  • 拍照,浏览本地手机图片,仿qq和微信
  • Android 布局生成微信分享图片

    热门讨论 2018-01-13 16:32:53
    Android 布局生成微信分享图片,需要的小伙伴们可以下载看看!我们互相学习!!
  • 本文主要介绍的是,Anroid 分享本地带二维码的图片微信好友和朋友圈的功能代码,具有一定的参考价值,希望能帮助到有需要的朋友
  • Android 超高仿微信图片选择器 图片该这么加载

    万次阅读 多人点赞 2014-10-14 09:25:45
    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/39943731...有必要掌握图片的压缩,缓存等处理,以到达纵使你有万张照片,纵使你的像素再高,我们也能正确的显示所有的图片。当然了,单纯显示图片
    转载请标明出处:
    http://blog.csdn.net/lmj623565791/article/details/39943731,本文出自:
    【张鸿洋的博客】
    

    1、概述

    关于手机图片加载器,在当今像素随随便便破千万的时代,一张图片占据的内存都相当可观,作为高大尚程序猿的我们,有必要掌握图片的压缩,缓存等处理,以到达纵使你有万张照片,纵使你的像素再高,我们也能正确的显示所有的图片。当然了,单纯显示图片没撒意思,我们决定高仿一下微信的图片选择器,在此,感谢微信!本篇博客将基于以下两篇博客:

    Android 快速开发系列 打造万能的ListView GridView 适配器  将使用我们打造的CommonAdapter作为我们例子中GridView以及ListView的适配器

    Android Handler 异步消息处理机制的妙用 创建强大的图片加载类 将使用我们自己写的ImageLoader作为我们的图片加载的核心类

    如果你没看过也没关系,等看完本篇博客,可以结合以上两篇再进行充分理解一下。

    好了,首先贴一下效果图:




    动态图实在是录不出来,大家自己打开微信点击发表图片,或者聊天窗口发送图片,大致和微信的效果一样~

    简单描述一下:

    1、默认显示图片最多的文件夹图片,以及底部显示图片总数量;如上图1;

    2、点击底部,弹出popupWindow,popupWindow包含所有含有图片的文件夹,以及显示每个文件夹中图片数量;如上图2;注:此时Activity变暗

    3、选择任何文件夹,进入该文件夹图片显示,可以点击选择图片,当然了,点击已选择的图片则会取消选择;如上图3;注:选中图片变暗

    当然了,最重要的效果一定流畅,不能动不动OOM~~

    本人测试手机小米2s,图片6802张,未出现OOM异常,效果也是非常流畅,堪比图库~

    不过存在bug在所难免,大家可以留言说下自己发现的bug;文末会提供源码下载。

    好了,下面就可以代码的征程了~

    2、图片的列表页

    首先对手机中图片进行扫描,拿到图片数量最多的,直接显示在GridView上;并且扫描结束,得到一个所有包含图片的文件夹信息的List;

    对于文件夹信息,我们单独创建了一个Bean:

    package com.zhy.bean;
    
    public class ImageFloder
    {
    	/**
    	 * 图片的文件夹路径
    	 */
    	private String dir;
    
    	/**
    	 * 第一张图片的路径
    	 */
    	private String firstImagePath;
    
    	/**
    	 * 文件夹的名称
    	 */
    	private String name;
    
    	/**
    	 * 图片的数量
    	 */
    	private int count;
    
    	public String getDir()
    	{
    		return dir;
    	}
    
    	public void setDir(String dir)
    	{
    		this.dir = dir;
    		int lastIndexOf = this.dir.lastIndexOf("/");
    		this.name = this.dir.substring(lastIndexOf);
    	}
    
    	public String getFirstImagePath()
    	{
    		return firstImagePath;
    	}
    
    	public void setFirstImagePath(String firstImagePath)
    	{
    		this.firstImagePath = firstImagePath;
    	}
    
    	public String getName()
    	{
    		return name;
    	}
    	public int getCount()
    	{
    		return count;
    	}
    
    	public void setCount(int count)
    	{
    		this.count = count;
    	}
    
    	
    
    }
    

    用来存储当前文件夹的路径,当前文件夹包含多少张图片,以及第一张图片路径用于做文件夹的图标;注:文件夹的名称,我们在set文件夹的路径的时候,自动提取,仔细看下setDir这个方法。

    接下来就是扫描手机图片的代码了:

    @Override
    	protected void onCreate(Bundle savedInstanceState)
    	{
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_main);
    
    		DisplayMetrics outMetrics = new DisplayMetrics();
    		getWindowManager().getDefaultDisplay().getMetrics(outMetrics);
    		mScreenHeight = outMetrics.heightPixels;
    
    		initView();
    		getImages();
    		initEvent();
    
    	}
    
    	
    
    	/**
    	 * 利用ContentProvider扫描手机中的图片,此方法在运行在子线程中 完成图片的扫描,最终获得jpg最多的那个文件夹
    	 */
    	private void getImages()
    	{
    		if (!Environment.getExternalStorageState().equals(
    				Environment.MEDIA_MOUNTED))
    		{
    			Toast.makeText(this, "暂无外部存储", Toast.LENGTH_SHORT).show();
    			return;
    		}
    		// 显示进度条
    		mProgressDialog = ProgressDialog.show(this, null, "正在加载...");
    
    		new Thread(new Runnable()
    		{
    			@Override
    			public void run()
    			{
    
    				String firstImage = null;
    
    				Uri mImageUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
    				ContentResolver mContentResolver = MainActivity.this
    						.getContentResolver();
    
    				// 只查询jpeg和png的图片
    				Cursor mCursor = mContentResolver.query(mImageUri, null,
    						MediaStore.Images.Media.MIME_TYPE + "=? or "
    								+ MediaStore.Images.Media.MIME_TYPE + "=?",
    						new String[] { "image/jpeg", "image/png" },
    						MediaStore.Images.Media.DATE_MODIFIED);
    
    				Log.e("TAG", mCursor.getCount() + "");
    				while (mCursor.moveToNext())
    				{
    					// 获取图片的路径
    					String path = mCursor.getString(mCursor
    							.getColumnIndex(MediaStore.Images.Media.DATA));
    
    					Log.e("TAG", path);
    					// 拿到第一张图片的路径
    					if (firstImage == null)
    						firstImage = path;
    					// 获取该图片的父路径名
    					File parentFile = new File(path).getParentFile();
    					if (parentFile == null)
    						continue;
    					String dirPath = parentFile.getAbsolutePath();
    					ImageFloder imageFloder = null;
    					// 利用一个HashSet防止多次扫描同一个文件夹(不加这个判断,图片多起来还是相当恐怖的~~)
    					if (mDirPaths.contains(dirPath))
    					{
    						continue;
    					} else
    					{
    						mDirPaths.add(dirPath);
    						// 初始化imageFloder
    						imageFloder = new ImageFloder();
    						imageFloder.setDir(dirPath);
    						imageFloder.setFirstImagePath(path);
    					}
    
    					int picSize = parentFile.list(new FilenameFilter()
    					{
    						@Override
    						public boolean accept(File dir, String filename)
    						{
    							if (filename.endsWith(".jpg")
    									|| filename.endsWith(".png")
    									|| filename.endsWith(".jpeg"))
    								return true;
    							return false;
    						}
    					}).length;
    					totalCount += picSize;
    
    					imageFloder.setCount(picSize);
    					mImageFloders.add(imageFloder);
    
    					if (picSize > mPicsSize)
    					{
    						mPicsSize = picSize;
    						mImgDir = parentFile;
    					}
    				}
    				mCursor.close();
    
    				// 扫描完成,辅助的HashSet也就可以释放内存了
    				mDirPaths = null;
    
    				// 通知Handler扫描图片完成
    				mHandler.sendEmptyMessage(0x110);
    
    			}
    		}).start();
    
    	}

    ps:运行出现空指针的话,在81行的位置添加判断,if(parentFile.list()==null)continue , 切记~~~有些图片比较诡异~~; 

    initView就不看了,都是些findViewById;

    getImages主要就是扫描图片的代码,我们开启了一个Thread进行扫描,扫描完成以后,我们得到了图片最多文件夹路径(mImgDir),手机中图片数量(totalCount);以及所有包含图片文件夹信息(mImageFloders)

    然后我们通过handler发送消息,在handleMessage里面:

    1、创建GridView的适配器,为我们的GridView设置适配器,显示图片;

    2、有了mImageFloders,就可以创建我们的popupWindow了

    看一眼我们的Handler

    private Handler mHandler = new Handler()
    	{
    		public void handleMessage(android.os.Message msg)
    		{
    			mProgressDialog.dismiss();
    			//为View绑定数据
    			data2View();
    			//初始化展示文件夹的popupWindw
    			initListDirPopupWindw();
    		}
    	};

    可以看到分别干了上述的两件事:

    /**
    	 * 为View绑定数据
    	 */
    	private void data2View()
    	{
    		if (mImgDir == null)
    		{
    			Toast.makeText(getApplicationContext(), "擦,一张图片没扫描到",
    					Toast.LENGTH_SHORT).show();
    			return;
    		}
    
    		mImgs = Arrays.asList(mImgDir.list());
    		/**
    		 * 可以看到文件夹的路径和图片的路径分开保存,极大的减少了内存的消耗;
    		 */
    		mAdapter = new MyAdapter(getApplicationContext(), mImgs,
    				R.layout.grid_item, mImgDir.getAbsolutePath());
    		mGirdView.setAdapter(mAdapter);
    		mImageCount.setText(totalCount + "张");
    	};

    data2View就是我们当前Activity上所有的View设置数据了。

    看到这里还用到了一个Adapter,我们GridView的:

    package com.zhy.imageloader;
    
    import java.util.LinkedList;
    import java.util.List;
    
    import android.content.Context;
    import android.graphics.Color;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.ImageView;
    
    import com.zhy.utils.CommonAdapter;
    
    public class MyAdapter extends CommonAdapter<String>
    {
    
    	/**
    	 * 用户选择的图片,存储为图片的完整路径
    	 */
    	public static List<String> mSelectedImage = new LinkedList<String>();
    
    	/**
    	 * 文件夹路径
    	 */
    	private String mDirPath;
    
    	public MyAdapter(Context context, List<String> mDatas, int itemLayoutId,
    			String dirPath)
    	{
    		super(context, mDatas, itemLayoutId);
    		this.mDirPath = dirPath;
    	}
    
    	@Override
    	public void convert(final com.zhy.utils.ViewHolder helper, final String item)
    	{
    		// 设置no_pic
    		helper.setImageResource(R.id.id_item_image, R.drawable.pictures_no);
    		// 设置no_selected
    		helper.setImageResource(R.id.id_item_select,
    				R.drawable.picture_unselected);
    		// 设置图片
    		helper.setImageByUrl(R.id.id_item_image, mDirPath + "/" + item);
    
    		final ImageView mImageView = helper.getView(R.id.id_item_image);
    		final ImageView mSelect = helper.getView(R.id.id_item_select);
    
    		mImageView.setColorFilter(null);
    		// 设置ImageView的点击事件
    		mImageView.setOnClickListener(new OnClickListener()
    		{
    			// 选择,则将图片变暗,反之则反之
    			@Override
    			public void onClick(View v)
    			{
    
    				// 已经选择过该图片
    				if (mSelectedImage.contains(mDirPath + "/" + item))
    				{
    					mSelectedImage.remove(mDirPath + "/" + item);
    					mSelect.setImageResource(R.drawable.picture_unselected);
    					mImageView.setColorFilter(null);
    				} else
    				// 未选择该图片
    				{
    					mSelectedImage.add(mDirPath + "/" + item);
    					mSelect.setImageResource(R.drawable.pictures_selected);
    					mImageView.setColorFilter(Color.parseColor("#77000000"));
    				}
    
    			}
    		});
    
    		/**
    		 * 已经选择过的图片,显示出选择过的效果
    		 */
    		if (mSelectedImage.contains(mDirPath + "/" + item))
    		{
    			mSelect.setImageResource(R.drawable.pictures_selected);
    			mImageView.setColorFilter(Color.parseColor("#77000000"));
    		}
    
    	}
    }
    

    可以看到我们GridView的Adapter继承了我们的CommonAdapter,如果不知道CommonAdapter为何物,可以去看看万能适配器那篇博文;

    我们现在只需要实现convert方法:

    在convert中,我们设置图片,设置事件等,对于图片的变暗,我们使用的是ImageView的setColorFilter ;根据Url加载图片的操作封装在helper.setImageByUrl(view,url)中,内部使用的是我们自己定义的ImageLoader,包括错乱处理都已经封装了,图片策略我们使用的是LIFO后进先出;不清楚的可以看文章一开始说明的那两篇博文,对于CommonAdapter以及ImageLoader都有从无到有的详细打造过程;

    到此我们的第一个Activity的所有的任务就完成了~~~


    3、展现文件夹的PopupWindow

    现在我们要实现,点击底部的布局弹出我们的文件夹选择框,并且我们弹出框后面的Activity要变暗;

    不急着贴代码,我们先考虑下PopupWindow怎么用最好,我们的PopupWindow需要设置布局文件,需要初始化View,需要初始化事件,还需要和Activity交互~~

    那么肯定的,我们使用独立的类,这个类和Activity很相似,在里面initView(),initEvent()之类的。

    我们创建了一个popupWindow使用的超类:

    package com.zhy.utils;
    
    import java.util.List;
    
    import android.content.Context;
    import android.graphics.drawable.BitmapDrawable;
    import android.view.MotionEvent;
    import android.view.View;
    import android.view.View.OnTouchListener;
    import android.widget.PopupWindow;
    
    public abstract class BasePopupWindowForListView<T> extends PopupWindow
    {
    	/**
    	 * 布局文件的最外层View
    	 */
    	protected View mContentView;
    	protected Context context;
    	/**
    	 * ListView的数据集
    	 */
    	protected List<T> mDatas;
    
    	public BasePopupWindowForListView(View contentView, int width, int height,
    			boolean focusable)
    	{
    		this(contentView, width, height, focusable, null);
    	}
    
    	public BasePopupWindowForListView(View contentView, int width, int height,
    			boolean focusable, List<T> mDatas)
    	{
    		this(contentView, width, height, focusable, mDatas, new Object[0]);
    
    	}
    
    	public BasePopupWindowForListView(View contentView, int width, int height,
    			boolean focusable, List<T> mDatas, Object... params)
    	{
    		super(contentView, width, height, focusable);
    		this.mContentView = contentView;
    		context = contentView.getContext();
    		if (mDatas != null)
    			this.mDatas = mDatas;
    
    		if (params != null && params.length > 0)
    		{
    			beforeInitWeNeedSomeParams(params);
    		}
    
    		setBackgroundDrawable(new BitmapDrawable());
    		setTouchable(true);
    		setOutsideTouchable(true);
    		setTouchInterceptor(new OnTouchListener()
    		{
    			@Override
    			public boolean onTouch(View v, MotionEvent event)
    			{
    				if (event.getAction() == MotionEvent.ACTION_OUTSIDE)
    				{
    					dismiss();
    					return true;
    				}
    				return false;
    			}
    		});
    		initViews();
    		initEvents();
    		init();
    	}
    
    	protected abstract void beforeInitWeNeedSomeParams(Object... params);
    
    	public abstract void initViews();
    
    	public abstract void initEvents();
    
    	public abstract void init();
    
    	public View findViewById(int id)
    	{
    		return mContentView.findViewById(id);
    	}
    
    	protected static int dpToPx(Context context, int dp)
    	{
    		return (int) (context.getResources().getDisplayMetrics().density * dp + 0.5f);
    	}
    
    }
    

    也就是封装了一下popupWindow常用的一些设置,然后使用了类似模版方法模式,约束子类,必须实现initView,initEvent,init等方法

    package com.zhy.imageloader;
    
    import java.util.List;
    
    import android.view.View;
    import android.widget.AdapterView;
    import android.widget.AdapterView.OnItemClickListener;
    import android.widget.ListView;
    
    import com.zhy.bean.ImageFloder;
    import com.zhy.utils.BasePopupWindowForListView;
    import com.zhy.utils.CommonAdapter;
    import com.zhy.utils.ViewHolder;
    
    public class ListImageDirPopupWindow extends BasePopupWindowForListView<ImageFloder>
    {
    	private ListView mListDir;
    
    	public ListImageDirPopupWindow(int width, int height,
    			List<ImageFloder> datas, View convertView)
    	{
    		super(convertView, width, height, true, datas);
    	}
    
    	@Override
    	public void initViews()
    	{
    		mListDir = (ListView) findViewById(R.id.id_list_dir);
    		mListDir.setAdapter(new CommonAdapter<ImageFloder>(context, mDatas,
    				R.layout.list_dir_item)
    		{
    			@Override
    			public void convert(ViewHolder helper, ImageFloder item)
    			{
    				helper.setText(R.id.id_dir_item_name, item.getName());
    				helper.setImageByUrl(R.id.id_dir_item_image,
    						item.getFirstImagePath());
    				helper.setText(R.id.id_dir_item_count, item.getCount() + "张");
    			}
    		});
    	}
    
    	public interface OnImageDirSelected
    	{
    		void selected(ImageFloder floder);
    	}
    
    	private OnImageDirSelected mImageDirSelected;
    
    	public void setOnImageDirSelected(OnImageDirSelected mImageDirSelected)
    	{
    		this.mImageDirSelected = mImageDirSelected;
    	}
    
    	@Override
    	public void initEvents()
    	{
    		mListDir.setOnItemClickListener(new OnItemClickListener()
    		{
    			@Override
    			public void onItemClick(AdapterView<?> parent, View view,
    					int position, long id)
    			{
    
    				if (mImageDirSelected != null)
    				{
    					mImageDirSelected.selected(mDatas.get(position));
    				}
    			}
    		});
    	}
    
    	@Override
    	public void init()
    	{
    		// TODO Auto-generated method stub
    
    	}
    
    	@Override
    	protected void beforeInitWeNeedSomeParams(Object... params)
    	{
    		// TODO Auto-generated method stub
    	}
    
    }
    
    好了,现在就是我们正在的popupWindow咯,布局文件夹主要是个ListView,所以在initView里面,我们得设置它的适配器;当然了,这里的适配器依然用我们的CommonAdapter,几行代码搞定~~

    然后我们需要和Activity交互,当我们点击某个文件夹的时候,外层的Activity需要改变它GridView的数据源,展示我们点击文件夹的图片;

    关于交互,我们从Activity的角度去看弹出框,Activity想知道什么,只想知道选择了别的文件夹来告诉我,所以我们创建一个接口OnImageDirSelected,对Activity设置回调;

    这里还可以这么写:就是把popupWindow的ListView公布出去,然后在Activity里面使用popupWindow.getListView(),setOnItemClickListener,这么做,个人觉得不好,耦合度太高,客户简单改下需求“这个文件夹展示,给我们换了,换成GridView”,呵呵,此时,你需要到处去修改Activity里面的代码,因为你Activity里面竟然还有个popupWindow.getListView。

    好了,扯多了,初始化事件的代码:

    @Override
    	public void initEvents()
    	{
    		mListDir.setOnItemClickListener(new OnItemClickListener()
    		{
    			@Override
    			public void onItemClick(AdapterView<?> parent, View view,
    					int position, long id)
    			{
    
    				if (mImageDirSelected != null)
    				{
    					mImageDirSelected.selected(mDatas.get(position));
    				}
    			}
    		});
    	}

    如果有人设置了回调,我们就调用;

    到此,整个popupWindow就出炉了,接下来就看啥时候让它展示了;

    4、选择不同的文件夹

    上面说道,当扫描图片完成,拿到包含图片的文件夹信息列表;这个列表就是我们popupWindow所需的数据,所以我们的popupWindow的初始化在handleMessage(上面贴了handler的代码)里面:

    在handleMessage里面调用initListDirPopupWindw

    /**
    	 * 初始化展示文件夹的popupWindw
    	 */
    	private void initListDirPopupWindw()
    	{
    		mListImageDirPopupWindow = new ListImageDirPopupWindow(
    				LayoutParams.MATCH_PARENT, (int) (mScreenHeight * 0.7),
    				mImageFloders, LayoutInflater.from(getApplicationContext())
    						.inflate(R.layout.list_dir, null));
    
    		mListImageDirPopupWindow.setOnDismissListener(new OnDismissListener()
    		{
    
    			@Override
    			public void onDismiss()
    			{
    				// 设置背景颜色变暗
    				WindowManager.LayoutParams lp = getWindow().getAttributes();
    				lp.alpha = 1.0f;
    				getWindow().setAttributes(lp);
    			}
    		});
    		// 设置选择文件夹的回调
    		mListImageDirPopupWindow.setOnImageDirSelected(this);
    	}
    我们初始化我们的popupWindow,设置了关闭对话框的回调,已经设置了选择不同文件夹的回调;
    这里仅仅是初始化,下面看我们合适将其弹出的,其实整个Activity也就一个事件,点击弹出该对话框,所以看Activity的initEvents方法:

    private void initEvent()
    	{
    		/**
    		 * 为底部的布局设置点击事件,弹出popupWindow
    		 */
    		mBottomLy.setOnClickListener(new OnClickListener()
    		{
    			@Override
    			public void onClick(View v)
    			{
    				mListImageDirPopupWindow
    						.setAnimationStyle(R.style.anim_popup_dir);
    				mListImageDirPopupWindow.showAsDropDown(mBottomLy, 0, 0);
    
    				// 设置背景颜色变暗
    				WindowManager.LayoutParams lp = getWindow().getAttributes();
    				lp.alpha = .3f;
    				getWindow().setAttributes(lp);
    			}
    		});
    	}

    可以看到,我们为底部布局设置点击事件;设置popupWindow的弹出与消失的动画;已经让Activity背景变暗变亮,通过改变Window alpha实现的。变亮在弹出框消息的监听里面~~

    动画的文件就不贴了,大家自己看源码;

    popupWindow弹出了,用户此时可以选择不同的文件夹,那么现在该看选择后的回调的代码了:

    我们的Activity实现了该接口,直接看实现的方法:

    	@Override
    	public void selected(ImageFloder floder)
    	{
    
    		mImgDir = new File(floder.getDir());
    		mImgs = Arrays.asList(mImgDir.list(new FilenameFilter()
    		{
    			@Override
    			public boolean accept(File dir, String filename)
    			{
    				if (filename.endsWith(".jpg") || filename.endsWith(".png")
    						|| filename.endsWith(".jpeg"))
    					return true;
    				return false;
    			}
    		}));
    		/**
    		 * 可以看到文件夹的路径和图片的路径分开保存,极大的减少了内存的消耗;
    		 */
    		mAdapter = new MyAdapter(getApplicationContext(), mImgs,
    				R.layout.grid_item, mImgDir.getAbsolutePath());
    		mGirdView.setAdapter(mAdapter);
    		// mAdapter.notifyDataSetChanged();
    		mImageCount.setText(floder.getCount() + "张");
    		mChooseDir.setText(floder.getName());
    		mListImageDirPopupWindow.dismiss();
    
    	}

    我们改变了GridView的适配器,以及底部的控件上的文件夹名称,文件数量等等;

    好了,到此结束;整篇由于篇幅原因没有贴任何布局文件,大家自己通过源码查看;

    在此希望大家可以通过该案例,能够去其糟粕,取其精华,学习其中值得借鉴的代码风格,不要真的当作一个例子去学习~~



    源码点击下载  

    ps:请真机测试,反正我的模拟器扫描不到图片~

    ps:运行出现空指针的话,在getImages中添加判断,if(parentFile.list()==null)continue , 切记~~~具体位置,上面有说; 





    ---------------------------------------------------------------------------------------------------------

    建了一个QQ群,方便大家交流。群号:55032675



    ----------------------------------------------------------------------------------------------------------

    博主部分视频已经上线,如果你不喜欢枯燥的文本,请猛戳(初录,期待您的支持):

    1、高仿微信5.2.1主界面及消息提醒

    2、高仿QQ5.0侧滑


    展开全文
  • 仿微信图片选择器,实现多张图片上传
  • 微信小程序图片瀑布流布局demo
  • Android 多张图片展示,仿微信图片上传,可以选择多张图片
  • 微信美女图片管理:基于node布局,像电脑上的图片管理程序那样,可对图片进行分类管理,可设置程序更方便使用,在微信小程序环境下运行后,主要是读取相册图库或自定义图库的图片,小程序运行效果请参见截图所示。
  • 微信小程序布局-图片+文字

    千次阅读 2019-12-26 09:59:40
    文字放置在图片的水平和垂直居中的位置上 效果图片 wxml代码如下 <view class="image-parent"> <image class='image' mode='widthFix' src='../../images/answer-ad.png'></image> <...
  • 三种Feed流中的图片布局:宫格式布局、拼图式布局、瀑布流式布局。 一、宫格式布局 宫格式布局也就是九宫格布局,多用在社交类的APP中,九宫格图片不仅能放进去很多内容,同时也能很好地引起网友的关注。   从...
  • 仿微信朋友圈图片九宫格布局
  • 这里就不贴效果图片了 很简单就是两个图片 显示的内容不同罢了 send_item_final.xml send_item.xml: 适配器代码 public class SendBlogAdapter extends RecyclerView.Adapter{ private Context context; ...
  • 微信小程序布局技巧(三)

    千次阅读 2019-05-08 16:59:48
    微信小程序布局技巧(三)前言小程序适配物理像素小程序中的pxpx和rpx转换应用尾巴 前言 本文是微信小程序(本文后面统称小程序)布局技巧系列最后一篇文章,主要说明小程序的屏幕适配问题。本文和系列文章前两篇...
  • 微信小程序布局及嵌套地图

    千次阅读 2019-01-14 16:04:07
    这篇博客主要讲微信小程序的布局的基础知识。以及微信小程序加入地图之后会出现的一些问题(坑)。 微信小程序布局之---Flex布局 1.想要使用flex布局的第一步: display:block块内容 使用新行开始显示。 ...
  • 常见应用场景如微信朋友圈照片九宫格和微信聊天图片预览,某些手机系统相册等viewpager图片查看 缩放 拖拽下拉缩小退出(效果同微信图片浏览)特点1.支持自定义图片加载框架。2.支持重写activity,完成切换切换效果...
  • 微信小程序布局技巧(二)

    千次阅读 多人点赞 2019-04-28 16:14:54
    微信小程序布局技巧(二)前言POSITION(定位)常用的定位属性值staticrelativeabsolutefixed定位元素元素层级应用尾巴 前言 在上一篇文章中:微信小程序布局技巧(一),我给大家介绍了微信小程序(后面统称小程序...
  • 最近做开发需要解决一个模仿微信朋友圈附加图片的功能,具体要求如下: (1)从手机中最多选择3张图片,可拍照上传; (2)选择的图片可以点击移除然后再添加新图片; (3)可以在手机包含图片的各个文件夹中随意...
  • 破解微信图片防盗链

    2016-10-21 17:02:00
    今天一哥们在博客中留言问到了怎样解决微信图片防盗链的问题。 之前在项目中,我也遇到了防盗链的问题。 在这里分享一下本人对微信图片防盗的简单解决思路。 第一种解决的思路,是非常简单的。 借助跳板,...
  • 效果类似微信朋友圈的图片排版,效果略有不同。 - 正方形的图片控件,高度会随着宽度一起变化。实现这样的布局有很多种思路,只是什么样的方式更优雅。本文提供一种相对优雅的方式供大家参考。思路 首先,优雅的...
  • 12月4日,小程序数据统计平台阿拉丁发布微信小程序11月榜单,本月Top...尽管目前附近的小程序功能还很简单,但点击进入已经包含文字、图片、视频等展示形式,微信在为进一步圈定线下流量打基础。 微信上线支付分,这是
  • 方便简易,一键集成,几句代码就可以添加类似微信图片选择控件了。 下面介绍一下该控件有些什么特点以及怎么使用。先看图: 效果如上图,点击加号弹出选择框,目前提供了两种形式,一个如图所见的PopupWindow,...
  • 使用技术主要是flex布局,绝对定位布局,小程序前端页面开发,以及一些样式! 直接贴代码,都有详细注释,熟悉一下,方便以后小程序开发! wxml: <image class=taobao-list-photo src={{item.imageUrl}}/>
  • 实现微信布局的四种方式(二)

    千次阅读 2016-04-23 14:11:52
    第二种实现微信布局的方式: 通过Fragment实现,不通过ViewPager,由于其布局文件的top.xml、bottom.xml、四个tab.xml均相同,其具体情况可以翻看本人上次写的博客《实现微信布局的四种方式(一)》。微信布局四种...
  • css3伪类匹配列表数目实现微信群多用户头像布局的技巧。不同用户头像数量不同的布局效果代码。

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 34,828
精华内容 13,931
关键字:

微信图片布局