1*90c8c64dSAndroid Build Coastguard Worker /* 2*90c8c64dSAndroid Build Coastguard Worker * Copyright 2014 The Android Open Source Project 3*90c8c64dSAndroid Build Coastguard Worker * 4*90c8c64dSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*90c8c64dSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*90c8c64dSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*90c8c64dSAndroid Build Coastguard Worker * 8*90c8c64dSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*90c8c64dSAndroid Build Coastguard Worker * 10*90c8c64dSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*90c8c64dSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*90c8c64dSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*90c8c64dSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*90c8c64dSAndroid Build Coastguard Worker * limitations under the License. 15*90c8c64dSAndroid Build Coastguard Worker */ 16*90c8c64dSAndroid Build Coastguard Worker package com.example.android.clippingbasic; 17*90c8c64dSAndroid Build Coastguard Worker 18*90c8c64dSAndroid Build Coastguard Worker import com.example.android.common.logger.Log; 19*90c8c64dSAndroid Build Coastguard Worker 20*90c8c64dSAndroid Build Coastguard Worker import android.graphics.Outline; 21*90c8c64dSAndroid Build Coastguard Worker import android.support.v4.app.Fragment; 22*90c8c64dSAndroid Build Coastguard Worker import android.os.Bundle; 23*90c8c64dSAndroid Build Coastguard Worker import android.view.LayoutInflater; 24*90c8c64dSAndroid Build Coastguard Worker import android.view.View; 25*90c8c64dSAndroid Build Coastguard Worker import android.view.ViewGroup; 26*90c8c64dSAndroid Build Coastguard Worker import android.view.ViewOutlineProvider; 27*90c8c64dSAndroid Build Coastguard Worker import android.widget.Button; 28*90c8c64dSAndroid Build Coastguard Worker import android.widget.TextView; 29*90c8c64dSAndroid Build Coastguard Worker 30*90c8c64dSAndroid Build Coastguard Worker /** 31*90c8c64dSAndroid Build Coastguard Worker * This sample shows how to clip a {@link View} using an {@link Outline}. 32*90c8c64dSAndroid Build Coastguard Worker */ 33*90c8c64dSAndroid Build Coastguard Worker public class ClippingBasicFragment extends Fragment { 34*90c8c64dSAndroid Build Coastguard Worker 35*90c8c64dSAndroid Build Coastguard Worker private final static String TAG = "ClippingBasicFragment"; 36*90c8c64dSAndroid Build Coastguard Worker 37*90c8c64dSAndroid Build Coastguard Worker /* Store the click count so that we can show a different text on every click. */ 38*90c8c64dSAndroid Build Coastguard Worker private int mClickCount = 0; 39*90c8c64dSAndroid Build Coastguard Worker 40*90c8c64dSAndroid Build Coastguard Worker /* The {@Link Outline} used to clip the image with. */ 41*90c8c64dSAndroid Build Coastguard Worker private ViewOutlineProvider mOutlineProvider; 42*90c8c64dSAndroid Build Coastguard Worker 43*90c8c64dSAndroid Build Coastguard Worker /* An array of texts. */ 44*90c8c64dSAndroid Build Coastguard Worker private String[] mSampleTexts; 45*90c8c64dSAndroid Build Coastguard Worker 46*90c8c64dSAndroid Build Coastguard Worker /* A reference to a {@Link TextView} that shows different text strings when clicked. */ 47*90c8c64dSAndroid Build Coastguard Worker private TextView mTextView; 48*90c8c64dSAndroid Build Coastguard Worker 49*90c8c64dSAndroid Build Coastguard Worker @Override onCreate(Bundle savedInstanceState)50*90c8c64dSAndroid Build Coastguard Worker public void onCreate(Bundle savedInstanceState) { 51*90c8c64dSAndroid Build Coastguard Worker super.onCreate(savedInstanceState); 52*90c8c64dSAndroid Build Coastguard Worker setHasOptionsMenu(true); 53*90c8c64dSAndroid Build Coastguard Worker mOutlineProvider = new ClipOutlineProvider(); 54*90c8c64dSAndroid Build Coastguard Worker mSampleTexts = getResources().getStringArray(R.array.sample_texts); 55*90c8c64dSAndroid Build Coastguard Worker } 56*90c8c64dSAndroid Build Coastguard Worker 57*90c8c64dSAndroid Build Coastguard Worker @Override onCreateView( LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)58*90c8c64dSAndroid Build Coastguard Worker public View onCreateView( 59*90c8c64dSAndroid Build Coastguard Worker LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { 60*90c8c64dSAndroid Build Coastguard Worker return inflater.inflate(R.layout.clipping_basic_fragment, container, false); 61*90c8c64dSAndroid Build Coastguard Worker } 62*90c8c64dSAndroid Build Coastguard Worker 63*90c8c64dSAndroid Build Coastguard Worker @Override onViewCreated(final View view, Bundle savedInstanceState)64*90c8c64dSAndroid Build Coastguard Worker public void onViewCreated(final View view, Bundle savedInstanceState) { 65*90c8c64dSAndroid Build Coastguard Worker super.onViewCreated(view, savedInstanceState); 66*90c8c64dSAndroid Build Coastguard Worker 67*90c8c64dSAndroid Build Coastguard Worker /* Set the initial text for the TextView. */ 68*90c8c64dSAndroid Build Coastguard Worker mTextView = (TextView) view.findViewById(R.id.text_view); 69*90c8c64dSAndroid Build Coastguard Worker changeText(); 70*90c8c64dSAndroid Build Coastguard Worker 71*90c8c64dSAndroid Build Coastguard Worker 72*90c8c64dSAndroid Build Coastguard Worker final View clippedView = view.findViewById(R.id.frame); 73*90c8c64dSAndroid Build Coastguard Worker 74*90c8c64dSAndroid Build Coastguard Worker /* Sets the OutlineProvider for the View. */ 75*90c8c64dSAndroid Build Coastguard Worker clippedView.setOutlineProvider(mOutlineProvider); 76*90c8c64dSAndroid Build Coastguard Worker 77*90c8c64dSAndroid Build Coastguard Worker /* When the button is clicked, the text is clipped or un-clipped. */ 78*90c8c64dSAndroid Build Coastguard Worker view.findViewById(R.id.button).setOnClickListener(new View.OnClickListener() { 79*90c8c64dSAndroid Build Coastguard Worker @Override 80*90c8c64dSAndroid Build Coastguard Worker public void onClick(View bt) { 81*90c8c64dSAndroid Build Coastguard Worker // Toggle whether the View is clipped to the outline 82*90c8c64dSAndroid Build Coastguard Worker if (clippedView.getClipToOutline()) { 83*90c8c64dSAndroid Build Coastguard Worker /* The Outline is set for the View, but disable clipping. */ 84*90c8c64dSAndroid Build Coastguard Worker clippedView.setClipToOutline(false); 85*90c8c64dSAndroid Build Coastguard Worker 86*90c8c64dSAndroid Build Coastguard Worker Log.d(TAG, String.format("Clipping to outline is disabled")); 87*90c8c64dSAndroid Build Coastguard Worker ((Button) bt).setText(R.string.clip_button); 88*90c8c64dSAndroid Build Coastguard Worker } else { 89*90c8c64dSAndroid Build Coastguard Worker /* Enables clipping on the View. */ 90*90c8c64dSAndroid Build Coastguard Worker clippedView.setClipToOutline(true); 91*90c8c64dSAndroid Build Coastguard Worker 92*90c8c64dSAndroid Build Coastguard Worker Log.d(TAG, String.format("Clipping to outline is enabled")); 93*90c8c64dSAndroid Build Coastguard Worker ((Button) bt).setText(R.string.unclip_button); 94*90c8c64dSAndroid Build Coastguard Worker } 95*90c8c64dSAndroid Build Coastguard Worker } 96*90c8c64dSAndroid Build Coastguard Worker }); 97*90c8c64dSAndroid Build Coastguard Worker 98*90c8c64dSAndroid Build Coastguard Worker /* When the text is clicked, a new string is shown. */ 99*90c8c64dSAndroid Build Coastguard Worker view.findViewById(R.id.text_view).setOnClickListener(new View.OnClickListener() { 100*90c8c64dSAndroid Build Coastguard Worker @Override 101*90c8c64dSAndroid Build Coastguard Worker public void onClick(View view) { 102*90c8c64dSAndroid Build Coastguard Worker mClickCount++; 103*90c8c64dSAndroid Build Coastguard Worker 104*90c8c64dSAndroid Build Coastguard Worker // Update the text in the TextView 105*90c8c64dSAndroid Build Coastguard Worker changeText(); 106*90c8c64dSAndroid Build Coastguard Worker 107*90c8c64dSAndroid Build Coastguard Worker // Invalidate the outline just in case the TextView changed size 108*90c8c64dSAndroid Build Coastguard Worker clippedView.invalidateOutline(); 109*90c8c64dSAndroid Build Coastguard Worker } 110*90c8c64dSAndroid Build Coastguard Worker }); 111*90c8c64dSAndroid Build Coastguard Worker } 112*90c8c64dSAndroid Build Coastguard Worker changeText()113*90c8c64dSAndroid Build Coastguard Worker private void changeText() { 114*90c8c64dSAndroid Build Coastguard Worker // Compute the position of the string in the array using the number of strings 115*90c8c64dSAndroid Build Coastguard Worker // and the number of clicks. 116*90c8c64dSAndroid Build Coastguard Worker String newText = mSampleTexts[mClickCount % mSampleTexts.length]; 117*90c8c64dSAndroid Build Coastguard Worker 118*90c8c64dSAndroid Build Coastguard Worker /* Once the text is selected, change the TextView */ 119*90c8c64dSAndroid Build Coastguard Worker mTextView.setText(newText); 120*90c8c64dSAndroid Build Coastguard Worker Log.d(TAG, String.format("Text was changed.")); 121*90c8c64dSAndroid Build Coastguard Worker 122*90c8c64dSAndroid Build Coastguard Worker 123*90c8c64dSAndroid Build Coastguard Worker } 124*90c8c64dSAndroid Build Coastguard Worker 125*90c8c64dSAndroid Build Coastguard Worker /** 126*90c8c64dSAndroid Build Coastguard Worker * A {@link ViewOutlineProvider} which clips the view with a rounded rectangle which is inset 127*90c8c64dSAndroid Build Coastguard Worker * by 10% 128*90c8c64dSAndroid Build Coastguard Worker */ 129*90c8c64dSAndroid Build Coastguard Worker private class ClipOutlineProvider extends ViewOutlineProvider { 130*90c8c64dSAndroid Build Coastguard Worker 131*90c8c64dSAndroid Build Coastguard Worker @Override getOutline(View view, Outline outline)132*90c8c64dSAndroid Build Coastguard Worker public void getOutline(View view, Outline outline) { 133*90c8c64dSAndroid Build Coastguard Worker final int margin = Math.min(view.getWidth(), view.getHeight()) / 10; 134*90c8c64dSAndroid Build Coastguard Worker outline.setRoundRect(margin, margin, view.getWidth() - margin, 135*90c8c64dSAndroid Build Coastguard Worker view.getHeight() - margin, margin / 2); 136*90c8c64dSAndroid Build Coastguard Worker } 137*90c8c64dSAndroid Build Coastguard Worker 138*90c8c64dSAndroid Build Coastguard Worker } 139*90c8c64dSAndroid Build Coastguard Worker }