当前位置:  编程技术>移动开发
本页文章导读:
    ▪【转帖】LayoutInflater中四品种型inflate方法的介绍        【转帖】LayoutInflater中四种类型inflate方法的介绍 原文出自:网络第一种:public View inflate (int resource, ViewGroup root) reSource:View的layout的IDroot:如果返回null,则将此View作为根,此时既可以应用.........
    ▪ Struts学习札记《一》        Struts学习笔记《一》 namespace决定了action的访问路径,默认为“”,表示可以接受所有路径的actionnamespace可以写为/,或者/xxx,或者/xxx/yyy,对应的action访问路径为/index.acion./xxx/index.action, /xxx/yyy/.........
    ▪ 关于兑现类似于圆形ProgressBar的播放进度条       关于实现类似于圆形ProgressBar的播放进度条 我们要实现一个类似于小米分享中的圆形播放进度条,android自带的圆形ProgressBar是默认自动旋转的,所以无法实现,于是我们想到了使用自定义一.........

[1]【转帖】LayoutInflater中四品种型inflate方法的介绍
    来源: 互联网  发布时间: 2014-02-18
【转帖】LayoutInflater中四种类型inflate方法的介绍
原文出自:网络
第一种:
public View inflate (int resource, ViewGroup root)
reSource:View的layout的ID
root:如果返回null,则将此View作为根,此时既可以应用此View中的其他控件了。
          如果返回!null, 则将默认的layout作为View的根。

第二种:
public View inflate (XmlPullParser parser, ViewGroup root)
parser:你需要解析xml的解析接口
root:如果返回null,则将此View作为根,此时既可以应用此View中的其他控件了。
          如果返回!null, 则将默认的layout作为View的根。

第三种:
public View inflate (XmlPullParser parser, ViewGroup root, boolean attachToRoot)
parser:你需要解析View的xml的解析接口
root:如果返回null,则将此View作为根,此时既可以应用此View中的其他控件了。
          如果返回!null, 则将默认的layout作为View的根。
attachToRoot:
ture:也就将此解析的xml作为View根
fase:则为默认的xml,做为根视图View

第四种:
public View inflate (int resource, ViewGroup root, boolean attachToRoot)

resource:View的layout的ID
root:如果返回null,则将此View作为根,此时既可以应用此View中的其他控件了。
          如果返回!null, 则将默认的layout作为View的根。
attachToRoot:
ture:也就将此解析的xml作为View根
fase:则为默认的xml,做为根视图View

同时在此讲讲让我去API中去理解这四个函数的原因吧!嘿嘿!你肯定又会多学一招!
在Activity中:
大家是否知道,在setContentView(new MySurfaceView(this))后,此Activity中声明的View控件,
如:TextView为什么引用不到layout布局文件中的控件ID呢!初一看能够应用到,但是为什么编译就报空指针呢!原因:在setContentView(new MySurfaceView(this))后,此时的View变为了根视图了,虽然能应用到TextView对应的ID,但是我在MySurfaceView中根本就没有这个对象,所以就报空指针咯!解决办法:
View view = LayoutInflater.from(this).inflate(R.layout.passover, null);注:每解析一次都会产生不同的对象
然后你再引用没问题,使用自如了。
今天是咋们部门同事告诉我的,问题解决啦!

    
[2] Struts学习札记《一》
    来源: 互联网  发布时间: 2014-02-18
Struts学习笔记《一》
namespace决定了action的访问路径,默认为“”,表示可以接受所有路径的action
namespace可以写为/,或者/xxx,或者/xxx/yyy,对应的action访问路径为/index.acion./xxx/index.action, /xxx/yyy/index.action
namespace最好也用模块来进行命名
具体视图的返回可以由自己定义的Action来决定
具体的手段是根据返回的字符串知道对应的配置项,来决定视图的内容具体Action的实现可以是一个普通的java类,里面有public String execute方法即可或者实现Action接口
不过最常用的是从ActionSupport继承,好处在于可以直接使用Struts2封转好的方法
struts2中的路径问题是根据action的路径而不是jsp路径来确定,所以尽量不要使用相对路径
index.jsp
虽然可以用redirect方式来解决,但redirect方式并非必要
解决办法非常简单,统一使用绝对路径。(在jsp中用request.getContextRoot方式来拿到webapp的路径)
或者使用myeclipse经常用的,指定basePath
Action在执行的时候并不一定要执行execute方法
可以在配置文件中配置Action的时候用method=来指定执行哪个方法 也可以在url地址中动态指定(动态方法调用DMI)(推荐)
前者会产生太多的action,所以不推荐使用
使用通配符,将配置量降到最低
不过一定要遵守“约定优于配置”的原则

    
[3] 关于兑现类似于圆形ProgressBar的播放进度条
    来源: 互联网  发布时间: 2014-02-18
关于实现类似于圆形ProgressBar的播放进度条



我们要实现一个类似于小米分享中的圆形播放进度条,android自带的圆形ProgressBar是默认自动旋转的,所以无法实现,于是我们想到了使用自定义一个View,来实现这种效果。
首先来看看自己定义的View
package cn.easymobi.application.bell.common;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.View;
public class ProgressView extends View{
private float fArcNum;
private float fMax;
private float density;
public float getDensity() {
return density;
}
public void setDensity(float density) {
this.density = density;
}
public ProgressView(Context context) {
super(context);
}
public ProgressView(Context context,AttributeSet attrs) {
super(context,attrs);
}
protected void onDraw(Canvas canvas) {
// TODO Auto-generated method stub
super.onDraw(canvas);
Paint paint=new Paint();
if(fArcNum>0)
{
paint.setColor(Color.GRAY);
paint.setFlags(Paint.ANTI_ALIAS_FLAG);
canvas.drawCircle(40*density/2, 40*density/2, 40*density/2, paint);}
paint.setColor(Color.YELLOW);
paint.setFlags(Paint.ANTI_ALIAS_FLAG);
//paint.setStrokeWidth(2);
RectF rect=new RectF(0, 0, 40*density, 40*density);
canvas.drawArc(rect, -90, fArcNum,true, paint);
paint.setColor(Color.BLACK);
paint.setFlags(Paint.ANTI_ALIAS_FLAG);
canvas.drawCircle(40*density/2, 40*density/2, 40*density/2-5, paint);
}
public void setProgress(float num)
{
fArcNum = (num/fMax) * 360;

this.postInvalidate();
}
public float getfArcNum() {
return fArcNum;
}
public void setfArcNum(float fArcNum) {
this.fArcNum = fArcNum;
}
public float getfMax() {
return fMax;
}
public void setfMax(float fMax) {
this.fMax = fMax;
}
}

 

 

使用:

 

private ProgressView progress;
	float num=0;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.clean);
		progress=(ProgressView)findViewById(R.id.progress_main_clean);
		progress.setDensity(1);
		progress.setfMax(100);
		Timer timer=new Timer();
		MyTask task=new MyTask();
		timer.schedule(task,0, 500);
	}
	
	class MyTask extends TimerTask{

		@Override
		public void run() {
			// TODO Auto-generated method stub
			
			progress.setProgress(num);
			System.out.println("number"+num);
			num++;
		}
		
	}

 
我们通过重写View的onDraw方法,根据fArcNum好fMax来判断当前播放到的位置,然后不停的刷新改View就实现了这个效果。至于画弧,是采用了drawArc方法,然后通过在其内部画圆遮盖多余部分实现。
下面是MediaPlayer与该View的同步处理,核心代码如下
// *******************************************************************
// Func: playAudio
//
// by: Sun
// 2011.9.1
// *******************************************************************
public void playAudio(final String path, final ProgressBar pb) {
Thread thread = new Thread(new Runnable() {
public void run() {
try {
if (mpMediaPlayer != null) {
mpMediaPlayer.stop();
mpMediaPlayer.release();
mpMediaPlayer = null;
}
mpMediaPlayer = new MediaPlayer();
mpMediaPlayer.setDataSource(path);
mpMediaPlayer.prepare();
mpMediaPlayer
.setOnPreparedListener(new OnPreparedListener() {
public void onPrepared(MediaPlayer mp) {
pb.setVisibility(ProgressBar.GONE);
frontPv.setfMax(mpMediaPlayer.getDuration());
frontPv.setProgress(0);
mpMediaPlayer.start();
refrash = new Thread(new Runnable() {
public void run() {
try {
while (frontPv.getfArcNum() <= 360
&& mpMediaPlayer
.isPlaying()) {

if (bIsOver)
break;
frontPv.setProgress(mpMediaPlayer
.getCurrentPosition());
Thread.sleep(1000);
mHandle.sendEmptyMessage(MSG_REFRESH_UI);
}
mHandle.sendEmptyMessage(MSG_PLAY_OVER);
} catch (Exception e) {
e.printStackTrace();
}
}
});
refrash.start();
}
});
} catch (Exception e) {
e.printStackTrace();
}
}
});
thread.start();
}
其中frontPv是我们自己定义的view,最后发送handler是调用invalidate方法刷新该view,mpMediaPlayers是我们定义的MediaPlayer对象。我们通过在进程中每隔一秒更新frontPv当中的fArcNum并且刷新实现转动的动画效果。


原文章出处 http://labs.ywlx.net/?p=1296


    
最新技术文章:
▪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详解
数据库其它 iis7站长之家
▪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