Repository: nugongshou110/AutoHomeRefreshListView Branch: master Commit: c3cbfd85e8cd Files: 40 Total size: 45.6 KB Directory structure: gitextract_3n07il1e/ ├── .gitignore ├── .idea/ │ ├── .name │ ├── compiler.xml │ ├── copyright/ │ │ └── profiles_settings.xml │ ├── gradle.xml │ ├── misc.xml │ ├── modules.xml │ ├── runConfigurations.xml │ └── vcs.xml ├── AutoHomeRefreshListView.iml ├── README.md ├── app/ │ ├── .gitignore │ ├── app.iml │ ├── build.gradle │ ├── proguard-rules.pro │ └── src/ │ ├── androidTest/ │ │ └── java/ │ │ └── com/ │ │ └── zhangqi/ │ │ └── autohomerefreshlistview/ │ │ └── ApplicationTest.java │ └── main/ │ ├── AndroidManifest.xml │ ├── java/ │ │ └── com/ │ │ └── zhangqi/ │ │ └── autohomerefreshlistview/ │ │ ├── AutoHome.java │ │ ├── AutoHomeListView.java │ │ ├── MainActivity.java │ │ ├── PointerView.java │ │ └── PullToFreshActivity.java │ └── res/ │ ├── anim/ │ │ └── pointer_rotate.xml │ ├── layout/ │ │ ├── activity_autohome.xml │ │ ├── activity_main.xml │ │ ├── autohome_animationview.xml │ │ ├── autohome_item.xml │ │ └── listview_header_view.xml │ ├── menu/ │ │ └── menu_main.xml │ ├── values/ │ │ ├── dimens.xml │ │ ├── strings.xml │ │ └── styles.xml │ └── values-w820dp/ │ └── dimens.xml ├── build.gradle ├── gradle/ │ └── wrapper/ │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradle.properties ├── gradlew ├── gradlew.bat └── settings.gradle ================================================ FILE CONTENTS ================================================ ================================================ FILE: .gitignore ================================================ .gradle /local.properties /.idea/workspace.xml /.idea/libraries .DS_Store /build /captures ================================================ FILE: .idea/.name ================================================ AutoHomeRefreshListView ================================================ FILE: .idea/compiler.xml ================================================ ================================================ FILE: .idea/copyright/profiles_settings.xml ================================================ ================================================ FILE: .idea/gradle.xml ================================================ ================================================ FILE: .idea/misc.xml ================================================ Android API 22 Platform ================================================ FILE: .idea/modules.xml ================================================ ================================================ FILE: .idea/runConfigurations.xml ================================================ ================================================ FILE: .idea/vcs.xml ================================================ ================================================ FILE: AutoHomeRefreshListView.iml ================================================ ================================================ FILE: README.md ================================================ # AutoHomeRefreshListView 仿汽车之家下拉刷新 ![这里写图片描述](http://img.blog.csdn.net/20151101145703270) ================================================ FILE: app/.gitignore ================================================ /build ================================================ FILE: app/app.iml ================================================ ================================================ FILE: app/build.gradle ================================================ apply plugin: 'com.android.application' android { compileSdkVersion 23 buildToolsVersion "23.0.0" defaultConfig { applicationId "com.zhangqi.autohomerefreshlistview" minSdkVersion 14 targetSdkVersion 23 versionCode 1 versionName "1.0" } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } } dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.android.support:appcompat-v7:23.0.0' } ================================================ FILE: app/proguard-rules.pro ================================================ # Add project specific ProGuard rules here. # By default, the flags in this file are appended to flags specified # in /Users/zhangqi/Library/Android/sdk/tools/proguard/proguard-android.txt # You can edit the include path and order by changing the proguardFiles # directive in build.gradle. # # For more details, see # http://developer.android.com/guide/developing/tools/proguard.html # Add any project specific keep options here: # If your project uses WebView with JS, uncomment the following # and specify the fully qualified class name to the JavaScript interface # class: #-keepclassmembers class fqcn.of.javascript.interface.for.webview { # public *; #} ================================================ FILE: app/src/androidTest/java/com/zhangqi/autohomerefreshlistview/ApplicationTest.java ================================================ package com.zhangqi.autohomerefreshlistview; import android.app.Application; import android.test.ApplicationTestCase; /** * Testing Fundamentals */ public class ApplicationTest extends ApplicationTestCase { public ApplicationTest() { super(Application.class); } } ================================================ FILE: app/src/main/AndroidManifest.xml ================================================ ================================================ FILE: app/src/main/java/com/zhangqi/autohomerefreshlistview/AutoHome.java ================================================ package com.zhangqi.autohomerefreshlistview; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.util.AttributeSet; import android.view.View; /** * Created by zhangqi on 15/10/17. */ public class AutoHome extends View{ private Bitmap backGroundBitmap; public Bitmap pointerBitmap; private int x; private int y; private Bitmap finalBackGroundBitmap; private Bitmap finalPointerBitmap; private float mCurrentProgress; public AutoHome(Context context) { super(context); init(context); } public AutoHome(Context context, AttributeSet attrs) { super(context, attrs); init(context); } public AutoHome(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(context); } private void init(Context context) { backGroundBitmap = Bitmap.createBitmap(BitmapFactory.decodeResource(context.getResources(), R.drawable.load_icon_dial2x)); pointerBitmap = Bitmap.createBitmap(BitmapFactory.decodeResource(context.getResources(), R.drawable.load_icon_pointer2x)); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { setMeasuredDimension(measureWidth(widthMeasureSpec), measureHeight(heightMeasureSpec)); } private int measureWidth(int widthMeasureSpec) { int result = 0; int size = MeasureSpec.getSize(widthMeasureSpec); int mode = MeasureSpec.getMode(widthMeasureSpec); if (mode == MeasureSpec.EXACTLY) { result = size; } else { result = backGroundBitmap.getWidth(); if (mode == MeasureSpec.AT_MOST) { result = Math.min(result, size); } } return result; } private int measureHeight(int heightMeasureSpec){ int result = 0; int size = MeasureSpec.getSize(heightMeasureSpec); int mode = MeasureSpec.getMode(heightMeasureSpec); if (mode == MeasureSpec.EXACTLY){ result = size; }else{ result = backGroundBitmap.getHeight(); if (mode == MeasureSpec.AT_MOST){ result = Math.min(result,size); } } return result; } @Override protected void onSizeChanged(int w, int h, int oldw, int oldh) { super.onSizeChanged(w, h, oldw, oldh); x = w; y = h; finalBackGroundBitmap = Bitmap.createScaledBitmap(backGroundBitmap, x, y, true); finalPointerBitmap = Bitmap.createScaledBitmap(pointerBitmap, x, y, true); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); canvas.drawBitmap(finalBackGroundBitmap,0,0,null); canvas.rotate(mCurrentProgress*2.7f,x/2,y/2); canvas.drawBitmap(finalPointerBitmap, 0, 0, null); } public void setCurrentProgress(float progress){ mCurrentProgress = progress*100; } } ================================================ FILE: app/src/main/java/com/zhangqi/autohomerefreshlistview/AutoHomeListView.java ================================================ package com.zhangqi.autohomerefreshlistview; import android.content.Context; import android.util.AttributeSet; import android.view.LayoutInflater; import android.view.MotionEvent; import android.view.View; import android.view.ViewGroup; import android.view.animation.Animation; import android.view.animation.AnimationUtils; import android.widget.AbsListView; import android.widget.FrameLayout; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.TextView; /** * Created by zhangqi on 15/10/18. */ public class AutoHomeListView extends ListView implements AbsListView.OnScrollListener{ private static final int DONE = 0; private static final int PULL_TO_REFRESH = 1; private static final int RELEASE_TO_REFRESH = 2; private static final int REFRESHING = 3; private static final int RATIO = 3; private LinearLayout headerView; private AutoHome mAutoHome; private int headerViewHeight; private float startY; private float offsetY; private TextView tv_pull_to_refresh; private OnAutoHomeRefreshListener mOnRefreshListener; private int state; private int mFirstVisibleItem; private boolean isRecord; private boolean isEnd; private boolean isRefreable; private FrameLayout mAnimContainer; private PointerView mAutoHomeAnim; private Animation animation; public AutoHomeListView(Context context) { super(context); init(context); } public AutoHomeListView(Context context, AttributeSet attrs) { super(context, attrs); init(context); } public AutoHomeListView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(context); } public interface OnAutoHomeRefreshListener{ void onRefresh(); } public void setOnAutoHomeRefreshListener(OnAutoHomeRefreshListener onRefreshListener){ mOnRefreshListener = onRefreshListener; isRefreable = true; } public void setOnRefreshComplete(){ isEnd = true; state = DONE; changeHeaderByState(state); } private void init(Context context) { setOverScrollMode(View.OVER_SCROLL_NEVER); setOnScrollListener(this); headerView = (LinearLayout) LayoutInflater.from(context).inflate(R.layout.autohome_item, null, false); mAutoHome = (AutoHome) headerView.findViewById(R.id.auto_home); tv_pull_to_refresh = (TextView) headerView.findViewById(R.id.tv_pull_to_refresh); mAnimContainer = (FrameLayout) headerView.findViewById(R.id.anim_container); mAutoHomeAnim = (PointerView) headerView.findViewById(R.id.anim_pointer); animation = AnimationUtils.loadAnimation(context, R.anim.pointer_rotate); measureView(headerView); addHeaderView(headerView); headerViewHeight = headerView.getMeasuredHeight(); headerView.setPadding(0, -headerViewHeight, 0, 0); state = DONE; isEnd = true; isRefreable = false; } @Override public void onScrollStateChanged(AbsListView absListView, int i) { } @Override public void onScroll(AbsListView absListView, int firstVisibleItem, int visibleItemCount, int totalItemCount) { mFirstVisibleItem = firstVisibleItem; } @Override public boolean onTouchEvent(MotionEvent ev) { if (isEnd) { if (isRefreable) { switch (ev.getAction()){ case MotionEvent.ACTION_DOWN: if (mFirstVisibleItem == 0 && !isRecord) { isRecord = true; startY = ev.getY(); } break; case MotionEvent.ACTION_MOVE: float tempY = ev.getY(); if (mFirstVisibleItem == 0 && !isRecord) { isRecord = true; startY = tempY; } if (state!=REFRESHING && isRecord ) { offsetY = tempY - startY; float currentHeight = (-headerViewHeight+offsetY/RATIO); float currentProgress = 1+currentHeight/headerViewHeight; if (currentProgress>=1) { currentProgress = 1; } if (state == RELEASE_TO_REFRESH && isRecord) { setSelection(0); if (-headerViewHeight+offsetY/RATIO<0) { state = PULL_TO_REFRESH; changeHeaderByState(state); }else if (offsetY<=0) { state = DONE; changeHeaderByState(state); } } if (state == PULL_TO_REFRESH && isRecord) { setSelection(0); if (-headerViewHeight+offsetY/RATIO>=0) { state = RELEASE_TO_REFRESH; changeHeaderByState(state); }else if (offsetY<=0) { state = DONE; changeHeaderByState(state); } } if (state == DONE && isRecord) { if (offsetY>=0) { state = PULL_TO_REFRESH; } } if (state == PULL_TO_REFRESH) { headerView.setPadding(0,(int)(-headerViewHeight+offsetY/RATIO) ,0,0); mAutoHome.setCurrentProgress(currentProgress); mAutoHome.postInvalidate(); } if (state == RELEASE_TO_REFRESH) { headerView.setPadding(0,(int)(-headerViewHeight+offsetY/RATIO) ,0, 0); mAutoHome.setCurrentProgress(currentProgress); mAutoHome.postInvalidate(); } } break; case MotionEvent.ACTION_UP: if (state == PULL_TO_REFRESH) { this.smoothScrollBy((int)(-headerViewHeight+offsetY/RATIO)+headerViewHeight, 500); changeHeaderByState(state); } if (state == RELEASE_TO_REFRESH) { this.smoothScrollBy((int)(-headerViewHeight+offsetY/RATIO), 500); state = REFRESHING; mOnRefreshListener.onRefresh(); changeHeaderByState(state); } isRecord = false; break; } } } return super.onTouchEvent(ev); } private void changeHeaderByState(int state){ switch (state) { case DONE: headerView.setPadding(0, -headerViewHeight, 0, 0); //第一状态的view显示出来 mAutoHome.setVisibility(View.VISIBLE); //先停止一下第二阶段view的动画 mAutoHomeAnim.clearAnimation(); //将第二阶段view隐藏起来 mAnimContainer.setVisibility(View.GONE); break; case RELEASE_TO_REFRESH: tv_pull_to_refresh.setText("放开刷新"); break; case PULL_TO_REFRESH: tv_pull_to_refresh.setText("下拉刷新"); //第一状态view显示出来 mAutoHome.setVisibility(View.VISIBLE); //停止第二阶段动画 mAutoHomeAnim.clearAnimation(); //将第二阶段view隐藏 mAnimContainer.setVisibility(View.GONE); break; case REFRESHING: tv_pull_to_refresh.setText("正在刷新"); //将第一阶段view隐藏 mAutoHome.setVisibility(View.GONE); //将第二阶段view显示出来 mAnimContainer.setVisibility(View.VISIBLE); //先停止第二阶段动画 mAutoHomeAnim.clearAnimation(); //启动第二阶段动画 mAutoHomeAnim.startAnimation(animation); break; default: break; } } private void measureView(View child) { ViewGroup.LayoutParams p = child.getLayoutParams(); if (p == null) { p = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT); } int childWidthSpec = ViewGroup.getChildMeasureSpec(0, 0 + 0, p.width); int lpHeight = p.height; int childHeightSpec; if (lpHeight > 0) { childHeightSpec = MeasureSpec.makeMeasureSpec(lpHeight, MeasureSpec.EXACTLY); } else { childHeightSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED); } child.measure(childWidthSpec, childHeightSpec); } } ================================================ FILE: app/src/main/java/com/zhangqi/autohomerefreshlistview/MainActivity.java ================================================ package com.zhangqi.autohomerefreshlistview; import android.app.Activity; import android.os.Bundle; import android.widget.SeekBar; public class MainActivity extends Activity { private SeekBar mSeekBar; private AutoHome mAutoHome; private float mCurrentProgress; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mSeekBar = (SeekBar) findViewById(R.id.seekbar); mAutoHome = (AutoHome) findViewById(R.id.autohome); mSeekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onProgressChanged(SeekBar seekBar, int i, boolean b) { mCurrentProgress = (float)seekBar.getProgress()/(float)seekBar.getMax(); mAutoHome.setCurrentProgress(mCurrentProgress); mAutoHome.invalidate(); } @Override public void onStartTrackingTouch(SeekBar seekBar) { } @Override public void onStopTrackingTouch(SeekBar seekBar) { } }); } } ================================================ FILE: app/src/main/java/com/zhangqi/autohomerefreshlistview/PointerView.java ================================================ package com.zhangqi.autohomerefreshlistview; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.util.AttributeSet; import android.view.View; /** * Created by zhangqi on 15/10/27. */ public class PointerView extends View { private int x; private int y; private Bitmap finalPointerBitmap; private Bitmap pointerBitmap; public PointerView(Context context) { super(context); init(); } public PointerView(Context context, AttributeSet attrs) { super(context, attrs); init(); } public PointerView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(); } private void init() { pointerBitmap = Bitmap.createBitmap(BitmapFactory.decodeResource(getResources(), R.drawable.load_icon_pointer2x)); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { setMeasuredDimension(measureWidth(widthMeasureSpec), measureHeight(heightMeasureSpec)); } private int measureWidth(int widthMeasureSpec){ int result = 0; int size = MeasureSpec.getSize(widthMeasureSpec); int mode = MeasureSpec.getMode(widthMeasureSpec); if (mode == MeasureSpec.EXACTLY){ result = size; }else{ result = pointerBitmap.getWidth(); if (mode == MeasureSpec.AT_MOST){ result = Math.min(result,size); } } return result; } private int measureHeight(int heightMeasureSpec){ int result = 0; int size = MeasureSpec.getSize(heightMeasureSpec); int mode = MeasureSpec.getMode(heightMeasureSpec); if (mode == MeasureSpec.EXACTLY){ result = size; }else{ result = pointerBitmap.getHeight(); if (mode == MeasureSpec.AT_MOST){ result = Math.min(result,size); } } return result; } @Override protected void onSizeChanged(int w, int h, int oldw, int oldh) { super.onSizeChanged(w, h, oldw, oldh); x = w; y = h; finalPointerBitmap = Bitmap.createScaledBitmap(pointerBitmap, x, y, true); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); canvas.rotate(270,x/2,y/2); canvas.drawBitmap(finalPointerBitmap,0,0,null); } } ================================================ FILE: app/src/main/java/com/zhangqi/autohomerefreshlistview/PullToFreshActivity.java ================================================ package com.zhangqi.autohomerefreshlistview; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.widget.ArrayAdapter; import java.lang.ref.WeakReference; import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * Created by zhangqi on 15/10/18. */ public class PullToFreshActivity extends Activity implements AutoHomeListView.OnAutoHomeRefreshListener { private static AutoHomeListView mListView; private static ArrayAdapter mAdapter; private final static int REFRESH_COMPLETE = 0; private List mDatas; private InterHandler mInterHandler = new InterHandler(this); private static class InterHandler extends Handler{ private WeakReference mActivity; public InterHandler(PullToFreshActivity activity){ mActivity = new WeakReference(activity); } @Override public void handleMessage(Message msg) { PullToFreshActivity activity = mActivity.get(); if (activity != null) { switch (msg.what) { case REFRESH_COMPLETE: activity.mListView.setOnRefreshComplete(); activity.mAdapter.notifyDataSetChanged(); activity.mListView.setSelection(0); break; } }else{ super.handleMessage(msg); } } } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_autohome); String[] data = new String[]{"hello world1", "hello world2", "hello world3", "hello world4", "hello world5", "hello world6", "hello world7", "hello world8", "hello world9", "hello world10", "hello world11", "hello world12", "hello world13", "hello world14", "hello world15"}; mDatas = new ArrayList(Arrays.asList(data)); mAdapter = new ArrayAdapter(this, android.R.layout.simple_list_item_1, mDatas); mListView = (AutoHomeListView) findViewById(R.id.listview); mListView.setAdapter(mAdapter); mListView.setOnAutoHomeRefreshListener(this); } @Override public void onRefresh() { new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(3000); mDatas.add(0, "new data"); mInterHandler.sendEmptyMessage(REFRESH_COMPLETE); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }).start(); } } ================================================ FILE: app/src/main/res/anim/pointer_rotate.xml ================================================ ================================================ FILE: app/src/main/res/layout/activity_autohome.xml ================================================ ================================================ FILE: app/src/main/res/layout/activity_main.xml ================================================ ================================================ FILE: app/src/main/res/layout/autohome_animationview.xml ================================================ ================================================ FILE: app/src/main/res/layout/autohome_item.xml ================================================ ================================================ FILE: app/src/main/res/layout/listview_header_view.xml ================================================ ================================================ FILE: app/src/main/res/menu/menu_main.xml ================================================ ================================================ FILE: app/src/main/res/values/dimens.xml ================================================ 16dp 16dp ================================================ FILE: app/src/main/res/values/strings.xml ================================================ AutoHomeRefreshListView Hello world! Settings ================================================ FILE: app/src/main/res/values/styles.xml ================================================ ================================================ FILE: app/src/main/res/values-w820dp/dimens.xml ================================================ 64dp ================================================ FILE: build.gradle ================================================ // Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { repositories { jcenter() } dependencies { classpath 'com.android.tools.build:gradle:1.3.0' // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } } allprojects { repositories { jcenter() } } ================================================ FILE: gradle/wrapper/gradle-wrapper.properties ================================================ #Sun Nov 01 15:18:44 CST 2015 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists distributionUrl=https\://services.gradle.org/distributions/gradle-2.4-all.zip ================================================ FILE: gradle.properties ================================================ # Project-wide Gradle settings. # IDE (e.g. Android Studio) users: # Gradle settings configured through the IDE *will override* # any settings specified in this file. # For more details on how to configure your build environment visit # http://www.gradle.org/docs/current/userguide/build_environment.html # Specifies the JVM arguments used for the daemon process. # The setting is particularly useful for tweaking memory settings. # Default value: -Xmx10248m -XX:MaxPermSize=256m # org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 # When configured, Gradle will run in incubating parallel mode. # This option should only be used with decoupled projects. More details, visit # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects # org.gradle.parallel=true ================================================ FILE: gradlew ================================================ #!/usr/bin/env bash ############################################################################## ## ## Gradle start up script for UN*X ## ############################################################################## # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. DEFAULT_JVM_OPTS="" APP_NAME="Gradle" APP_BASE_NAME=`basename "$0"` # Use the maximum available, or set MAX_FD != -1 to use that value. MAX_FD="maximum" warn ( ) { echo "$*" } die ( ) { echo echo "$*" echo exit 1 } # OS specific support (must be 'true' or 'false'). cygwin=false msys=false darwin=false case "`uname`" in CYGWIN* ) cygwin=true ;; Darwin* ) darwin=true ;; MINGW* ) msys=true ;; esac # For Cygwin, ensure paths are in UNIX format before anything is touched. if $cygwin ; then [ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"` fi # Attempt to set APP_HOME # Resolve links: $0 may be a link PRG="$0" # Need this for relative symlinks. while [ -h "$PRG" ] ; do ls=`ls -ld "$PRG"` link=`expr "$ls" : '.*-> \(.*\)$'` if expr "$link" : '/.*' > /dev/null; then PRG="$link" else PRG=`dirname "$PRG"`"/$link" fi done SAVED="`pwd`" cd "`dirname \"$PRG\"`/" >&- APP_HOME="`pwd -P`" cd "$SAVED" >&- CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar # Determine the Java command to use to start the JVM. if [ -n "$JAVA_HOME" ] ; then if [ -x "$JAVA_HOME/jre/sh/java" ] ; then # IBM's JDK on AIX uses strange locations for the executables JAVACMD="$JAVA_HOME/jre/sh/java" else JAVACMD="$JAVA_HOME/bin/java" fi if [ ! -x "$JAVACMD" ] ; then die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME Please set the JAVA_HOME variable in your environment to match the location of your Java installation." fi else JAVACMD="java" which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. Please set the JAVA_HOME variable in your environment to match the location of your Java installation." fi # Increase the maximum file descriptors if we can. if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then MAX_FD_LIMIT=`ulimit -H -n` if [ $? -eq 0 ] ; then if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then MAX_FD="$MAX_FD_LIMIT" fi ulimit -n $MAX_FD if [ $? -ne 0 ] ; then warn "Could not set maximum file descriptor limit: $MAX_FD" fi else warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" fi fi # For Darwin, add options to specify how the application appears in the dock if $darwin; then GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" fi # For Cygwin, switch paths to Windows format before running java if $cygwin ; then APP_HOME=`cygpath --path --mixed "$APP_HOME"` CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` # We build the pattern for arguments to be converted via cygpath ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` SEP="" for dir in $ROOTDIRSRAW ; do ROOTDIRS="$ROOTDIRS$SEP$dir" SEP="|" done OURCYGPATTERN="(^($ROOTDIRS))" # Add a user-defined pattern to the cygpath arguments if [ "$GRADLE_CYGPATTERN" != "" ] ; then OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" fi # Now convert the arguments - kludge to limit ourselves to /bin/sh i=0 for arg in "$@" ; do CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` else eval `echo args$i`="\"$arg\"" fi i=$((i+1)) done case $i in (0) set -- ;; (1) set -- "$args0" ;; (2) set -- "$args0" "$args1" ;; (3) set -- "$args0" "$args1" "$args2" ;; (4) set -- "$args0" "$args1" "$args2" "$args3" ;; (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; esac fi # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules function splitJvmOpts() { JVM_OPTS=("$@") } eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" ================================================ FILE: gradlew.bat ================================================ @if "%DEBUG%" == "" @echo off @rem ########################################################################## @rem @rem Gradle startup script for Windows @rem @rem ########################################################################## @rem Set local scope for the variables with windows NT shell if "%OS%"=="Windows_NT" setlocal @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. set DEFAULT_JVM_OPTS= set DIRNAME=%~dp0 if "%DIRNAME%" == "" set DIRNAME=. set APP_BASE_NAME=%~n0 set APP_HOME=%DIRNAME% @rem Find java.exe if defined JAVA_HOME goto findJavaFromJavaHome set JAVA_EXE=java.exe %JAVA_EXE% -version >NUL 2>&1 if "%ERRORLEVEL%" == "0" goto init echo. echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. echo. echo Please set the JAVA_HOME variable in your environment to match the echo location of your Java installation. goto fail :findJavaFromJavaHome set JAVA_HOME=%JAVA_HOME:"=% set JAVA_EXE=%JAVA_HOME%/bin/java.exe if exist "%JAVA_EXE%" goto init echo. echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% echo. echo Please set the JAVA_HOME variable in your environment to match the echo location of your Java installation. goto fail :init @rem Get command-line arguments, handling Windowz variants if not "%OS%" == "Windows_NT" goto win9xME_args if "%@eval[2+2]" == "4" goto 4NT_args :win9xME_args @rem Slurp the command line arguments. set CMD_LINE_ARGS= set _SKIP=2 :win9xME_args_slurp if "x%~1" == "x" goto execute set CMD_LINE_ARGS=%* goto execute :4NT_args @rem Get arguments from the 4NT Shell from JP Software set CMD_LINE_ARGS=%$ :execute @rem Setup the command line set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar @rem Execute Gradle "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% :end @rem End local scope for the variables with windows NT shell if "%ERRORLEVEL%"=="0" goto mainEnd :fail rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of rem the _cmd.exe /c_ return code! if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 exit /b 1 :mainEnd if "%OS%"=="Windows_NT" endlocal :omega ================================================ FILE: settings.gradle ================================================ include ':app'