diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..9c4de58 --- /dev/null +++ b/.gitignore @@ -0,0 +1,7 @@ +.gradle +/local.properties +/.idea/workspace.xml +/.idea/libraries +.DS_Store +/build +/captures diff --git a/.idea/.name b/.idea/.name new file mode 100644 index 0000000..4007ad4 --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +GifView \ No newline at end of file diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..96cc43e --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/copyright/profiles_settings.xml b/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000..e7bedf3 --- /dev/null +++ b/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/.idea/encodings.xml b/.idea/encodings.xml new file mode 100644 index 0000000..97626ba --- /dev/null +++ b/.idea/encodings.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..1bbc21d --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..c60d22d --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1.7 + + + + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..534a831 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/runConfigurations.xml b/.idea/runConfigurations.xml new file mode 100644 index 0000000..7f68460 --- /dev/null +++ b/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..6564d52 --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/GifView.iml b/GifView.iml new file mode 100644 index 0000000..366f099 --- /dev/null +++ b/GifView.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/Qn1QMFU.gif b/Qn1QMFU.gif new file mode 100644 index 0000000..bc43663 Binary files /dev/null and b/Qn1QMFU.gif differ diff --git a/Thumbs.db b/Thumbs.db new file mode 100644 index 0000000..6aaf978 Binary files /dev/null and b/Thumbs.db differ diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..796b96d --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/app/app.iml b/app/app.iml new file mode 100644 index 0000000..ae1d6a0 --- /dev/null +++ b/app/app.iml @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..b87230b --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,32 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 23 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "cuneyt.example.com.gifview" + minSdkVersion 15 + targetSdkVersion 23 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } +} +repositories { + maven { url "https://jitpack.io" } +} +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + testCompile 'junit:junit:4.12' + compile 'com.android.support:appcompat-v7:23.0.1' + compile 'com.android.support:design:23.0.1' + compile('com.afollestad.material-dialogs:core:0.8.2.0@aar') { + transitive = true + } +} diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..be5b184 --- /dev/null +++ b/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in C:\Users\lnvo\AppData\Local\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 *; +#} diff --git a/app/src/androidTest/java/cuneyt/example/com/gifview/ApplicationTest.java b/app/src/androidTest/java/cuneyt/example/com/gifview/ApplicationTest.java new file mode 100644 index 0000000..2520798 --- /dev/null +++ b/app/src/androidTest/java/cuneyt/example/com/gifview/ApplicationTest.java @@ -0,0 +1,13 @@ +package cuneyt.example.com.gifview; + +import android.app.Application; +import android.test.ApplicationTestCase; + +/** + * Testing Fundamentals + */ +public class ApplicationTest extends ApplicationTestCase { + public ApplicationTest() { + super(Application.class); + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..938e633 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + diff --git a/app/src/main/java/cuneyt/example/com/gifview/Activities/ListViewActivity.java b/app/src/main/java/cuneyt/example/com/gifview/Activities/ListViewActivity.java new file mode 100644 index 0000000..d292374 --- /dev/null +++ b/app/src/main/java/cuneyt/example/com/gifview/Activities/ListViewActivity.java @@ -0,0 +1,66 @@ +package cuneyt.example.com.gifview.Activities; + +import android.app.ListActivity; +import android.os.Bundle; +import android.os.Handler; +import android.os.PersistableBundle; +import android.support.v4.widget.SwipeRefreshLayout; +import android.view.LayoutInflater; +import android.view.View; +import android.widget.Adapter; +import android.widget.ArrayAdapter; +import android.widget.EditText; +import android.widget.ListView; +import android.widget.TextView; +import android.widget.Toast; + +import com.afollestad.materialdialogs.MaterialDialog; + +import cuneyt.example.com.gifview.R; +import cuneyt.example.com.gifview.Utils.GifView; + +/** + * Created by Cuneyt on 14.10.2015. + */ +public class ListViewActivity extends ListActivity { + SwipeRefreshLayout mSwipeRefreshLayout; + ListView listView; + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_list); + listView = (ListView)findViewById(android.R.id.list); + ArrayAdapter itemsAdapter = + new ArrayAdapter(this, android.R.layout.simple_list_item_1, getResources().getStringArray(R.array.city_names)); + listView.setAdapter(itemsAdapter); + + mSwipeRefreshLayout = (SwipeRefreshLayout)findViewById(R.id.swipe); + mSwipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { + @Override + public void onRefresh() { + refreshContent(); + } + }); + + refreshContent(); + Toast.makeText(ListViewActivity.this, "Swipe To Refresh", Toast.LENGTH_LONG).show(); + } + private void refreshContent() {//fake + LayoutInflater layoutInflater = getLayoutInflater(); + View view = layoutInflater.inflate(R.layout.dialog_loading, null); + GifView gifView1 = (GifView) view.findViewById(R.id.gif1); + gifView1.setVisibility(View.VISIBLE); + final MaterialDialog dialog = new MaterialDialog.Builder(ListViewActivity.this).customView(view, true).build(); + dialog.show(); + + final Handler handler = new Handler(); + handler.postDelayed(new Runnable() { + @Override + public void run() { + mSwipeRefreshLayout.setRefreshing(false); + dialog.dismiss(); + } + }, 1000); + } + +} \ No newline at end of file diff --git a/app/src/main/java/cuneyt/example/com/gifview/Activities/MainActivity.java b/app/src/main/java/cuneyt/example/com/gifview/Activities/MainActivity.java new file mode 100644 index 0000000..4238b74 --- /dev/null +++ b/app/src/main/java/cuneyt/example/com/gifview/Activities/MainActivity.java @@ -0,0 +1,184 @@ +package cuneyt.example.com.gifview.Activities; + +import android.content.Intent; +import android.os.Bundle; +import android.support.v4.app.FragmentTransaction; +import android.support.v7.app.AppCompatActivity; +import android.support.v7.widget.Toolbar; +import android.view.Gravity; +import android.view.LayoutInflater; +import android.view.Menu; +import android.view.MenuItem; +import android.view.View; +import android.view.View.OnClickListener; +import android.widget.Button; +import android.widget.Toast; + +import com.afollestad.materialdialogs.MaterialDialog; + +import cuneyt.example.com.gifview.Fragments.GifFragment; +import cuneyt.example.com.gifview.R; +import cuneyt.example.com.gifview.Utils.GifView; + +public class MainActivity extends AppCompatActivity { + Button loadingBtn1, loadingBtn2, loadingBtn3, loadingBtn4, deletingBtn; + Button toast; + Button fragment; + Button activity; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_main); + Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); + setSupportActionBar(toolbar); + + activity = (Button)findViewById(R.id.activity); + activity.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + openActivity(); + } + }); + fragment = (Button)findViewById(R.id.fragment); + fragment.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + openFragment(); + } + }); + toast = (Button) findViewById(R.id.toast); + toast.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + showToast(); + + } + }); + + loadingBtn1 = (Button) findViewById(R.id.loading_btn1); + loadingBtn1.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + + openLoadingDialog(1); + } + }); + loadingBtn2 = (Button) findViewById(R.id.loading_btn2); + loadingBtn2.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + + openLoadingDialog(2); + } + }); + loadingBtn3 = (Button) findViewById(R.id.loading_btn3); + loadingBtn3.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + + openLoadingDialog(3); + } + }); + loadingBtn4 = (Button) findViewById(R.id.loading_btn4); + loadingBtn4.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + + openLoadingDialog(4); + } + }); + + deletingBtn = (Button) findViewById(R.id.deleting_btn); + deletingBtn.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + + openDeletingDialog(); + } + }); + + + } + + public void openActivity(){ + Intent i = new Intent(MainActivity.this,ListViewActivity.class); + startActivity(i); + } + + public void openFragment(){ + FragmentTransaction trans = getSupportFragmentManager() + .beginTransaction(); + GifFragment fragment = new GifFragment().newInstance(); + fragment.setHasOptionsMenu(true); + trans.replace(R.id.frame, fragment, fragment.getTAG()); + trans.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN); + trans.addToBackStack(fragment.getTAG()); + trans.commitAllowingStateLoss(); + } + public void showToast() { + LayoutInflater inflater = getLayoutInflater(); + View layout = inflater.inflate(R.layout.custom_toast, null); + Toast toast = new Toast(getApplicationContext()); + toast.setGravity(Gravity.CENTER_VERTICAL, 0, 0); + toast.setDuration(Toast.LENGTH_LONG); + toast.setView(layout); + toast.show(); + } + + public void openLoadingDialog(int index) { + LayoutInflater layoutInflater = getLayoutInflater(); + View view = layoutInflater.inflate(R.layout.dialog_loading, null); + GifView gifView1 = (GifView) view.findViewById(R.id.gif1); + GifView gifView2 = (GifView) view.findViewById(R.id.gif2); + GifView gifView3 = (GifView) view.findViewById(R.id.gif3); + GifView gifView4 = (GifView) view.findViewById(R.id.gif4); + switch (index) { + case 1: + gifView1.setVisibility(View.VISIBLE); + break; + case 2: + gifView2.setVisibility(View.VISIBLE); + break; + case 3: + gifView3.setVisibility(View.VISIBLE); + break; + case 4: + gifView4.setVisibility(View.VISIBLE); + break; + } + + MaterialDialog dialog = new MaterialDialog.Builder(MainActivity.this).customView(view, true).build(); + dialog.show(); + + + } + + public void openDeletingDialog() { + MaterialDialog dialog = new MaterialDialog.Builder(MainActivity.this).customView(R.layout.dialog_deleting, true).build(); + dialog.show(); + + } + + @Override + public boolean onCreateOptionsMenu(Menu menu) { + // Inflate the menu; this adds items to the action bar if it is present. + getMenuInflater().inflate(R.menu.menu_main, menu); + return true; + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + // Handle action bar item clicks here. The action bar will + // automatically handle clicks on the Home/Up button, so long + // as you specify a parent activity in AndroidManifest.xml. + int id = item.getItemId(); + + //noinspection SimplifiableIfStatement + if (id == R.id.action_settings) { + return true; + } + + return super.onOptionsItemSelected(item); + } +} diff --git a/app/src/main/java/cuneyt/example/com/gifview/Fragments/GifFragment.java b/app/src/main/java/cuneyt/example/com/gifview/Fragments/GifFragment.java new file mode 100644 index 0000000..a30dcd4 --- /dev/null +++ b/app/src/main/java/cuneyt/example/com/gifview/Fragments/GifFragment.java @@ -0,0 +1,46 @@ +package cuneyt.example.com.gifview.Fragments; + +import android.os.Bundle; +import android.support.annotation.Nullable; +import android.support.v4.app.Fragment; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; + +import cuneyt.example.com.gifview.R; + +/** + * Created by Cuneyt on 14.10.2015. + */ +public class GifFragment extends Fragment { + private String TAG; + LayoutInflater inflater; + private static int InstanceCount = 0; + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + } + + @Nullable + @Override + public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { + + this.inflater = inflater; + View view = inflater.inflate(R.layout.fragment_layout, container, false); + return view; + } + + public static GifFragment newInstance() { + GifFragment fragment = new GifFragment(); + fragment.setTAG((GifFragment.InstanceCount++) + ""); + return fragment; + } + + public String getTAG() { + return TAG; + } + + public void setTAG(String TAG) { + this.TAG = TAG; + } +} diff --git a/app/src/main/java/cuneyt/example/com/gifview/Utils/GifView.java b/app/src/main/java/cuneyt/example/com/gifview/Utils/GifView.java new file mode 100644 index 0000000..c0703a4 --- /dev/null +++ b/app/src/main/java/cuneyt/example/com/gifview/Utils/GifView.java @@ -0,0 +1,272 @@ +package cuneyt.example.com.gifview.Utils; + +import android.annotation.SuppressLint; +import android.content.Context; +import android.content.res.TypedArray; +import android.graphics.Canvas; +import android.graphics.Movie; +import android.os.Build; +import android.support.annotation.NonNull; +import android.util.AttributeSet; +import android.view.View; + +import cuneyt.example.com.gifview.R; + +/** + * Created by Cuneyt on 4.10.2015. + */ +public class GifView extends View { + + private static final int DEFAULT_MOVIEW_DURATION = 1000; + + private int mMovieResourceId; + private Movie mMovie; + + private long mMovieStart; + private int mCurrentAnimationTime = 0; + + /** + * Position for drawing animation frames in the center of the view. + */ + private float mLeft; + private float mTop; + + /** + * Scaling factor to fit the animation within view bounds. + */ + private float mScale; + + /** + * Scaled movie frames width and height. + */ + private int mMeasuredMovieWidth; + private int mMeasuredMovieHeight; + + private volatile boolean mPaused = false; + private boolean mVisible = true; + + public GifView(Context context) { + this(context, null); + } + + public GifView(Context context, AttributeSet attrs) { + this(context, attrs, R.styleable.CustomTheme_gifViewStyle); + } + + public GifView(Context context, AttributeSet attrs, int defStyle) { + super(context, attrs, defStyle); + + setViewAttributes(context, attrs, defStyle); + } + + @SuppressLint("NewApi") + private void setViewAttributes(Context context, AttributeSet attrs, int defStyle) { + + /** + * Starting from HONEYCOMB(Api Level:11) have to turn off HW acceleration to draw + * Movie on Canvas. + */ + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { + setLayerType(View.LAYER_TYPE_SOFTWARE, null); + } + + final TypedArray array = context.obtainStyledAttributes(attrs, R.styleable.GifView, defStyle, R.style.Widget_GifView); + + //-1 is default value + mMovieResourceId = array.getResourceId(R.styleable.GifView_gif, -1); + mPaused = array.getBoolean(R.styleable.GifView_paused, false); + + array.recycle(); + + if (mMovieResourceId != -1) { + mMovie = Movie.decodeStream(getResources().openRawResource(mMovieResourceId)); + } + } + + public void setMovieResource(int movieResId) { + this.mMovieResourceId = movieResId; + mMovie = Movie.decodeStream(getResources().openRawResource(mMovieResourceId)); + requestLayout(); + } + + public void setMovie(Movie movie) { + this.mMovie = movie; + requestLayout(); + } + + public Movie getMovie() { + return mMovie; + } + + public void setMovieTime(int time) { + mCurrentAnimationTime = time; + invalidate(); + } + + public void setPaused(boolean paused) { + this.mPaused = paused; + + /** + * Calculate new movie start time, so that it resumes from the same + * frame. + */ + if (!paused) { + mMovieStart = android.os.SystemClock.uptimeMillis() - mCurrentAnimationTime; + } + + invalidate(); + } + + public boolean isPaused() { + return this.mPaused; + } + + @Override + protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { + + if (mMovie != null) { + int movieWidth = mMovie.width(); + int movieHeight = mMovie.height(); + + /* + * Calculate horizontal scaling + */ + float scaleH = 1f; + int measureModeWidth = MeasureSpec.getMode(widthMeasureSpec); + + if (measureModeWidth != MeasureSpec.UNSPECIFIED) { + int maximumWidth = MeasureSpec.getSize(widthMeasureSpec); + if (movieWidth > maximumWidth) { + scaleH = (float) movieWidth / (float) maximumWidth; + } + } + + /* + * calculate vertical scaling + */ + float scaleW = 1f; + int measureModeHeight = MeasureSpec.getMode(heightMeasureSpec); + + if (measureModeHeight != MeasureSpec.UNSPECIFIED) { + int maximumHeight = MeasureSpec.getSize(heightMeasureSpec); + if (movieHeight > maximumHeight) { + scaleW = (float) movieHeight / (float) maximumHeight; + } + } + + /* + * calculate overall scale + */ + mScale = 1f / Math.max(scaleH, scaleW); + + mMeasuredMovieWidth = (int) (movieWidth * mScale); + mMeasuredMovieHeight = (int) (movieHeight * mScale); + + setMeasuredDimension(mMeasuredMovieWidth, mMeasuredMovieHeight); + + } else { + /* + * No movie set, just set minimum available size. + */ + setMeasuredDimension(getSuggestedMinimumWidth(), getSuggestedMinimumHeight()); + } + } + + @Override + protected void onLayout(boolean changed, int l, int t, int r, int b) { + super.onLayout(changed, l, t, r, b); + + /* + * Calculate left / top for drawing in center + */ + mLeft = (getWidth() - mMeasuredMovieWidth) / 2f; + mTop = (getHeight() - mMeasuredMovieHeight) / 2f; + + mVisible = getVisibility() == View.VISIBLE; + } + + @Override + protected void onDraw(Canvas canvas) { + if (mMovie != null) { + if (!mPaused) { + updateAnimationTime(); + drawMovieFrame(canvas); + invalidateView(); + } else { + drawMovieFrame(canvas); + } + } + } + + /** + * Invalidates view only if it is visible. + *
+ * {@link #postInvalidateOnAnimation()} is used for Jelly Bean and higher. + * + */ + @SuppressLint("NewApi") + private void invalidateView() { + if(mVisible) { + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) { + postInvalidateOnAnimation(); + } else { + invalidate(); + } + } + } + + /** + * Calculate current animation time + */ + private void updateAnimationTime() { + long now = android.os.SystemClock.uptimeMillis(); + + if (mMovieStart == 0) { + mMovieStart = now; + } + + int dur = mMovie.duration(); + + if (dur == 0) { + dur = DEFAULT_MOVIEW_DURATION; + } + + mCurrentAnimationTime = (int) ((now - mMovieStart) % dur); + } + + /** + * Draw current GIF frame + */ + private void drawMovieFrame(Canvas canvas) { + + mMovie.setTime(mCurrentAnimationTime); + + canvas.save(Canvas.MATRIX_SAVE_FLAG); + canvas.scale(mScale, mScale); + mMovie.draw(canvas, mLeft / mScale, mTop / mScale); + canvas.restore(); + } + + @SuppressLint("NewApi") + @Override + public void onScreenStateChanged(int screenState) { + super.onScreenStateChanged(screenState); + mVisible = screenState == SCREEN_STATE_ON; + invalidateView(); + } + + @SuppressLint("NewApi") + @Override + protected void onVisibilityChanged(@NonNull View changedView, int visibility) { + super.onVisibilityChanged(changedView, visibility); + mVisible = visibility == View.VISIBLE; + invalidateView(); + } + + @Override + protected void onWindowVisibilityChanged(int visibility) { + super.onWindowVisibilityChanged(visibility); + mVisible = visibility == View.VISIBLE; + invalidateView(); + } +} \ No newline at end of file diff --git a/app/src/main/res/layout/activity_list.xml b/app/src/main/res/layout/activity_list.xml new file mode 100644 index 0000000..6740af4 --- /dev/null +++ b/app/src/main/res/layout/activity_list.xml @@ -0,0 +1,18 @@ + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/activity_loading_gifs.xml b/app/src/main/res/layout/activity_loading_gifs.xml new file mode 100644 index 0000000..20e802e --- /dev/null +++ b/app/src/main/res/layout/activity_loading_gifs.xml @@ -0,0 +1,14 @@ + + + + + + + + + diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..841af97 --- /dev/null +++ b/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + diff --git a/app/src/main/res/layout/content_loading_gifs.xml b/app/src/main/res/layout/content_loading_gifs.xml new file mode 100644 index 0000000..283e9f4 --- /dev/null +++ b/app/src/main/res/layout/content_loading_gifs.xml @@ -0,0 +1,14 @@ + + + + + + diff --git a/app/src/main/res/layout/content_main.xml b/app/src/main/res/layout/content_main.xml new file mode 100644 index 0000000..a6413b1 --- /dev/null +++ b/app/src/main/res/layout/content_main.xml @@ -0,0 +1,115 @@ + + + + + + +