Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Parent activity interface added + missing functions added #195

Merged
merged 11 commits into from
Mar 21, 2017
Original file line number Diff line number Diff line change
Expand Up @@ -1269,6 +1269,11 @@ public int getSlidePosition(Slide slide) {
return adapter.getItemPosition(slide);
}

@SuppressWarnings("unused")
public int getCurrentSlidePosition() {
return binding.miPager.getCurrentItem();
}

@SuppressWarnings("unused")
public Fragment getItem(int position) {
return adapter.getItem(position);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;

import com.heinrichreimersoftware.materialintro.R;
Expand All @@ -34,7 +35,7 @@ public class SimpleSlide implements Slide, RestorableSlide, ButtonCtaSlide {
private static final int DEFAULT_PERMISSIONS_REQUEST_CODE = 34; //Random number
private SimpleSlideFragment fragment;


private final long id;
private final CharSequence title;
@StringRes
private final int titleRes;
Expand All @@ -61,9 +62,10 @@ public class SimpleSlide implements Slide, RestorableSlide, ButtonCtaSlide {
private View.OnClickListener buttonCtaClickListener = null;

protected SimpleSlide(Builder builder) {
fragment = SimpleSlideFragment.newInstance(builder.title, builder.titleRes,
fragment = SimpleSlideFragment.newInstance(builder.id, builder.title, builder.titleRes,
builder.description, builder.descriptionRes, builder.imageRes,
builder.backgroundRes, builder.layoutRes, builder.permissionsRequestCode);
id = builder.id;
title = builder.title;
titleRes = builder.titleRes;
description = builder.description;
Expand Down Expand Up @@ -182,6 +184,7 @@ public boolean equals(Object o) {

SimpleSlide that = (SimpleSlide) o;

if (id != that.id) return false;
if (titleRes != that.titleRes) return false;
if (descriptionRes != that.descriptionRes) return false;
if (imageRes != that.imageRes) return false;
Expand All @@ -207,6 +210,7 @@ public boolean equals(Object o) {
@Override
public int hashCode() {
int result = fragment != null ? fragment.hashCode() : 0;
result = 31 * result + ((Long)id).hashCode();
result = 31 * result + (title != null ? title.hashCode() : 0);
result = 31 * result + titleRes;
result = 31 * result + (description != null ? description.hashCode() : 0);
Expand All @@ -228,6 +232,7 @@ public int hashCode() {
public static class Builder {
@ColorRes
private int backgroundRes = 0;
private long id = 0;
@ColorRes
private int backgroundDarkRes = 0;
private CharSequence title = null;
Expand Down Expand Up @@ -278,6 +283,11 @@ public Builder titleHtml(String titleHtml) {
return this;
}

public Builder id(long id) {
this.id = id;
return this;
}

public Builder title(@StringRes int titleRes) {
this.titleRes = titleRes;
this.title = null;
Expand Down Expand Up @@ -386,6 +396,8 @@ public SimpleSlide build() {
}

public static class SimpleSlideFragment extends ParallaxSlideFragment {
private static final String ARGUMENT_ID =
"com.heinrichreimersoftware.materialintro.SimpleFragment.ARGUMENT_ID";
private static final String ARGUMENT_TITLE =
"com.heinrichreimersoftware.materialintro.SimpleFragment.ARGUMENT_TITLE";
private static final String ARGUMENT_TITLE_RES =
Expand All @@ -404,14 +416,19 @@ public static class SimpleSlideFragment extends ParallaxSlideFragment {
private static final String ARGUMENT_PERMISSIONS_REQUEST_CODE =
"com.heinrichreimersoftware.materialintro.SimpleFragment.ARGUMENT_PERMISSIONS_REQUEST_CODE";

private TextView titleView = null;
private TextView descriptionView = null;
private ImageView imageView = null;

public SimpleSlideFragment() {
}

public static SimpleSlideFragment newInstance(CharSequence title, @StringRes int titleRes,
public static SimpleSlideFragment newInstance(long id, CharSequence title, @StringRes int titleRes,
CharSequence description, @StringRes int descriptionRes,
@DrawableRes int imageRes, @ColorRes int backgroundRes,
@LayoutRes int layout, int permissionsRequestCode) {
Bundle arguments = new Bundle();
arguments.putLong(ARGUMENT_ID, id);
arguments.putCharSequence(ARGUMENT_TITLE, title);
arguments.putInt(ARGUMENT_TITLE_RES, titleRes);
arguments.putCharSequence(ARGUMENT_DESCRIPTION, description);
Expand Down Expand Up @@ -449,10 +466,11 @@ public View onCreateView(LayoutInflater inflater, ViewGroup container,
View fragment = inflater.inflate(arguments.getInt(ARGUMENT_LAYOUT_RES,
R.layout.mi_fragment_simple_slide), container, false);

TextView titleView = (TextView) fragment.findViewById(R.id.mi_title);
TextView descriptionView = (TextView) fragment.findViewById(R.id.mi_description);
ImageView imageView = (ImageView) fragment.findViewById(R.id.mi_image);
titleView = (TextView) fragment.findViewById(R.id.mi_title);
descriptionView = (TextView) fragment.findViewById(R.id.mi_description);
imageView = (ImageView) fragment.findViewById(R.id.mi_image);

long id = arguments.getLong(ARGUMENT_ID);
CharSequence title = arguments.getCharSequence(ARGUMENT_TITLE);
int titleRes = arguments.getInt(ARGUMENT_TITLE_RES);
CharSequence description = arguments.getCharSequence(ARGUMENT_DESCRIPTION);
Expand Down Expand Up @@ -519,9 +537,42 @@ public View onCreateView(LayoutInflater inflater, ViewGroup container,
descriptionView.setTextColor(textColorSecondary);
}

if (getActivity() instanceof SimpleSlideActivity) {
((SimpleSlideActivity)getActivity()).onSlideViewCreated(this, fragment, id);
}

return fragment;
}

@Override
public void onDestroyView() {
if (getActivity() instanceof SimpleSlideActivity) {
long id = getArguments().getLong(ARGUMENT_ID);
((SimpleSlideActivity)getActivity()).onSlideDestroyView(this, getView(), id);
}
titleView = null;
descriptionView = null;
imageView = null;
super.onDestroyView();
}

public TextView getTitleView() {
return titleView;
}

public TextView getDescriptionView() {
return descriptionView;
}

public ImageView getImageView(){
return imageView;
}

public int getSlideId()
{
return getArguments().getInt(ARGUMENT_ID);
}

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
@NonNull int[] grantResults) {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
package com.heinrichreimersoftware.materialintro.slide;

import android.view.View;

public interface SimpleSlideActivity
{
void onSlideViewCreated(SimpleSlide.SimpleSlideFragment fragment, View view, long id);
void onSlideDestroyView(SimpleSlide.SimpleSlideFragment fragment, View view, long id);
}