`

左边可拖出菜单(页面)效果

阅读更多



这个效果现在很多软件都实现了,其实说穿了很简单的。就是一个动画,做的地道点的加一个手势拖拉效果。
我写的代码(未参考任何代码,不知道别人怎么实现的。):
import java.util.ArrayList;

import android.content.Context;
import android.os.Bundle;
import android.util.Log;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.KeyEvent;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.ViewGroup;
import android.view.animation.Animation;
import android.view.animation.Animation.AnimationListener;
import android.view.animation.LinearInterpolator;
import android.view.animation.TranslateAnimation;
import android.widget.AbsoluteLayout;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;

public class SlideRightActivity extends BaseActivity implements OnTouchListener,OnGestureListener{
	private Context context;
	private Button btn;
	private LinearLayout left_panel,right_panel;
	private boolean isShowing=false;
	private final int duration=200;
	
	//
	private GestureDetector mGestureDetector; 
//	private ViewGroup container;
	@Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_slide_right);
        context=this;
        initViews();
    }

	
	@Override
	protected void onResume() {
		// TODO Auto-generated method stub
		super.onResume();
		initValues();
	}

	@Override
	protected void updateViews(Object o) {
		// TODO Auto-generated method stub

	}

	@Override
	protected void initViews() {
		// TODO Auto-generated method stub
//		container=(ViewGroup)findViewById(R.id.container);
		left_panel=(LinearLayout)findViewById(R.id.left_panel);
		left_panel.setLayoutParams(new AbsoluteLayout.LayoutParams((int)(getResources().getDisplayMetrics().widthPixels*0.8), AbsoluteLayout.LayoutParams.MATCH_PARENT, 0, 0));
		right_panel=(LinearLayout)findViewById(R.id.right_panel);
		
		right_panel.setOnTouchListener(this);
		//定义手势识别  
		mGestureDetector = new GestureDetector(this,this);  
		mGestureDetector.setIsLongpressEnabled(false);
		
		ArrayList<String> list=new ArrayList<String>();
		list.add("1");
		list.add("2");
		list.add("3");
		list.add("4");
		list.add("5");
		list.add("6");
		ListView listView=(ListView)findViewById(R.id.listView);
		ListViewAdapter adapter=new ListViewAdapter(list);
		listView.setAdapter(adapter);
		
		
		btn=(Button)findViewById(R.id.btn);
		btn.setOnClickListener(onClickListener);
		ArrayList<String> texts=new ArrayList<String>();
  		texts.add("111");
  		texts.add("222");
  		texts.add("333");
  		texts.add("444");
  		texts.add("555");
  		texts.add("666");
  		texts.add("777");
  		ListView listViewBeside=(ListView)findViewById(R.id.listViewBeside);
  		ListViewAdapter adapterBeside=new ListViewAdapter(texts);
  		listViewBeside.setAdapter(adapterBeside);
  		/**让ListView不拦截手势滑动*/
  		listViewBeside.setOnTouchListener(new View.OnTouchListener(){

			@Override
			public boolean onTouch(View v, MotionEvent event) {
				// TODO Auto-generated method stub
				doSlideWhenTouchUp(event);
				mGestureDetector.onTouchEvent(event);
				return false;
			}
  			
  		});
    
  		listViewBeside.setOnItemClickListener(new ListView.OnItemClickListener() {

			@Override
			public void onItemClick(AdapterView<?> parent, View view,
					int position, long id) {
				// TODO Auto-generated method stub
				Log.i("tag", "position=="+position);
			}
		});
  		
	}

	View.OnClickListener onClickListener=new View.OnClickListener(){

		@Override
		public void onClick(View v) {
			// TODO Auto-generated method stub
			int width=left_panel.getMeasuredWidth();
			if(isShowing){
				doSlideCloseAnimation(right_panel,width);
			}else{
				doSlideOpenAnimation(right_panel,width);
			}
		}
		
	};
	
	@Override
	protected void initValues() {
		// TODO Auto-generated method stub
	}

	@Override
	protected void initHandler() {
		// TODO Auto-generated method stub

	}
	
	
	private void doSlideOpenAnimation(View v,int width) {
		TranslateAnimation animation = new TranslateAnimation(0, width, 0, 0);
		animation.setInterpolator(new LinearInterpolator());
		animation.setDuration(duration);
		animation.setFillAfter(true);
		v.startAnimation(animation);
		animation.setAnimationListener(new AnimationListener(){

			@Override
			public void onAnimationStart(Animation animation) {
				// TODO Auto-generated method stub
				
			}

			@Override
			public void onAnimationEnd(Animation animation) {
				// TODO Auto-generated method stub
				resetLayout(left_panel.getMeasuredWidth(),0);
                isShowing=true;
			}

			@Override
			public void onAnimationRepeat(Animation animation) {
				// TODO Auto-generated method stub
				
			}
			
		});
	}

	private void resetLayout(int width,int height){
		AbsoluteLayout.LayoutParams params = (AbsoluteLayout.LayoutParams)right_panel.getLayoutParams();
		params.x=width;
		params.y=height;
		right_panel.setLayoutParams(params);
		right_panel.clearAnimation();
	}
	
	private void doSlideCloseAnimation(View v,final int width) {
		TranslateAnimation animation = new TranslateAnimation(0, -width, 0, 0);
		animation.setInterpolator(new LinearInterpolator());
		animation.setDuration(duration);
		animation.setFillAfter(true);
		v.startAnimation(animation);
		animation.setAnimationListener(new AnimationListener(){

			@Override
			public void onAnimationStart(Animation animation) {
				// TODO Auto-generated method stub
				
			}

			@Override
			public void onAnimationEnd(Animation animation) {
				// TODO Auto-generated method stub
				resetLayout(0,0);
				isShowing=false;
			}

			@Override
			public void onAnimationRepeat(Animation animation) {
				// TODO Auto-generated method stub
				
			}
			
		});
		
	}
	
	class ListViewAdapter extends BaseAdapter{

		private ArrayList<String> list;
		public ListViewAdapter(ArrayList<String> list){
			this.list=list;
		}
		@Override
		public int getCount() {
			// TODO Auto-generated method stub
			return list.size();
		}

		@Override
		public Object getItem(int position) {
			// TODO Auto-generated method stub
			return list.get(position);
		}

		@Override
		public long getItemId(int position) {
			// TODO Auto-generated method stub
			return position;
		}

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			// TODO Auto-generated method stub
			if (convertView == null) {
				convertView = LayoutInflater.from(context).inflate(
						R.layout.simple_item_1_for_listview, null);
			}
			TextView tv0=(TextView)convertView.findViewById(R.id.simple_item_0);
			tv0.setText(list.get(position));
			return convertView;
		}
		
	}

	@Override
	public boolean onDown(MotionEvent e) {
		// TODO Auto-generated method stub
		return true;
	}


	@Override
	public void onShowPress(MotionEvent e) {
		// TODO Auto-generated method stub
		
	}


	@Override
	public boolean onSingleTapUp(MotionEvent e) {
		// TODO Auto-generated method stub
		return false;
	}

	private int mScrollx;
	@Override
	public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,
			float distanceY) {
		// TODO Auto-generated method stub
		mScrollx -= distanceX;//distanceX:向左为正,右为负
		AbsoluteLayout.LayoutParams params = (AbsoluteLayout.LayoutParams)right_panel.getLayoutParams();
		params.x+=mScrollx;//distanceX:向左为正,右为负
		if(params.x>left_panel.getMeasuredWidth()){
			params.x=left_panel.getMeasuredWidth();
		}
		if(params.x<0){
			params.x=0;
		}
		right_panel.setLayoutParams(params);
		return false;
	}


	@Override
	public void onLongPress(MotionEvent e) {
		// TODO Auto-generated method stub
		
	}


	@Override
	public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
			float velocityY) {
		// TODO Auto-generated method stub
		/** 手势快速滑动,打开/关闭panel。现已被onScroll()完成同样的功能 */
		/*int width=left_panel.getMeasuredWidth();
		if(velocityX>500){
			if(!isShowing)
				if(right_panel.getLeft()==0)
					doSlideOpenAnimation(right_panel, width);
		}else if(velocityX<-500){
			if(isShowing)
				if(right_panel.getLeft()==width)
					doSlideCloseAnimation(right_panel, width);
		}*/
		return false;
	}


	@Override
	public boolean onTouch(View v, MotionEvent event) {
		// TODO Auto-generated method stub
		doSlideWhenTouchUp(event);
		return mGestureDetector.onTouchEvent(event);
	}
	
	private void doSlideWhenTouchUp(MotionEvent event){
		switch (event.getAction()) {
		case MotionEvent.ACTION_UP:
			/** 手势拖动到一 半松手时,根据拖动的距离判断打开/关闭 */
			AbsoluteLayout.LayoutParams params = (AbsoluteLayout.LayoutParams)right_panel.getLayoutParams();
			int width=left_panel.getMeasuredWidth();
			int slideDistance=width>>1;
			if (params.x >= slideDistance) {
				doSlideOpenAnimation(right_panel, width-params.x);
			}else{
				doSlideCloseAnimation(right_panel, params.x);
			}
		default:
			break;
		}
	}
	
	@Override
	public boolean onKeyDown(int keyCode, KeyEvent event) {
		return super.onKeyDown(keyCode, event);
	}
	
	 
}


布局:
<AbsoluteLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/container"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" 
    >

    <LinearLayout
        android:id="@+id/left_panel"
        android:layout_width="250dp"
        android:layout_height="fill_parent"
        android:orientation="vertical" 
        android:layout_x="0dp"
        android:layout_y="0dp"
        >
        <ListView 
	    android:id="@+id/listView"
	    android:layout_width="fill_parent"
    	android:layout_height="fill_parent" 
    	android:cacheColorHint="@android:color/transparent"
	    />
    </LinearLayout>
    <LinearLayout
        android:id="@+id/right_panel"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" 
        android:background="@color/green"
        android:layout_x="0dp"
        android:layout_y="0dp"
        >
        <Button
            android:id="@+id/btn"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:text="open/close" />

        <ListView
            android:id="@+id/listViewBeside"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:cacheColorHint="@android:color/transparent" />
    </LinearLayout>

</AbsoluteLayout>


如果不加手势的话,其实也可以的:
import java.util.ArrayList;

import android.content.Context;
import android.os.Bundle;
import android.util.Log;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.KeyEvent;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.VelocityTracker;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.ViewGroup;
import android.view.animation.Animation;
import android.view.animation.Animation.AnimationListener;
import android.view.animation.LinearInterpolator;
import android.view.animation.TranslateAnimation;
import android.widget.AbsoluteLayout;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;

public class SlideRightActivity extends BaseActivity implements OnTouchListener/*,OnGestureListener*/{
	private Context context;
	private Button btn;
	private LinearLayout left_panel,right_panel;
	private boolean isShowing=false;
	private final int duration=200;
//	private GestureDetector mGestureDetector; 
	@Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_slide_right);
        context=this;
        initViews();
    }

	
	@Override
	protected void onResume() {
		// TODO Auto-generated method stub
		super.onResume();
		initValues();
	}

	@Override
	protected void updateViews(Object o) {
		// TODO Auto-generated method stub

	}

	@Override
	protected void initViews() {
		// TODO Auto-generated method stub
		left_panel=(LinearLayout)findViewById(R.id.left_panel);
		left_panel.setLayoutParams(new AbsoluteLayout.LayoutParams((int)(getResources().getDisplayMetrics().widthPixels*0.8), AbsoluteLayout.LayoutParams.MATCH_PARENT, 0, 0));
		right_panel=(LinearLayout)findViewById(R.id.right_panel);
		
		right_panel.setOnTouchListener(this);
		//定义手势识别  
//		mGestureDetector = new GestureDetector(this,this);  
//		mGestureDetector.setIsLongpressEnabled(false);
		
		ArrayList<String> list=new ArrayList<String>();
		list.add("1");
		list.add("2");
		list.add("3");
		list.add("4");
		list.add("5");
		list.add("6");
		ListView listView=(ListView)findViewById(R.id.listView);
		ListViewAdapter adapter=new ListViewAdapter(list);
		listView.setAdapter(adapter);
		
		
		btn=(Button)findViewById(R.id.btn);
		btn.setOnClickListener(onClickListener);
		ArrayList<String> texts=new ArrayList<String>();
  		texts.add("111");
  		texts.add("222");
  		texts.add("333");
  		texts.add("444");
  		texts.add("555");
  		texts.add("666");
  		texts.add("777");
  		ListView listViewBeside=(ListView)findViewById(R.id.listViewBeside);
  		ListViewAdapter adapterBeside=new ListViewAdapter(texts);
  		listViewBeside.setAdapter(adapterBeside);
  		/**让ListView不拦截手势滑动*/
  		listViewBeside.setOnTouchListener(new View.OnTouchListener(){

			@Override
			public boolean onTouch(View v, MotionEvent event) {
				// TODO Auto-generated method stub
				doSlideWhenTouchUp(event);
//				mGestureDetector.onTouchEvent(event);
				return false;
			}
  			
  		});
    
  		listViewBeside.setOnItemClickListener(new ListView.OnItemClickListener() {

			@Override
			public void onItemClick(AdapterView<?> parent, View view,
					int position, long id) {
				// TODO Auto-generated method stub
				Log.i("tag", "position=="+position);
			}
		});
  		
	}

	View.OnClickListener onClickListener=new View.OnClickListener(){

		@Override
		public void onClick(View v) {
			// TODO Auto-generated method stub
			int width=left_panel.getMeasuredWidth();
			if(isShowing){
				doSlideCloseAnimation(right_panel,width);
			}else{
				doSlideOpenAnimation(right_panel,width);
			}
		}
		
	};
	
	@Override
	protected void initValues() {
		// TODO Auto-generated method stub
	}

	@Override
	protected void initHandler() {
		// TODO Auto-generated method stub

	}
	
	
	private void doSlideOpenAnimation(View v,int width) {
		TranslateAnimation animation = new TranslateAnimation(0, width, 0, 0);
		animation.setInterpolator(new LinearInterpolator());
		animation.setDuration(duration);
		animation.setFillAfter(true);
		v.startAnimation(animation);
		animation.setAnimationListener(new AnimationListener(){

			@Override
			public void onAnimationStart(Animation animation) {
				// TODO Auto-generated method stub
				
			}

			@Override
			public void onAnimationEnd(Animation animation) {
				// TODO Auto-generated method stub
				resetLayout(left_panel.getMeasuredWidth(),0);
                isShowing=true;
			}

			@Override
			public void onAnimationRepeat(Animation animation) {
				// TODO Auto-generated method stub
				
			}
			
		});
	}

	private void resetLayout(int width,int height){
		AbsoluteLayout.LayoutParams params = (AbsoluteLayout.LayoutParams)right_panel.getLayoutParams();
		params.x=width;
		params.y=height;
		right_panel.setLayoutParams(params);
		right_panel.clearAnimation();
	}
	
	private void doSlideCloseAnimation(View v,final int width) {
		TranslateAnimation animation = new TranslateAnimation(0, -width, 0, 0);
		animation.setInterpolator(new LinearInterpolator());
		animation.setDuration(duration);
		animation.setFillAfter(true);
		v.startAnimation(animation);
		animation.setAnimationListener(new AnimationListener(){

			@Override
			public void onAnimationStart(Animation animation) {
				// TODO Auto-generated method stub
				
			}

			@Override
			public void onAnimationEnd(Animation animation) {
				// TODO Auto-generated method stub
				resetLayout(0,0);
				isShowing=false;
			}

			@Override
			public void onAnimationRepeat(Animation animation) {
				// TODO Auto-generated method stub
				
			}
			
		});
		
	}
	
	class ListViewAdapter extends BaseAdapter{

		private ArrayList<String> list;
		public ListViewAdapter(ArrayList<String> list){
			this.list=list;
		}
		@Override
		public int getCount() {
			// TODO Auto-generated method stub
			return list.size();
		}

		@Override
		public Object getItem(int position) {
			// TODO Auto-generated method stub
			return list.get(position);
		}

		@Override
		public long getItemId(int position) {
			// TODO Auto-generated method stub
			return position;
		}

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			// TODO Auto-generated method stub
			if (convertView == null) {
				convertView = LayoutInflater.from(context).inflate(
						R.layout.simple_item_1_for_listview, null);
			}
			TextView tv0=(TextView)convertView.findViewById(R.id.simple_item_0);
			tv0.setText(list.get(position));
			return convertView;
		}
		
	}

	/*@Override
	public boolean onDown(MotionEvent e) {
		// TODO Auto-generated method stub
		return true;
	}


	@Override
	public void onShowPress(MotionEvent e) {
		// TODO Auto-generated method stub
		
	}


	@Override
	public boolean onSingleTapUp(MotionEvent e) {
		// TODO Auto-generated method stub
		return false;
	}

	private int mScrollx;
	@Override
	public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,
			float distanceY) {
		// TODO Auto-generated method stub
		mScrollx -= distanceX;//distanceX:向左为正,右为负
		AbsoluteLayout.LayoutParams params = (AbsoluteLayout.LayoutParams)right_panel.getLayoutParams();
		params.x+=mScrollx;//distanceX:向左为正,右为负
		if(params.x>left_panel.getMeasuredWidth()){
			params.x=left_panel.getMeasuredWidth();
		}
		if(params.x<0){
			params.x=0;
		}
		right_panel.setLayoutParams(params);
		return false;
	}


	@Override
	public void onLongPress(MotionEvent e) {
		// TODO Auto-generated method stub
		
	}


	@Override
	public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
			float velocityY) {
		// TODO Auto-generated method stub
		return false;
	}*/


	@Override
	public boolean onTouch(View v, MotionEvent event) {
		// TODO Auto-generated method stub
//		doSlideWhenTouchUp(event);
//		return mGestureDetector.onTouchEvent(event);
		Log.i("tag", "Action="+event.getAction());
		doSlideWhenTouchUp(event);
		return true;
	}
	
	private VelocityTracker tracker = null;//速度跟踪器,用于判断偏左还是偏右
	private boolean direction=true;//向左or向右拉
	private void doSlideWhenTouchUp(MotionEvent event){
		switch (event.getAction()) {
		case MotionEvent.ACTION_DOWN:
			if(tracker == null){  
                tracker = VelocityTracker.obtain();    
            }else{  
                tracker.clear();   
            }  
            tracker.addMovement(event);
			break;
		case MotionEvent.ACTION_UP:
			tracker.recycle();
			/** 手势拖动到一 半松手时,根据拖动的距离判断打开/关闭 */
			AbsoluteLayout.LayoutParams params = (AbsoluteLayout.LayoutParams)right_panel.getLayoutParams();
			int width=left_panel.getMeasuredWidth();
			int slideDistance=width/3;
			if(direction){
				if (params.x >= slideDistance) {
					doSlideOpenAnimation(right_panel, width-params.x);
				}else{
					doSlideCloseAnimation(right_panel, params.x);
				}
			}else{
				if (params.x >= width-slideDistance) {
					doSlideOpenAnimation(right_panel, width-params.x);
				}else{
					doSlideCloseAnimation(right_panel, params.x);
				}
			}
		case MotionEvent.ACTION_MOVE:
			tracker.addMovement(event);    
            tracker.computeCurrentVelocity(1000); 
			float  XVelocity=tracker.getXVelocity()*0.02f;//0.02是速度系数,这个根据手机世纪表现调出来的
			if(XVelocity<0){//向左划
				direction=false;
			}else{//向右划
				direction=true;
			}
//			Log.i("tag", "XVelocity="+XVelocity);  
			params = (AbsoluteLayout.LayoutParams)right_panel.getLayoutParams();
			params.x+=XVelocity;//distanceX:向左为正,右为负
			if(params.x>left_panel.getMeasuredWidth()){
				params.x=left_panel.getMeasuredWidth();
			}
			if(params.x<0){
				params.x=0;
			}
			right_panel.setLayoutParams(params);
			break;
		default:
			break;
		}
	}
	
	@Override
	public boolean onKeyDown(int keyCode, KeyEvent event) {
		return super.onKeyDown(keyCode, event);
	}
	
	 
}
  • 大小: 22.5 KB
分享到:
评论
2 楼 gundumw100 2014-04-02  
PpOo 写道
BaseActivity在哪?

将activity中带@Override的方法去掉@Override即可
1 楼 PpOo 2014-03-31  
BaseActivity在哪?

相关推荐

    在html页面中弹出子页面效果

    在html页面中弹出子页面效果,我在struts1中使用的。 用示例图!

    VC 实现可拖出主窗口的工具栏效果.rar

    VC 实现可拖出主窗口的工具栏效果,也就是窗口中的工具栏菜单可以整体被拖动,可停靠在窗口内,当靠近主窗体时,会像带有磁性一样吸附在主窗口的某个区域中,有很多播放器的播放列表就是这种窗口设计风格,用户可...

    实现QTabWidget拖出拆分窗口,拖入合并窗口,固定标签,关闭标签菜单源码

    QTabWidget拖出拆分窗口,拖入合并窗口,固定标签,关闭标签菜单,程序运行效果可以访问http://t.csdn.cn/biFEd查看,是否满足需求,再决定是否下载,避免浪费积分

    滑动屏幕拖出菜单效果

    源码DCBlurMenu,手指在导航条上向下滑动屏幕,可以拖拉出菜单,然后手指不离开屏幕继续滑动,可以选择菜单上的某个选项,松开手指后,菜单收回。菜单具有模糊背景的效果。 A blurred swipe down menu designed for...

    托盘+菜单控件(可以实现托盘以及带有图片的菜单)

    可以非常简单的实现程序托盘以及带有图片的菜单,还可以实现托盘菜单的闪烁

    Android 可拖动浮动工具条(菜单)Demo

    研究了一下午Android中可拖动浮动工具条的视线,主要思路是通过一个GridView绑定几个Item,通过Item点击事件可以实现具体操作。废话不多说上代码,过程全在Demo中

    自制unity 道路拖尾效果

    道路拖尾光点特效,拖尾效果,制作处道路上有运动的感觉效果见链接:https://blog.csdn.net/luckydogyxx/article/details/116918145

    仿网易点击左侧菜单右侧出现选项卡功能

    仿网易邮箱的点击左侧菜单右侧出现可关闭的选项卡功能,jquery+css+div代码

    页面中浮动的DIV(可拖移)

    页面中浮动的DIV(可拖移)页面中浮动的DIV(可拖移)

    拖扯效果,网页代码 html

    拖扯效果,很好。很使用 欢迎大家下载

    QML弹出窗口组件,灯箱效果、动画效果,可拖拽

    QML弹出窗口组件,灯箱效果、动画效果,可拖拽 核心思路:一个mask层,一个最顶层,都用rectangle,禁止事件穿透,动画效果 http://www.cnblogs.com/surfsky/p/3998391.html

    maya菜单及快捷键

    maya菜单及快捷键,熟悉maya。maya菜单及快捷键,熟悉maya

    易语言源码易语言文件拖进拖出列表源码.rar

    易语言源码易语言文件拖进拖出列表源码.rar 易语言源码易语言文件拖进拖出列表源码.rar 易语言源码易语言文件拖进拖出列表源码.rar 易语言源码易语言文件拖进拖出列表源码.rar 易语言源码易语言文件拖进拖出列表...

    易语言文件拖进拖出列表

    易语言文件拖进拖出列表源码,文件拖进拖出列表,处理消息,子程序_处理事件,子程序_枚举标题,处理,UnhookWindowsHookEx,SetWindowsHookEx,GetModuleHandle,CallNextHookEx,CopyMemoryR,枚举子窗口_,取父窗口_

    易语言文件拖进拖出列表源码

    易语言文件拖进拖出列表源码。@易语言在线学习。

    仿360杀毒-页面切换动画效果(C#源码)

    C#winform版 《仿360杀毒》页面切换动画效果昨天跟一个同事聊天,谈到了360杀毒的页面效果不错,我们所做的winform页面都是拖控件还是拖控件,不能吸引客户的注意力,想改成360的样式。 今天活不多,抽空仿做了两个...

    WakiCoolBar For Asp.net

    它可放进Web工具箱中,并可拖入WEB页面进行可视化的设置。只需设置Panels属性,几分钟时间,即可获得一个漂亮的类Outlook样式的菜单。各种页面效果均可通过控件属性来调节。使用者根本无须会Javascript,一样可以实现...

    wakicoolbar

    各种页面效果均可通过控件属性来调节,使用者根本无需会 Javascript,一样可以实现专业漂亮的菜单界面。 控件2.0版主要更新: 1.新增设置控件背景图片属性(BackGround),并可设置背景图片的显示位置及重复模式。 2....

    用Axure制作页面滚动时菜单固定在顶部的页面.rp

    用Axure制作页面滚动时菜单固定在顶部的页面 1.在Axure工作区中拖入4个矩形,分别为Head,Tab,content和bottom,其中content长一些 2.复制tab为tab2,坐标x与tab相同,坐标y为0,转化tab2为动态模板,并设置为隐藏 ...

    一个鼠标拖影、拖尾Flash效果源文件.rar

    一个简单的Flash鼠标拖影效果,也就是晃去鼠标,会留下鼠标的轨迹,类似于拖尾效果,拖着长长的尾巴,是一种比较常见的Flash鼠标特效,自带有源文件,在Flash8下可打开重新修改源文件。

Global site tag (gtag.js) - Google Analytics