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

Splash Screen Stretched #2652

Closed
anshbajpai opened this issue Feb 7, 2021 · 34 comments · Fixed by #5559
Closed

Splash Screen Stretched #2652

anshbajpai opened this issue Feb 7, 2021 · 34 comments · Fixed by #5559
Assignees
Labels
bug End user-perceivable behaviors which are not desirable. good first issue This item is good for new contributors to make their pull request. Impact: Low Low perceived user impact (e.g. edge cases). Z-ibt Temporary label for Ben to keep track of issues he's triaged.

Comments

@anshbajpai
Copy link

anshbajpai commented Feb 7, 2021

Describe the bug
Splash screen is displayed when a user opens the app, on small screen devices the splash screen is working as expected, but on large screen devices, the splash screen is getting stretched and doesn't work as expected.

To Reproduce
Steps to reproduce the behavior:

  1. Go to the Oppia app
  2. Click on the icon
  3. If your device screen is more than 6 inch
  4. See splash screen getting stretched

Expected behavior
The splash screen should be displayed in the same aspect ratio as needed.

Screenshots

[Note: Also reported in #3193 -- see additional videos in that issue.]

Expected Behaviour
Expected Behaviour
Actual Behaviour
SplashScreen

Device

  • OnePlus 7 Pro
  • Android 10.0

The logo should be fixed as per device width:

@anshbajpai
Copy link
Author

Hi , i want to work on this issue

anshbajpai added a commit to anshbajpai/oppia-android that referenced this issue Feb 7, 2021
@chrk2205
Copy link
Contributor

chrk2205 commented Feb 7, 2021

@anshbajpai
did you signed the CLA??
https://github.com/oppia/oppia-android/wiki

@anshbajpai
Copy link
Author

Yeah, I have signed the CLA now.

@anandwana001
Copy link
Contributor

@anshbajpai Suggesting to fill the Contributor survey as well to get an onboarding mentor assigned to get started with the contribution.
https://github.com/oppia/oppia-android/wiki#onboarding-instructions

@anshbajpai
Copy link
Author

@anandwana001 I have completed the survey now

@rt4914 rt4914 added the good first issue This item is good for new contributors to make their pull request. label Feb 8, 2021
@rt4914 rt4914 added this to the Backlog milestone Feb 8, 2021
@anandwana001
Copy link
Contributor

unassigning as no further update.

@ArpitShukIa
Copy link
Contributor

I would like to work on this. Assign to me plz.

@seanlip seanlip added bug End user-perceivable behaviors which are not desirable. and removed issue_user_learner labels Mar 29, 2023
@adhiamboperes
Copy link
Collaborator

adhiamboperes commented Oct 4, 2023

It doesn't seem like @backpackerdeveloper is still working on this issue. Note to other devs: We agreed that the approach taken in #5147 is fine, and there are comments on the PR that need to be addressed for the solution to be complete.

Note: You need to have Bazel set up and running in order to resolve this.

@Cyclotron17
Copy link

Cyclotron17 commented Dec 7, 2023

Hi Team,

I hope you're doing well. I've encountered an issue related to converting dp to sdp in our Android project. After some research, I found a solution that involves using the "sdp" library to make our layout dimensions more adaptable across different screen sizes and resolutions.

To implement this solution, I propose the following changes:

Added "sdp" Library:
In the app-level build.gradle file, add the "sdp" library dependency:

in app-level build.gradle add the following dependency
implementation 'com.intuit.sdp:sdp-android:1.0.6'

Updated the Layout XML:
Modify the layout_width and layout_height attributes in the layout XML file to use sdp:

in the splash_activity.xml file change the width and height as following

Define sdp Dimensions:
In the "dimens.xml" file in the "res/values" directory to include the sdp dimensions:

<!-- Example dimension for width -->
<dimen name="width_228sdp">228sdp</dimen>

<!-- Example dimension for height -->
<dimen name="height_88sdp">88sdp</dimen>
These changes should resolve the issue by making our layout dimensions scalable. Please review and let me know if you have any feedback or concerns.

Thanks,
Can you please assign me this issue?

@adhiamboperes
Copy link
Collaborator

Hi Team,

I hope you're doing well. I've encountered an issue related to converting dp to sdp in our Android project. After some research, I found a solution that involves using the "sdp" library to make our layout dimensions more adaptable across different screen sizes and resolutions.

To implement this solution, I propose the following changes:

Added "sdp" Library: In the app-level build.gradle file, add the "sdp" library dependency:

in app-level build.gradle add the following dependency implementation 'com.intuit.sdp:sdp-android:1.0.6'

Updated the Layout XML: Modify the layout_width and layout_height attributes in the layout XML file to use sdp:

in the splash_activity.xml file change the width and height as following Define sdp Dimensions: In the "dimens.xml" file in the "res/values" directory to include the sdp dimensions:

<!-- Example dimension for width -->
<dimen name="width_228sdp">228sdp</dimen>

<!-- Example dimension for height -->
<dimen name="height_88sdp">88sdp</dimen>

These changes should resolve the issue by making our layout dimensions scalable. Please review and let me know if you have any feedback or concerns.
Thanks, Can you please assign me this issue?

@Cyclotron17, the approach is sound. But as per my previous comment, you also need to add the dependency to bazel, and I have linked a way to do it.

@Cyclotron17
Copy link

Hi Team,
I hope you're doing well. I've encountered an issue related to converting dp to sdp in our Android project. After some research, I found a solution that involves using the "sdp" library to make our layout dimensions more adaptable across different screen sizes and resolutions.
To implement this solution, I propose the following changes:
Added "sdp" Library: In the app-level build.gradle file, add the "sdp" library dependency:
in app-level build.gradle add the following dependency implementation 'com.intuit.sdp:sdp-android:1.0.6'
Updated the Layout XML: Modify the layout_width and layout_height attributes in the layout XML file to use sdp:
in the splash_activity.xml file change the width and height as following Define sdp Dimensions: In the "dimens.xml" file in the "res/values" directory to include the sdp dimensions:

<!-- Example dimension for width -->
<dimen name="width_228sdp">228sdp</dimen>

<!-- Example dimension for height -->
<dimen name="height_88sdp">88sdp</dimen>

These changes should resolve the issue by making our layout dimensions scalable. Please review and let me know if you have any feedback or concerns.
Thanks, Can you please assign me this issue?

@Cyclotron17, the approach is sound. But as per my previous comment, you also need to add the dependency to bazel, and I have linked a way to do it.

Sure thing, will be adding that as well

Cyclotron17 added a commit to Cyclotron17/oppia-android that referenced this issue Dec 10, 2023
@BenHenning BenHenning added this to the 1.0 Global availability milestone Aug 29, 2024
@TanishMoral11
Copy link
Collaborator

TanishMoral11 commented Oct 8, 2024

Hey @anandwana001, Can You Please Assign This Issue To Me.

@adhiamboperes
Copy link
Collaborator

@TanishMoral11, assigned.

@TanishMoral11
Copy link
Collaborator

Hey @adhiamboperes ,

I want to share the approach I'm planning to take for this issue, and I would appreciate your feedback on whether it is correct:

splash_image.xml:
I will create a new layer-list drawable, which includes:

A background color (@color/oppiaPrimaryLight)
The splash image (@drawable/splash_page) centered.

splash_page.xml:
I plan to modify the path data for the splash image, and I will remove the old clip-path.

styles.xml:
I will update the SplashScreenTheme to reference the new splash_image drawable, and set adjustViewBounds to true to handle different screen sizes.

Can you please confirm if this approach is correct, or suggest any changes I should make?

Thank you!

@adhiamboperes
Copy link
Collaborator

@TanishMoral11, I think splash_page is a vector that is generated a green bg + @drawable/full_oppia_logo. It maybe thage you need to completely replace the splash_page with the new drawable you describe. Could you please try it out and let us know.

@TanishMoral11
Copy link
Collaborator

@adhiamboperes PTAL #5555

subhajitxyz pushed a commit to subhajitxyz/oppia-android that referenced this issue Nov 19, 2024
…le and updated styles (oppia#5559)

Fixes oppia#2652: This PR aims to enhance the splash screen implementation by
making the following changes:

- **splash_image.xml**: Created a new layer-list drawable that includes
a background color (`@color/oppiaPrimaryLight`) and centers the splash
image (`@drawable/splash_page`).
- **splash_page.xml**: Modified the path data for the splash image and
removed the old clip-path to ensure proper rendering.
- **styles.xml**: Updated the `SplashScreenTheme` to reference the new
`splash_image` drawable and set `adjustViewBounds` to true, allowing for
better handling of different screen sizes.

These changes are intended to improve the visual consistency and
responsiveness of the splash screen across various devices.

## Essential Checklist
- [x] The PR title and explanation each start with "Fix #bugnum: " (If
this PR fixes part of an issue, prefix the title with "Fix part of
#bugnum: ...").
- [x] Any changes to `scripts/assets` files have their rationale
included in the PR explanation.
- [x] The PR follows the [style
guide](https://github.com/oppia/oppia-android/wiki/Coding-style-guide).
- [x] The PR does not contain any unnecessary code changes from Android
Studio
([reference](https://github.com/oppia/oppia-android/wiki/Guidance-on-submitting-a-PR#undo-unnecessary-changes)).
- [x] The PR is made from a branch that's **not** called "develop" and
is up-to-date with "develop".
- [x] The PR is **assigned** to the appropriate reviewers
([reference](https://github.com/oppia/oppia-android/wiki/Guidance-on-submitting-a-PR#clarification-regarding-assignees-and-reviewers-section)).

Before : 

https://github.com/user-attachments/assets/161eb1ca-57b1-4b63-829a-de41f1b99702

After : 

https://github.com/user-attachments/assets/fcd480ff-aabd-4fe3-9887-b9bf50b276ac

---------

Co-authored-by: Adhiambo Peres <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug End user-perceivable behaviors which are not desirable. good first issue This item is good for new contributors to make their pull request. Impact: Low Low perceived user impact (e.g. edge cases). Z-ibt Temporary label for Ben to keep track of issues he's triaged.