- 浏览: 5825410 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (890)
- WindowsPhone (0)
- android (88)
- android快速迭代 (17)
- android基础 (34)
- android进阶 (172)
- android高级 (0)
- android拾遗 (85)
- android动画&效果 (68)
- Material Design (13)
- LUA (5)
- j2me (32)
- jQuery (39)
- spring (26)
- hibernate (20)
- struts (26)
- tomcat (9)
- javascript+css+html (62)
- jsp+servlet+javabean (14)
- java (37)
- velocity+FCKeditor (13)
- linux+批处理 (9)
- mysql (19)
- MyEclipse (9)
- ajax (7)
- wap (8)
- j2ee+apache (24)
- 其他 (13)
- phonegap (35)
最新评论
-
Memories_NC:
本地lua脚本终于执行成功了,虽然不是通过redis
java中调用lua脚本语言1 -
ZHOU452840622:
大神://处理返回的接收状态 这个好像没有监听到 遇 ...
android 发送短信的两种方式 -
PXY:
拦截部分地址,怎么写的for(int i=0;i<lis ...
判断是否登录的拦截器SessionFilter -
maotou1988:
Android控件之带清空按钮(功能)的AutoComplet ...
自定义AutoCompleteTextView -
yangmaolinpl:
希望有表例子更好。。。,不过也看明白了。
浅谈onInterceptTouchEvent、onTouchEvent与onTouch
Android系统的进度条控件默认的设计的不是很周全,比如没有包含文字的显示,那么如何在Android进度条控件上显示文字呢? 来自Google内部的代码来了解下,主要使用的addView这样的方法通过覆盖一层Chronometer秒表控件来实现,整个代码如下
public class TextProgressBar extends RelativeLayout implements OnChronometerTickListener { public static final String TAG = "TextProgressBar"; static final int CHRONOMETER_ID = android.R.id.text1; static final int PROGRESSBAR_ID = android.R.id.progress; Chronometer mChronometer = null; ProgressBar mProgressBar = null; long mDurationBase = -1; int mDuration = -1; boolean mChronometerFollow = false; int mChronometerGravity = Gravity.NO_GRAVITY; public TextProgressBar(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } public TextProgressBar(Context context, AttributeSet attrs) { super(context, attrs); } public TextProgressBar(Context context) { super(context); } //Android开发网提示关键部分在这里 @Override public void addView(View child, int index, ViewGroup.LayoutParams params) { super.addView(child, index, params); int childId = child.getId(); if (childId == CHRONOMETER_ID && child instanceof Chronometer) { mChronometer = (Chronometer) child; mChronometer.setOnChronometerTickListener(this); // Check if Chronometer should move with with ProgressBar mChronometerFollow = (params.width == ViewGroup.LayoutParams.WRAP_CONTENT); mChronometerGravity = (mChronometer.getGravity() & Gravity.HORIZONTAL_GRAVITY_MASK); } else if (childId == PROGRESSBAR_ID && child instanceof ProgressBar) { mProgressBar = (ProgressBar) child; } } @android.view.RemotableViewMethod public void setDurationBase(long durationBase) { mDurationBase = durationBase; if (mProgressBar == null || mChronometer == null) { throw new RuntimeException("Expecting child ProgressBar with id " + "'android.R.id.progress' and Chronometer id 'android.R.id.text1'"); } // Update the ProgressBar maximum relative to Chronometer base mDuration = (int) (durationBase - mChronometer.getBase()); if (mDuration <= 0) { mDuration = 1; } mProgressBar.setMax(mDuration); } public void onChronometerTick(Chronometer chronometer) { if (mProgressBar == null) { throw new RuntimeException( "Expecting child ProgressBar with id 'android.R.id.progress'"); } // Stop Chronometer if we're past duration long now = SystemClock.elapsedRealtime(); if (now >= mDurationBase) { mChronometer.stop(); } int remaining = (int) (mDurationBase - now); mProgressBar.setProgress(mDuration - remaining); if (mChronometerFollow) { RelativeLayout.LayoutParams params; params = (RelativeLayout.LayoutParams) mProgressBar.getLayoutParams(); int contentWidth = mProgressBar.getWidth() - (params.leftMargin + params.rightMargin); int leadingEdge = ((contentWidth * mProgressBar.getProgress()) / mProgressBar.getMax()) + params.leftMargin; int adjustLeft = 0; int textWidth = mChronometer.getWidth(); if (mChronometerGravity == Gravity.RIGHT) { adjustLeft = -textWidth; } else if (mChronometerGravity == Gravity.CENTER_HORIZONTAL) { adjustLeft = -(textWidth / 2); } leadingEdge += adjustLeft; int rightLimit = contentWidth - params.rightMargin - textWidth; if (leadingEdge < params.leftMargin) { leadingEdge = params.leftMargin; } else if (leadingEdge > rightLimit) { leadingEdge = rightLimit; } params = (RelativeLayout.LayoutParams) mChronometer.getLayoutParams(); params.leftMargin = leadingEdge; mChronometer.requestLayout(); } } }
发表评论
-
http://www.android-studio.org/
2018-08-06 09:25 0http://www.android-studio.org/ ... -
SlidingDrawer源码
2012-03-14 10:13 3809我把SlidingDrawer源码提了出来,希望对1.5的朋友 ... -
简单拖动效果(带Cache,需要完善)
2011-10-13 15:10 4231如何去实现一个具有幻象的拖拽效果? 所谓”幻象“就是当你按下去 ... -
Android Activity中启动另一应用程序的方法,无需得到类名
2011-08-02 14:46 17268在网上搜索了一会相关的实现代码,发现所有的文章都说是需要包名和 ... -
java-universal-tween-engine,一个动画系统库
2011-06-29 09:21 6745http://code.google.com/p/java-u ... -
网上发现的一个android UI包
2011-05-24 12:21 4117里面有些UI和效果 -
android中使用代码启动其他程序
2011-04-29 23:15 5304你要訪問其他的程序,那麼這個程序要先裝載到模擬器或真機上面,因 ... -
listView背景问题以及限制editText字数以及如果想通知别人已经不能在写
2011-04-29 22:44 32111.在listView设置好背景之后 你如果点击空白出 你会发 ... -
Android键盘和触摸事件处理
2011-04-29 22:32 7006activity和VIEW都能接收触摸和按键,如果响应事件只需 ... -
Android的绘制文本对象FontMetrics的介绍及绘制文本
2011-04-29 22:29 11494一。Android绘制文本对象FontMetrics介绍 ... -
Android View 拖动&插入
2011-04-29 22:20 3550View 拖动&插入 即: 支持 拖动图标 然后 ... -
使TextView文本可以水平和垂直滚动
2011-04-29 21:59 14432在做一个小的电子书程序,要求电子书具有放大缩小的功能,所以肯定 ... -
ArrayAdapter源码
2011-04-29 12:29 6304看看人家怎么写的。 /* * Copyright (C ... -
Android下获取开机时间
2011-04-02 21:51 6232找了一圈没发现能得到开机启动时间资料,于是乎突发奇想,得到了解 ... -
AutoCompleteTextView连接到数据库
2011-03-30 20:49 4732AutoCompleteTextView可以根据输入 ... -
改变屏幕Brightness(亮度)
2011-03-30 12:48 4606http://www.eoeandroid.com/forum ... -
android 拖拽图片&拖动浮动按钮到处跑
2011-02-24 20:55 31776来自老外: import android.app.Acti ... -
拖动一个控件在另一个控件(layout)上,并固定位置在几个位置显示
2011-02-24 20:51 5896实现效果: 鼠标拖动btn SSS,SSS在水平的layo ... -
Handler与Message类,实现n秒后无操作自动消失功能
2011-02-24 20:45 4644实现功能:某控件不操作10秒后,自动消失。如照相机变焦条出现后 ... -
带删除按钮的ListView
2011-02-24 10:33 6151不用说了,上图先: import java.util.A ...
相关推荐
总的来说,实现一个竖直自定义进度条并带文字显示的过程涉及到了Android的自定义View、样式配置、XML drawable以及布局管理等多个方面。理解这些知识点可以帮助开发者更自由地设计和定制Android应用的界面,提供更...
在Android开发中,自定义控件是提升应用用户体验和视觉效果的重要手段。在这个特定的案例中,我们关注的是一个带有文字的进度条,其文字颜色会随着进度条的增长而渐变。这种效果可以为用户提供更直观、动态的反馈,...
在C#编程中,`progressBar`控件是Windows Forms应用程序中常见的元素,用于向...以上就是关于“C# progressBar进度条绘制文字显示百分比”的详细解释,通过这些步骤,你可以创建一个更直观、用户体验更好的进度条控件。
android自定义半圆进度条,可以自己根据里面备注的参数,调整半圆的长度。这里是使用说明:http://blog.csdn.net/beibaokongming/article/details/79002646
在Android开发中,自定义控件是提升应用独特性和用户体验的重要手段。本篇文章将深入探讨如何创建一个圆形进度条,即`CircleProgressView`。这个控件能够以圆形的形式展示进度,常见于加载动画或者显示数据百分比的...
在AndBase框架中,这个环形进度条控件可能还包括了更多高级功能和定制选项,如渐变颜色、内圆环、文字显示等。通过对源码的详细阅读和理解,开发者可以根据项目需求进行适当的扩展和优化。 总的来说,这个环形...
在Android开发中,自定义视图是提升用户体验和界面独特性的重要手段。本文将深入探讨如何创建一个带文字的椭圆形...这种自定义控件的灵活性使得开发者能够在Android应用中实现各种独特的设计概念,提升用户的交互体验。
4. **显示更新**:在控制台或用户界面上输出新的文字进度条状态。 在.NET框架中,可以使用System.Windows.Forms命名空间的ProgressBar控件来实现此功能。以下是一个简单的C#示例: ```csharp using System; using ...
在Android开发中,自定义控件是提升应用界面独特性和用户体验的重要手段。本文将深入探讨如何在Android中创建一个自定义的圆形进度条,这个进度条不仅能够展示进度,还能根据设计需求进行个性化定制。 首先,我们...
在Android开发中,自定义控件能够满足特定的界面需求,提供更加丰富的用户体验。本教程将深入探讨如何创建一个自定义的圆形进度条,也就是所谓的饼图,它具有缓动效果,适用于各种进度统计场景。这个自定义控件的...
首先,我们从基础开始,了解Android中的默认进度条控件`ProgressBar`。它是Android系统提供的一个原生组件,可以显示进度或等待状态。但是,如果想实现更个性化的视觉效果,例如渐变色、自定义形状等,就需要自定义...
在Android开发中,`HorizontalProgressBar`是用于展示进度的一种控件,它以水平条的形式显示当前任务或操作的完成程度。在特定情况下,我们可能希望在进度条的右侧添加一些额外的元素,如圆点或者数字,以更直观地...
本压缩包“安卓进度条loadingprogress相关-Android源码圆形进度条.rar”包含了Android系统中实现圆形进度条的相关源码,可能是开发者为了展示或者学习如何自定义控件而准备的示例。下面将详细探讨圆形进度条在...
通用上传控件JS进度条源码 源码描述: 开发环境:vs2012(源代码复制到其他版本vs也可以用) 浏览器兼容:全部,需要支持Silverlight 技术特点: 单、多文件上传,js进度条,同页面支持无限个 功能描述: 同页面...
ProgressBar是Android系统提供的一个基本控件,用于显示进度信息。它有两种模式:水平(Horizontal)和圆形(Circular)。我们将在自定义组件中结合这两种模式,创建一个既横向又圆形的进度条。 1. **自定义View类*...
这是一个独特的控件,它将按钮和进度条功能结合在一起,用户在点击按钮后,按钮会显示一个进度条,表示某个后台任务正在执行。这在执行异步操作或需要用户等待的场景中非常有用,因为它提供了直观的用户体验。 要...
4. 重写CDialog或CDialogEx类的OnDrawItem() 函数,用于在ListView的每个项上绘制进度条。这通常涉及计算进度条的宽度和高度,然后使用 CDC 类的绘图函数(如MoveTo(), LineTo(), Rectangle() 等)来绘制进度条。 5...
总之,“android自定义环形进度条ProgressWheel”是一个实用的自定义控件,它结合了`View`的绘制机制、`Shape`的图形绘制能力,以及Android的动画机制,使得开发者可以轻松地在应用中实现个性化的环形进度条。...
这个资源集合,"ASPNET批量上传控件 显示进度条",提供了实现这一功能的方法,包括了C#编程语言、ASP.NET框架、SQL数据库交互以及源码分析等关键知识点。 批量上传控件通常是一个自定义的Web控件,它允许用户选择多...