基本信息
源码名称:android 移动PathMenu 菜单 例子源码下载
源码大小:1.57M
文件格式:.rar
开发语言:Java
更新时间:2015-04-01
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
pathmenu
pathmenu
public class PathMenuActivity extends Activity implements OnTouchListener {
private boolean areButtonsShowing;
private RelativeLayout composerButtonsWrapper;
private ImageView composerButtonsShowHideButtonIcon;
private RelativeLayout composerButtonsShowHideButton;
private WebView wv;
int lastX,lastY;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
MyAnimations.initOffset(PathMenuActivity.this);
findViews();
setListener();
wv.loadUrl("http://mall.tymshop.com/index.aspx");
wv.setWebViewClient(new WebViewClient());
// 加号的动画
composerButtonsShowHideButton.startAnimation(MyAnimations.getRotateAnimation(0, 360, 200));
composerButtonsShowHideButton.setOnTouchListener(this);
}
//菜单拖动事件
@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
int ea=event.getAction();
DisplayMetrics dm=getResources().getDisplayMetrics();
int screenWidth=dm.widthPixels;
int screenHeight=dm.heightPixels-100;//需要减掉图片的高度
switch(ea){
case MotionEvent.ACTION_DOWN:
lastX=(int)event.getRawX();//获取触摸事件触摸位置的原始X坐标
lastY=(int)event.getRawY();
case MotionEvent.ACTION_MOVE:
//event.getRawX();获得移动的位置
int dx=(int)event.getRawX()-lastX;
int dy=(int)event.getRawY()-lastY;
int l=v.getLeft() dx;
int b=v.getBottom() dy;
int r=v.getRight() dx;
int t=v.getTop() dy;
//下面判断移动是否超出屏幕
if(l<0){
l=0;
r=l v.getWidth();
}
if(t<0){
t=0;
b=t v.getHeight();
}
if(r>screenWidth){
r=screenWidth;
l=r-v.getWidth();
}
if(b>screenHeight){
b=screenHeight;
t=b-v.getHeight();
}
v.layout(l, t, r, b);
lastX=(int)event.getRawX();
lastY=(int)event.getRawY();
/*v.setX(lastX);
v.setY(lastY);*/
v.postInvalidate();
break;
case MotionEvent.ACTION_UP:
break;
}
return false;
}
private void findViews() {
composerButtonsWrapper = (RelativeLayout) findViewById(R.id.composer_buttons_wrapper);
composerButtonsShowHideButton = (RelativeLayout) findViewById(R.id.composer_buttons_show_hide_button);
composerButtonsShowHideButtonIcon = (ImageView) findViewById(R.id.composer_buttons_show_hide_button_icon);
wv = (WebView) findViewById(R.id.webView123);
}
private void setListener() {
// 给大按钮设置点击事件
composerButtonsShowHideButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
if (!areButtonsShowing) {
// 图标的动画
MyAnimations.startAnimationsIn(composerButtonsWrapper, 300);
// 加号的动画
composerButtonsShowHideButtonIcon.startAnimation(MyAnimations.getRotateAnimation(0, 360, 300));
} else {
// 图标的动画
MyAnimations.startAnimationsOut(composerButtonsWrapper, 300);
// 加号的动画
composerButtonsShowHideButtonIcon.startAnimation(MyAnimations.getRotateAnimation(360, 0, 300));
}
areButtonsShowing = !areButtonsShowing;
}
});
// 给小图标设置点击事件
for (int i = 0; i < composerButtonsWrapper.getChildCount(); i ) {
final ImageView smallIcon = (ImageView) composerButtonsWrapper.getChildAt(i);
final int position = i;
smallIcon.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View arg0) {
// 这里写各个item的点击事件
// 1.加号按钮缩小后消失 缩小的animation
// 2.其他按钮缩小后消失 缩小的animation
// 3.被点击按钮放大后消失 透明度渐变 放大渐变的animation
if (smallIcon.getId()==R.id.composer_button_meichat) {
Intent intent = new Intent(PathMenuActivity.this, ShowActivity.class);
startActivity(intent);
// PathMenuActivity.this.finish();
}
if (smallIcon.getId()==R.id.composer_button_found) {
Intent intent = new Intent(PathMenuActivity.this, ShowActivity.class);
startActivity(intent);
// PathMenuActivity.this.finish();
}
if (smallIcon.getId()==R.id.composer_button_maillist) {
Intent intent = new Intent(PathMenuActivity.this, ShowActivity.class);
startActivity(intent);
// PathMenuActivity.this.finish();
}
if (smallIcon.getId()==R.id.composer_button_mysetting) {
Intent intent = new Intent(PathMenuActivity.this, ShowActivity.class);
startActivity(intent);
// PathMenuActivity.this.finish();
}
composerButtonsShowHideButtonIcon.startAnimation(MyAnimations.getRotateAnimation(-225, 0, 300));
areButtonsShowing = !areButtonsShowing;
smallIcon.startAnimation(MyAnimations.getMaxAnimation(400));
for (int j = 0; j < composerButtonsWrapper.getChildCount(); j ) {
if (j != position) {
final ImageView smallIcon = (ImageView) composerButtonsWrapper.getChildAt(j);
smallIcon.startAnimation(MyAnimations.getMiniAnimation(300));
}
}
}
});
}
}
}