当前位置:  编程技术>移动开发
本页文章导读:
    ▪为何是这样        为什么是这样 没有友情链接这个是什么情况呢 ......
    ▪ SeekBar 式样设置        SeekBar 样式设置   UI参考               <SeekBar android:id="@+id/seekbar" android:layout_width="fill_parent" android:layout_height="wrap_content" android:progressDrawable="@layout/seekba.........
    ▪ 运用 TabActivity 实现滑动翻页(带动画)和标签置底与定制效果       使用 TabActivity 实现滑动翻页(带动画)和标签置底与定制效果     花了一天功夫,把 TabActivity 捣鼓出了个样子,差不多和自己所想的一致了,下图为滑动效果(带动画)。     其实做完.........

[1]为何是这样
    来源: 互联网  发布时间: 2014-02-18
为什么是这样
没有友情链接
这个是什么情况呢

    
[2] SeekBar 式样设置
    来源: 互联网  发布时间: 2014-02-18
SeekBar 样式设置



  UI参考

 

 

 

 

 

 

 



 
 

 

 <SeekBar
        android:id="@+id/seekbar"
        
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:progressDrawable="@layout/seekbar_style"
        android:thumb="@layout/thumb" />

 

 

方式一:通过背景图片设置实现

seekbar_style.xml

 

<?xml version="1.0" encoding="UTF-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <!-- 背景项 -->
    <item android:id="@android:id/background">
        <!-- 背景图 :这里使用9文件,因此这么配置,
        如果使用的是普通图片可直接使用<drawable />标签,或者使用<shape />标签,自定义图形 -->
        <nine-patch android:src="/blog_article/@drawable/skin_bg/index.html" />
    </item>
    <!-- 进度图 -->
    <item android:id="@android:id/progress">
     <clip >
            <nine-patch android:src="/blog_article/@drawable/skin_bg2/index.html" />
     </clip>
     </item>
</layer-list>

 

thumb.xml

<?xml version="1.0" encoding="UTF-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- seekbar的滑块样式 -->
    <!-- 按下状态 -->
    <item android:drawable="@drawable/menu_bg" android:state_pressed="true"/>
    <!-- 普通无焦点状态 -->
    <item android:drawable="@drawable/menu_bg" android:state_focused="false" android:state_pressed="false"/>

</selector>

 

 

 

方式二:通过<shape  />标签为SeekBar设置背景和进度的xml配置文件

seekbar_style.xml

 

<?xml version="1.0" encoding="utf-8"?>   
<!-- ChenJianLi Code: View: Seekbar    
        滑动时的背景效果 -->   
  
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">   
  <!--  背景  -->   
    <item android:id="@android:id/background">   
        <shape>   
            <corners android:radius="5dip" />   
            <gradient   
                    android:startColor="#ffffffff"  
                    android:centerColor="#fffffff0"  
                    android:centerY="0.75"  
                    android:endColor="#fffffafa"  
                    android:angle="270"  
            />   
        </shape>   
    </item>   
    <!--  第二进度条  -->   
    <item android:id="@android:id/secondaryProgress">   
        <clip>   
            <shape>   
                <corners android:radius="5dip" />   
                <gradient   
                        android:startColor="#8000cdcd"  
                        android:centerColor="#8000bfff"  
                        android:centerY="0.75"  
                        android:endColor="#a000b2ee"  
                        android:angle="270"  
                />   
            </shape>   
        </clip>   
    </item>   
    <!--  第一进度条  -->   
    <item android:id="@android:id/progress">   
        <clip>   
            <shape>   
                <corners android:radius="5dip" />   
                <gradient   
                        android:startColor="#ff00ffff"  
                        android:centerColor="#ff00ced1"  
                        android:centerY="0.75"  
                        android:endColor="#ff00f5ff"  
                        android:angle="270"  
                />   
            </shape>   
        </clip>   
    </item>   

 方式三:

<?xml version="1.0" encoding="UTF-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >

    <!-- 使用<drawable />标签设置背景图片 -->
    <!-- 背景项 -->

    <item
        android:id="@android:id/background"
        android:drawable="@drawable/timeline1"></item>
    <!-- 进度图 -->

    <item
        android:id="@android:id/progress"
        android:drawable="@drawable/timeline2"></item>

</layer-list>

 


    
[3] 运用 TabActivity 实现滑动翻页(带动画)和标签置底与定制效果
    来源: 互联网  发布时间: 2014-02-18
使用 TabActivity 实现滑动翻页(带动画)和标签置底与定制效果

    花了一天功夫,把 TabActivity 捣鼓出了个样子,差不多和自己所想的一致了,下图为滑动效果(带动画)。

    其实做完后,才发现,TabActivity 并不难用,只需要你自己去扩展一些他的方法,就可以达到你自己想到效果。

    不多说了,把实现动画的部分贴出现,其他的自己看源码吧。

 

@Override
public void setCurrentTab(int index) {
  int mCurrentTabID = getCurrentTab();
  if (null != getCurrentView()) {
   // 第一次设置 Tab 时,该值为 null。
   if (isOpenAnimation) {
    if (mCurrentTabID == (mTabCount - 1) && index == 0) {
     getCurrentView().startAnimation(slideLeftOut);
    } else if (mCurrentTabID == 0 && index == (mTabCount - 1)) {
     getCurrentView().startAnimation(slideRightOut);
    } else if (index > mCurrentTabID) {
     getCurrentView().startAnimation(slideLeftOut);
    } else if (index < mCurrentTabID) {
     getCurrentView().startAnimation(slideRightOut);
    }
   }
  }
  super.setCurrentTab(index);
  if (isOpenAnimation) {
   if (mCurrentTabID == (mTabCount - 1) && index == 0) {
    getCurrentView().startAnimation(slideLeftIn);
   } else if (mCurrentTabID == 0 && index == (mTabCount - 1)) {
    getCurrentView().startAnimation(slideRightIn);
   } else if (index > mCurrentTabID) {
    getCurrentView().startAnimation(slideLeftIn);
   } else if (index < mCurrentTabID) {
    getCurrentView().startAnimation(slideRightIn);
   }
  }
}


    不过是继承了 TabHost 组件类,并扩展了其 setCurrentTab(int index) 方法,不过有一个 Bug 没有解决,便当连续快速的滑动屏幕时,当 TabHost 加载的 view 或 activity 背景图为透明效果时,会出现重影现象。
    希望有高价解决。
    关于标签置底,其实可以查看 XML 文件得到答案,使用 TabActivity 时,其布局文件的顶级视图必须为 TabHost 控件,通过看 TabHost 的源码,可以看到,它其实就是一个 FrameLayout,包含了两个控件:FrameLayout mTabContent(展示我们加载的 View 或 Activity)  和 TabWidget mTabWidget(展示 Tab 的标签,其实就是一个 LinearLayout),默认布局都是采用系统的,所以我们可以在自己的 XML 文件中,将这两个的顺序更换一下,就可以了,同样的,既然我们可以得到 TabWidget,那么就可以对其进行布局设计,制定效果也就可以实现了。

       现在想来,QQ、UC这些漂亮的按钮滑动方式,会不会也是这样实现的呢,研究中…………

 

1 楼 小卡卡西 2012-08-16  
   谢谢分享,下载下来看看

    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3