diff --git a/Android/doric/src/main/java/pub/doric/pullable/DoricRefreshView.java b/Android/doric/src/main/java/pub/doric/pullable/DoricRefreshView.java index 2d404750..6ab3633e 100644 --- a/Android/doric/src/main/java/pub/doric/pullable/DoricRefreshView.java +++ b/Android/doric/src/main/java/pub/doric/pullable/DoricRefreshView.java @@ -2,6 +2,7 @@ package pub.doric.pullable; import android.content.Context; import android.util.AttributeSet; +import android.util.Log; import android.view.Gravity; import android.view.View; import android.view.ViewGroup; @@ -17,10 +18,12 @@ import androidx.annotation.Nullable; * @Author: pengfei.zhou * @CreateDate: 2019-11-25 */ -public class DoricRefreshView extends FrameLayout implements IPullable { +public class DoricRefreshView extends FrameLayout implements PullingListener { private View content; private Animation.AnimationListener mListener; + private PullingListener mPullingListenr; + public DoricRefreshView(@NonNull Context context) { super(context); } @@ -50,33 +53,29 @@ public class DoricRefreshView extends FrameLayout implements IPullable { return content; } + + public void setPullingListenr(PullingListener listenr) { + this.mPullingListenr = listenr; + } + @Override public void startAnimation() { - if (content != null && content instanceof IPullable) { - ((IPullable) content).startAnimation(); + if (mPullingListenr != null) { + mPullingListenr.startAnimation(); } } @Override public void stopAnimation() { - if (content != null && content instanceof IPullable) { - ((IPullable) content).stopAnimation(); - } - } - - @Override - public int successAnimation() { - if (content != null && content instanceof IPullable) { - return ((IPullable) content).successAnimation(); - } else { - return 0; + if (mPullingListenr != null) { + mPullingListenr.stopAnimation(); } } @Override public void setProgressRotation(float rotation) { - if (content != null && content instanceof IPullable) { - ((IPullable) content).setProgressRotation(rotation); + if (mPullingListenr != null) { + mPullingListenr.setProgressRotation(rotation); } } diff --git a/Android/doric/src/main/java/pub/doric/pullable/IPullable.java b/Android/doric/src/main/java/pub/doric/pullable/IPullable.java deleted file mode 100644 index 83bb96af..00000000 --- a/Android/doric/src/main/java/pub/doric/pullable/IPullable.java +++ /dev/null @@ -1,27 +0,0 @@ -package pub.doric.pullable; - -/** - * @Description: pub.doric.pullable - * @Author: pengfei.zhou - * @CreateDate: 2019-11-25 - */ -public interface IPullable { - - void startAnimation(); - - void stopAnimation(); - - /** - * run the animation after pull request success and before stop animation - * - * @return the duration of success animation or 0 if no success animation - */ - int successAnimation(); - - /** - * Set the amount of rotation to apply to the progress spinner. - * - * @param rotation Rotation is from [0..1] - */ - void setProgressRotation(float rotation); -} diff --git a/Android/doric/src/main/java/pub/doric/pullable/PullingListener.java b/Android/doric/src/main/java/pub/doric/pullable/PullingListener.java index 71df7b07..6c2c3257 100644 --- a/Android/doric/src/main/java/pub/doric/pullable/PullingListener.java +++ b/Android/doric/src/main/java/pub/doric/pullable/PullingListener.java @@ -5,7 +5,7 @@ package pub.doric.pullable; * @Author: pengfei.zhou * @CreateDate: 2019-11-25 */ -public interface IPullable { +public interface PullingListener { void startAnimation(); diff --git a/Android/doric/src/main/java/pub/doric/pullable/RefreshableNode.java b/Android/doric/src/main/java/pub/doric/pullable/RefreshableNode.java index 37fbb31a..329f8207 100644 --- a/Android/doric/src/main/java/pub/doric/pullable/RefreshableNode.java +++ b/Android/doric/src/main/java/pub/doric/pullable/RefreshableNode.java @@ -1,5 +1,7 @@ package pub.doric.pullable; +import android.view.animation.Animation; + import com.github.pengfeizhou.jscore.JSObject; import com.github.pengfeizhou.jscore.JSValue; import com.github.pengfeizhou.jscore.JavaValue; @@ -17,7 +19,7 @@ import pub.doric.shader.ViewNode; * @CreateDate: 2019-11-26 */ @DoricPlugin(name = "Refreshable") -public class RefreshableNode extends SuperNode { +public class RefreshableNode extends SuperNode implements PullingListener { private String mContentViewId; private ViewNode mContentNode; @@ -32,7 +34,9 @@ public class RefreshableNode extends SuperNode { @Override protected DoricSwipeLayout build() { - return new DoricSwipeLayout(getContext()); + DoricSwipeLayout doricSwipeLayout = new DoricSwipeLayout(getContext()); + doricSwipeLayout.getRefreshView().setPullingListenr(this); + return doricSwipeLayout; } @Override @@ -162,4 +166,25 @@ public class RefreshableNode extends SuperNode { public void isRefreshing(DoricPromise doricPromise) { doricPromise.resolve(new JavaValue(this.mView.isRefreshing())); } + + @Override + public void startAnimation() { + if (mHeaderNode != null) { + mHeaderNode.callJSResponse("startAnimation"); + } + } + + @Override + public void stopAnimation() { + if (mHeaderNode != null) { + mHeaderNode.callJSResponse("stopAnimation"); + } + } + + @Override + public void setProgressRotation(float rotation) { + if (mHeaderNode != null) { + mHeaderNode.callJSResponse("setProgressRotation", rotation); + } + } } diff --git a/Android/doric/src/main/java/pub/doric/shader/ViewNode.java b/Android/doric/src/main/java/pub/doric/shader/ViewNode.java index ee394eab..3a98a74f 100644 --- a/Android/doric/src/main/java/pub/doric/shader/ViewNode.java +++ b/Android/doric/src/main/java/pub/doric/shader/ViewNode.java @@ -257,4 +257,16 @@ public abstract class ViewNode extends DoricContextHolder { public int getHeight() { return mView.getHeight(); } + + @DoricMethod + public void setRotation(JSValue jsValue) { + float rotation = jsValue.asNumber().toFloat(); + while (rotation > 1) { + rotation = rotation - 1; + } + while (rotation < -1) { + rotation = rotation + 1; + } + doricLayer.setRotation(rotation * 360); + } } diff --git a/demo/src/RefreshableDemo.ts b/demo/src/RefreshableDemo.ts index 24d83750..a3b457ca 100644 --- a/demo/src/RefreshableDemo.ts +++ b/demo/src/RefreshableDemo.ts @@ -60,6 +60,18 @@ class RefreshableDemo extends Panel { refreshView.setRefreshable(context, false) } } as IText), + label('Rotate self').apply({ + width: 300, + height: 50, + bgColor: colors[0], + textSize: 30, + textColor: Color.WHITE, + layoutConfig: layoutConfig().exactly(), + } as IText).also(v => { + v.onClick = () => { + v.nativeChannel(context, "setRotation")(0.25) + } + }), ]).apply({ layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT), gravity: gravity().center(), diff --git a/demo/src/utils.ts b/demo/src/utils.ts index a024952e..18debee8 100644 --- a/demo/src/utils.ts +++ b/demo/src/utils.ts @@ -1,5 +1,7 @@ import { Color, text, Stack, Text, layoutConfig, LayoutSpec, gravity } from "doric"; +export const icon_refresh = '' + export const colors = [ "#70a1ff", "#7bed9f", diff --git a/js-framework/src/ui/refreshable.ts b/js-framework/src/ui/refreshable.ts index f1ca4704..1a73cb93 100644 --- a/js-framework/src/ui/refreshable.ts +++ b/js-framework/src/ui/refreshable.ts @@ -3,6 +3,7 @@ import { List } from "./list"; import { Scroller } from "./scroller"; import { BridgeContext } from "../runtime/global"; import { layoutConfig } from "./declarative"; +import { Image } from "./widgets"; export interface IRefreshable extends IView { content: List | Scroller @@ -58,3 +59,13 @@ export function refreshable(config: IRefreshable) { } return ret } + +export interface IPullable { + startAnimation(): void + stopAnimation(): void + setProgressRotation(rotation: number): void +} + +export class PullableView extends Image { + +} \ No newline at end of file